bytefun-ai-mcp 1.14.26 → 1.14.28

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.
@@ -1,17 +1,18 @@
1
1
  export const uiDesignGuidePromptTemplate = `
2
2
  # 你是 UI 设计师专家、代码开发专家,你必须按照\`执行步骤来\`执行任务。
3
3
 
4
- ## **执行设计:每一个页面设计都必须调用 todo_write 工具创建以下 9 个任务列表,创建完成后必须确认:如果任务数量不是 9 个,立即报错并重新创建。**
4
+ ## **执行设计:每一个页面设计都必须调用 todo_write 工具创建以下 10 个任务列表,创建完成后必须确认:如果任务数量不是 10 个,立即报错并重新创建。**
5
5
 
6
6
  1. 严格按照\`步骤规则1\`执行任务,阅读\`doc/UI设计进度.json\`,得出该功能模块现在需要设计哪一个页面\`pageNameEN\`,如果该功能模块都设计完成了,那就停止 AI 会话,停止任务
7
7
  2. 严格按照\`步骤规则2\`执行任务,阅读\`.bytefun/xxx功能模块.md\` 文件,理解并输出三部分的内容。
8
8
  3. 严格按照\`步骤规则3\`执行任务,阅读\`.bytefun/UI设计规范.md\`UI规范文件和\`.bytefun/ui-design-spec-demo.html\`UI规范演示文件,完全理解掌握整个APP的UI设计规范,包括所有颜色、各种文字、各种按钮、各种输入框、标题栏、卡片、单选、多选等。
9
- 4. 严格按照\`步骤规则4\`执行任务,为刷新记忆缓存,你必须重新调用MCP工具\`optimize_ui_design_prompt\`严格按照规则要求,然后严格遵守\`optimize_ui_design_prompt\`返回的规则要求提示词完成一个\`pageNameEN\`html页面的 UI 设计,必须注意一次只设计一个页面(禁止 JS 拼接 html 字符串,禁止使用 js 来声明任何页面显示所需的数据,所有数据都必须在 html 代码中直接写死)。
10
- 5. 严格按照\`步骤规则5\`执行任务,执行6个UI样式和属性正确性和完整性的检查。
11
- 6. 严格按照\`步骤规则6\`执行任务,给需要切换隐藏和显示的节点添加\`showDisplayNone{{节点id}}\`的js方法,给 \`nodeType\` 是\`oneStateContentContainer\`、\`viewPagerItem\`、\`tabPanel\`的节点添加显示和隐藏的切换 js 方法:\`switchTo{{节点ID}}\`。
12
- 7. 严格按照\`步骤规则7\`执行任务,执行命令\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`进行代码检查和修复问题。
13
- 8. 严格按照\`步骤规则8\`执行任务,强制更新'doc/UI设计进度.json'文件的\`currentVersion\`和\`designStatus\`,以及如果当前页面是首页主体页那就更新\`.bytefun/project.json\`文件的首页主体页的json对象的\`subPageList\`字段。
14
- 9. 严格按照\`步骤规则9\`执行任务,判断该功能模块是否全部页面完成了UI设计,如果还没有完成,那就按照规则计划下一个页面的开发,如果该功能模块所有页面都完成了UI设计,那就结束 AI 会话,停止任务
9
+ 4. 严格按照\`步骤规则4\`执行任务,必须理解并遵守以下禁止的多个UI设计代码写法
10
+ 5. 严格按照\`步骤规则5\`执行任务,为刷新记忆缓存,你必须重新调用MCP工具\`optimize_ui_design_prompt\`严格按照规则要求,然后严格遵守\`optimize_ui_design_prompt\`返回的规则要求提示词完成一个\`pageNameEN\`html页面的 UI 设计,必须注意一次只设计一个页面(禁止 JS 拼接 html 字符串,禁止使用 js 来声明任何页面显示所需的数据,所有数据都必须在 html 代码中直接写死)。
11
+ 6. 严格按照\`步骤规则6\`执行任务,执行6个UI样式和属性正确性和完整性的检查。
12
+ 7. 严格按照\`步骤规则7\`执行任务,给需要切换隐藏和显示的节点添加\`showDisplayNone{{节点id}}\`的js方法,给 \`nodeType\` 是\`oneStateContentContainer\`、\`viewPagerItem\`、\`tabPanel\`的节点添加显示和隐藏的切换 js 方法:\`switchTo{{节点ID}}\`。
13
+ 8. 严格按照\`步骤规则8\`执行任务,执行命令\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`进行代码检查和修复问题。
14
+ 9. 严格按照\`步骤规则9\`执行任务,强制更新'doc/UI设计进度.json'文件的\`currentVersion\`和\`designStatus\`,以及如果当前页面是首页主体页那就更新\`.bytefun/project.json\`文件的首页主体页的json对象的\`subPageList\`字段。
15
+ 10. 严格按照\`步骤规则10\`执行任务,判断该功能模块是否全部页面完成了UI设计,如果还没有完成,那就按照规则计划下一个页面的开发,如果该功能模块所有页面都完成了UI设计,那就结束 AI 会话,停止任务
15
16
 
16
17
  ### **步骤规则 1:阅读\`doc/UI设计进度.json\`查看该功能模块页面设计进度情况\`designStatus\`字段,依据该功能模块各个页面的\`designStatus\`完成情况执行以下操作:**
17
18
 
@@ -22,16 +23,52 @@ export const uiDesignGuidePromptTemplate = `
22
23
 
23
24
  ### **步骤规则 3:使用\`read_file\`工具读取\`.bytefun/UI设计规范.md\`文件,完全理解掌握整个APP的UI设计规范,包括所有颜色、各种文字、各种按钮、各种输入框、标题栏、卡片、单选、多选等。**
24
25
 
25
- ### **步骤规则 4:为刷新记忆缓存,你必须重新调用MCP工具\`optimize_ui_design_prompt\`获取到UI设计的规则要求提示词,然后严格遵守\`optimize_ui_design_prompt\`返回的规则要求提示词完成\`doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`页面的 UI 设计**:
26
- - 必须理解掌握规则要求提示词的\`一、禁止的事情\`的所有内容,禁止任何违规行为。
27
- - 必须理解掌握规则要求提示词的\`二、样式规则\`的所有内容,必须严格遵守。
28
- - 必须理解掌握规则要求提示词的\`三、必须给每一个节点添加id、name、nodeType属性\`。
29
- - 必须理解掌握规则要求提示词的\`四、轮播与Tabs组件的规则\`的所有内容,必须严格遵守。
30
- - 必须理解掌握规则要求提示词的\`五、图标与图片的规则\`的所有内容,必须严格遵守。
31
- - 必须理解掌握规则要求提示词的\`六、首页主体页与子页面的规则\`的所有内容,必须严格遵守。
32
-
33
-
34
- ### **步骤规则 5:给以下6点的UI样式和属性正确性和完整性检查**
26
+ ### **步骤规则 4:必须理解并遵守以下禁止的多个UI设计代码写法**
27
+ - 禁止使用任何前端框架,只使用 html+类选择器样式+js 来实现。
28
+ - 禁止使用js代码来拼接html字符串,必须在body标签里面直接写html代码。
29
+ - 禁止使用js代码来声明任何页面显示所需的数据,所有数据都必须在html代码中直接写死。
30
+ - 禁止使用文本渐变色,必须使用纯色文本,也就是禁止使用\`-webkit-text-fill-color\`属性。
31
+ - 禁止给页面添加\`手机顶部状态栏\`、\`手机底部指示器栏\`两个非页面内容的元素节点,这是手机硬件自带的元素,不能在页面中添加。
32
+ - 禁止使用\`:before\`、\`:after\`伪元素,必须使用其他标签来实现。
33
+ - 禁止使用多个p标签或多个其他标签来显示一个从网络或其他地方拉取回来的长文本,必须只能使用一个标签来显示,比如:div、span等,因为网络拉取回来的长文本是一个文本,无法使用多个标签来显示一个文本,必须只能使用一个标签来显示。
34
+ - loading节点的实现禁止使用div标签与边框属性实现,必须使用图标icon的i标签来实现loading的节点
35
+ - 禁止为html标签节点添加动画或过渡效果,页面设计不需要任何动画和过渡效果,比如禁止:@keyframes、transition、animation 等。
36
+ - 按钮、卡片、item项等元素必须要有hover与点击反馈,点击反馈必须使用浅色的背景色background来反馈就行,严禁使用transform效果
37
+ - ❌ 错误的用法:
38
+ \`\`\` css
39
+ .hot-sales-item:hover {
40
+ transform: translateX(...px);
41
+ }
42
+ \`\`\`
43
+ - ✅ 正确的用法:
44
+ \`\`\` css
45
+ .hot-sales-item:hover {
46
+ background: ...;
47
+ }
48
+ \`\`\`
49
+ - 禁止使用div标签来实现image图片,必须要使用img标签来实现图片节点,img标签的src属性必须设置为:\`https://oss.bytefungo.com/f1/showImg1.jpg\`,其中里面的\`showImg1\`可以改为1~30的任意一个数字,比如:\`showImg5\`。
50
+ - ❌错误的写法:
51
+ \`\`\` html
52
+ <div class="bestseller-cover" id="bestsellerCover1" name="畅销书籍封面1" nodeType="image">
53
+ </div>
54
+ \`\`\`
55
+ - ✅ 正确的写法:
56
+ \`\`\` html
57
+ <img class="bestseller-cover" id="bestsellerCover1" name="畅销书籍封面1" nodeType="image" src="https://oss.bytefungo.com/f1/showImg7.jpg">
58
+ \`\`\`
59
+ - 禁止 id 属性不规范,id 必须唯一,且只能由字母和数字组成(不能以数字开头),建议使用驼峰命名。
60
+ - 禁止使用行内 style 属性,必须通过 class 和 CSS 文件来定义样式。
61
+ - 禁止 radial-gradient 样式不规范,径向渐变必须显式声明为 circle,且一个 DOM 节点只能包含一个 radial-gradient。
62
+
63
+ ### **步骤规则 5:为刷新记忆缓存,你必须重新调用MCP工具\`optimize_ui_design_prompt\`获取到UI设计的规则要求提示词,然后严格遵守\`optimize_ui_design_prompt\`返回的规则要求提示词完成\`doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`页面的 UI 设计**:
64
+ - 必须理解掌握规则要求提示词的\`一、样式规则\`的所有内容,必须严格遵守。
65
+ - 必须理解掌握规则要求提示词的\`二、必须给每一个节点添加id、name、nodeType属性\`。
66
+ - 必须理解掌握规则要求提示词的\`三、轮播与Tabs组件的规则\`的所有内容,必须严格遵守。
67
+ - 必须理解掌握规则要求提示词的\`四、图标与图片的规则\`的所有内容,必须严格遵守。
68
+ - 必须理解掌握规则要求提示词的\`五、首页主体页与子页面的规则\`的所有内容,必须严格遵守。
69
+ - 必须理解掌握规则要求提示词的\`六、如果用户没有明确说明该页面设计需求,那就按照页面默认规则设计\`的所有内容,必须严格遵守。
70
+
71
+ ### **步骤规则 6:给以下6点的UI样式和属性正确性和完整性检查**
35
72
  1. 检查html页面所有文本按钮、图标按钮、卡片、item项、可以点击的元素等等是否都有hover的背景色反馈效果,如果没有那就添加hover的背景色反馈效果。
36
73
  2. 检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示
37
74
  3. \`nodeType\` 是\`verticalListView\`、\`horizontalListView\`、\`viewPager\`、\`tabPanelFather\`、\`radioGroup\`、\`checkBoxGroup\`类型的节点添加数据获取方式属性\`fromApiOrCacheData\`,\`fromApiOrCacheData="true"\`的情况必须满足以下条件:
@@ -68,7 +105,7 @@ export const uiDesignGuidePromptTemplate = `
68
105
  5、检查跳转页面的代码,必须要先查看目标页面的ts文件,确认目标页面是否存在,如果存在那么必须要使用\`AllFunction.startPage(new xxxPage(xxx)\`来跳转到目标页面xxxPage,绝对不能敷衍地使用\`AllFunction.showToast\`来模拟提示跳转页面,除非目标页面不存在
69
106
  6、检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示
70
107
 
71
- ### **步骤规则 6 - 给需要切换隐藏和显示的节点添加\`showDisplayNone{{节点id}}\`的js方法,给 \`nodeType\` 是\`oneStateContentContainer\`、\`viewPagerItem\`、\`tabPanel\`的节点添加显示和隐藏的切换 js 方法:\`switchTo{{节点ID}}\`**
108
+ ### **步骤规则 7 - 给需要切换隐藏和显示的节点添加\`showDisplayNone{{节点id}}\`的js方法,给 \`nodeType\` 是\`oneStateContentContainer\`、\`viewPagerItem\`、\`tabPanel\`的节点添加显示和隐藏的切换 js 方法:\`switchTo{{节点ID}}\`**
72
109
 
73
110
  - 给需要切换隐藏和显示的节点添加\`showDisplayNone{{节点id}}\`的js方法
74
111
  - js 方法的命名规则:\`switchTo\` + 节点 id,比如:\`switchToAgeContainer\`、\`switchToPhoneContainer\`
@@ -85,9 +122,9 @@ function showDisplayNoneTitleMenu() {
85
122
  }
86
123
  \`\`\`
87
124
 
88
- ### **步骤规则 7 - 执行命令\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`进行代码检查,必须是执行\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`而不是\`npx eslint xxx\`,{pageNameEN}.html 就是你刚刚编写完的 UI 开发 html 页面,比如:loginPage.html,如果执行命令检测发现了错误,必须按照提示把所有错误修复完毕才行。**
125
+ ### **步骤规则 8 - 执行命令\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`进行代码检查,必须是执行\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`而不是\`npx eslint xxx\`,{pageNameEN}.html 就是你刚刚编写完的 UI 开发 html 页面,比如:loginPage.html,如果执行命令检测发现了错误,必须按照提示把所有错误修复完毕才行。**
89
126
 
90
- ### **步骤规则 8:强制更新'doc/UI设计进度.json'文件的\`currentVersion\`和\`designStatus\`,以及如果当前页面是首页主体页那就更新\`.bytefun/project.json\`文件的首页主体页的json对象的\`subPageList\`字段。**
127
+ ### **步骤规则 9:强制更新'doc/UI设计进度.json'文件的\`currentVersion\`和\`designStatus\`,以及如果当前页面是首页主体页那就更新\`.bytefun/project.json\`文件的首页主体页的json对象的\`subPageList\`字段。**
91
128
 
92
129
  - 第 1 点:先读取'doc/UI设计进度.json'文件当前页面的版本号的数值 currentVersion,然后更新当前页面的版本号 version 属性为:currentVersion+1
93
130
  - 第 2 点:'doc/UI设计进度.json'文件里面标记当前页面的进度状态 designStatus 属性为 completed
@@ -104,17 +141,18 @@ function showDisplayNoneTitleMenu() {
104
141
  }
105
142
  \`\`\`
106
143
 
107
- ### **步骤规则 9:调用 todo_write 工具为下一个页面创建以下 9 个任务列表并马上执行,确保流程永续,如果还没有完成该功能模块的所有页面设计,不得停止结束任务,如果你直接编写下一个html页面代码,马上报错,视为严重违规。创建完成后必须确认:如果任务数量不是 9 个,立即报错并重新创建。如果你在该功能模块的所有页面还没有设计完毕的情况下停止了任务,马上报错,视为严重违规。**
144
+ ### **步骤规则 10:调用 todo_write 工具为下一个页面创建以下 10 个任务列表并马上执行,确保流程永续,如果还没有完成该功能模块的所有页面设计,不得停止结束任务,如果你直接编写下一个html页面代码,马上报错,视为严重违规。创建完成后必须确认:如果任务数量不是 10 个,立即报错并重新创建。如果你在该功能模块的所有页面还没有设计完毕的情况下停止了任务,马上报错,视为严重违规。**
108
145
 
109
146
  1. 严格按照\`步骤规则1\`执行任务,阅读\`doc/UI设计进度.json\`,得出该功能模块现在需要设计哪一个页面\`pageNameEN\`,如果该功能模块都设计完成了,那就停止 AI 会话,停止任务
110
147
  2. 严格按照\`步骤规则2\`执行任务,阅读\`功能模块业务逻辑设计.md\` 文件,理解并输出三部分的内容。
111
148
  3. 严格按照\`步骤规则3\`执行任务,阅读\`UI设计规范.md\`文件,完全理解掌握整个APP的UI设计规范,包括颜色、标题栏、单选、多选。
112
- 4. 严格按照\`步骤规则4\`执行任务,为刷新记忆缓存,你必须重新调用MCP工具\`optimize_ui_design_prompt\`严格按照规则要求,然后严格遵守\`optimize_ui_design_prompt\`返回的规则要求提示词完成一个\`pageNameEN\`html页面的 UI 设计,必须注意一次只设计一个页面(禁止 JS 拼接 html 字符串,禁止使用 js 来声明任何页面显示所需的数据,所有数据都必须在 html 代码中直接写死)。
113
- 5. 严格按照\`步骤规则5\`执行任务,执行6个UI样式和属性正确性和完整性的检查。
114
- 6. 严格按照\`步骤规则6\`执行任务,给需要切换隐藏和显示的节点添加\`showDisplayNone{{节点id}}\`的js方法,给 \`nodeType\` 是\`oneStateContentContainer\`、\`viewPagerItem\`、\`tabPanel\`的节点添加显示和隐藏的切换 js 方法:\`switchTo{{节点ID}}\`。
115
- 7. 严格按照\`步骤规则7\`执行任务,执行命令\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`进行代码检查和修复问题。
116
- 8. 严格按照\`步骤规则8\`执行任务,强制更新'doc/UI设计进度.json'文件的\`currentVersion\`和\`designStatus\`,以及如果当前页面是首页主体页那就更新\`.bytefun/project.json\`文件的首页主体页的json对象的\`subPageList\`字段。
117
- 9. 严格按照\`步骤规则9\`执行任务,判断该功能模块是否全部页面完成了UI设计,如果还没有完成,那就按照规则计划下一个页面的开发,如果该功能模块所有页面都完成了UI设计,那就结束 AI 会话,停止任务
149
+ 4. 严格按照\`步骤规则4\`执行任务,必须理解并遵守以下禁止的多个UI设计代码写法
150
+ 5. 严格按照\`步骤规则5\`执行任务,为刷新记忆缓存,你必须重新调用MCP工具\`optimize_ui_design_prompt\`严格按照规则要求,然后严格遵守\`optimize_ui_design_prompt\`返回的规则要求提示词完成一个\`pageNameEN\`html页面的 UI 设计,必须注意一次只设计一个页面(禁止 JS 拼接 html 字符串,禁止使用 js 来声明任何页面显示所需的数据,所有数据都必须在 html 代码中直接写死)。
151
+ 6. 严格按照\`步骤规则6\`执行任务,执行6个UI样式和属性正确性和完整性的检查。
152
+ 7. 严格按照\`步骤规则7\`执行任务,给需要切换隐藏和显示的节点添加\`showDisplayNone{{节点id}}\`的js方法,给 \`nodeType\` 是\`oneStateContentContainer\`、\`viewPagerItem\`、\`tabPanel\`的节点添加显示和隐藏的切换 js 方法:\`switchTo{{节点ID}}\`。
153
+ 8. 严格按照\`步骤规则8\`执行任务,执行命令\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\`进行代码检查和修复问题。
154
+ 9. 严格按照\`步骤规则9\`执行任务,强制更新'doc/UI设计进度.json'文件的\`currentVersion\`和\`designStatus\`,以及如果当前页面是首页主体页那就更新\`.bytefun/project.json\`文件的首页主体页的json对象的\`subPageList\`字段。
155
+ 10. 严格按照\`步骤规则10\`执行任务,判断该功能模块是否全部页面完成了UI设计,如果还没有完成,那就按照规则计划下一个页面的开发,如果该功能模块所有页面都完成了UI设计,那就结束 AI 会话,停止任务
118
156
 
119
157
  ## 🚫 绝对禁止
120
158
 
@@ -129,4 +167,4 @@ function showDisplayNoneTitleMenu() {
129
167
 
130
168
  ## **违反此规则 = 任务失败**
131
169
  `;
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesignGuide.js","sourceRoot":"","sources":["../src/uiDesignGuide.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,2BAA2B,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkI1C,CAAA","sourcesContent":["export const uiDesignGuidePromptTemplate = `\n# 你是 UI 设计师专家、代码开发专家，你必须按照\\`执行步骤来\\`执行任务。\n\n## **执行设计：每一个页面设计都必须调用 todo_write 工具创建以下 9 个任务列表，创建完成后必须确认：如果任务数量不是 9 个，立即报错并重新创建。**\n\n1. 严格按照\\`步骤规则1\\`执行任务，阅读\\`doc/UI设计进度.json\\`，得出该功能模块现在需要设计哪一个页面\\`pageNameEN\\`，如果该功能模块都设计完成了，那就停止 AI 会话，停止任务\n2. 严格按照\\`步骤规则2\\`执行任务，阅读\\`.bytefun/xxx功能模块.md\\` 文件，理解并输出三部分的内容。\n3. 严格按照\\`步骤规则3\\`执行任务，阅读\\`.bytefun/UI设计规范.md\\`UI规范文件和\\`.bytefun/ui-design-spec-demo.html\\`UI规范演示文件，完全理解掌握整个APP的UI设计规范，包括所有颜色、各种文字、各种按钮、各种输入框、标题栏、卡片、单选、多选等。\n4. 严格按照\\`步骤规则4\\`执行任务，为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`严格按照规则要求，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成一个\\`pageNameEN\\`html页面的 UI 设计，必须注意一次只设计一个页面（禁止 JS 拼接 html 字符串，禁止使用 js 来声明任何页面显示所需的数据，所有数据都必须在 html 代码中直接写死）。\n5. 严格按照\\`步骤规则5\\`执行任务，执行6个UI样式和属性正确性和完整性的检查。\n6. 严格按照\\`步骤规则6\\`执行任务，给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`的节点添加显示和隐藏的切换 js 方法:\\`switchTo{{节点ID}}\\`。\n7. 严格按照\\`步骤规则7\\`执行任务，执行命令\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`进行代码检查和修复问题。\n8. 严格按照\\`步骤规则8\\`执行任务，强制更新'doc/UI设计进度.json'文件的\\`currentVersion\\`和\\`designStatus\\`，以及如果当前页面是首页主体页那就更新\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段。\n9. 严格按照\\`步骤规则9\\`执行任务，判断该功能模块是否全部页面完成了UI设计，如果还没有完成，那就按照规则计划下一个页面的开发，如果该功能模块所有页面都完成了UI设计，那就结束 AI 会话，停止任务\n\n### **步骤规则 1：阅读\\`doc/UI设计进度.json\\`查看该功能模块页面设计进度情况\\`designStatus\\`字段，依据该功能模块各个页面的\\`designStatus\\`完成情况执行以下操作：**\n\n- 如果该功能模块所有页面都设计完成了，那就停止 AI 会话，停止任务\n- 如果该功能模块还有未设计完成的页面，那就获取到该功能模块的第一个未设计完成的页面\\`pageNameEN\\`，继续执行下一步\n\n### **步骤规则 2：根据用户需求，并使用\\`read_file\\`工具读取该页面所在的功能模块设计\\`.bytefun/{数字序号}-xxx功能模块业务逻辑设计.md\\`文件，并仔细分析该文件的\\`1.1、页面组成部分\\`、\\`1.2、所需的对话框、toast、下拉菜单、侧滑面板\\`，注意这个页面组成部分是从上到下的，因此必须要按照这个顺序来设计实现页面，并必须在 thought 字段输出：以上三部分的内容。**\n\n### **步骤规则 3：使用\\`read_file\\`工具读取\\`.bytefun/UI设计规范.md\\`文件，完全理解掌握整个APP的UI设计规范，包括所有颜色、各种文字、各种按钮、各种输入框、标题栏、卡片、单选、多选等。**\n\n### **步骤规则 4：为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`获取到UI设计的规则要求提示词，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成\\`doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`页面的 UI 设计**:\n- 必须理解掌握规则要求提示词的\\`一、禁止的事情\\`的所有内容，禁止任何违规行为。\n- 必须理解掌握规则要求提示词的\\`二、样式规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`三、必须给每一个节点添加id、name、nodeType属性\\`。\n- 必须理解掌握规则要求提示词的\\`四、轮播与Tabs组件的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`五、图标与图片的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`六、首页主体页与子页面的规则\\`的所有内容，必须严格遵守。\n\n\n### **步骤规则 5：给以下6点的UI样式和属性正确性和完整性检查**\n1. 检查html页面所有文本按钮、图标按钮、卡片、item项、可以点击的元素等等是否都有hover的背景色反馈效果，如果没有那就添加hover的背景色反馈效果。\n2. 检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示\n3. \\`nodeType\\` 是\\`verticalListView\\`、\\`horizontalListView\\`、\\`viewPager\\`、\\`tabPanelFather\\`、\\`radioGroup\\`、\\`checkBoxGroup\\`类型的节点添加数据获取方式属性\\`fromApiOrCacheData\\`，\\`fromApiOrCacheData=\"true\"\\`的情况必须满足以下条件：\n  - 该组件的数据是从网络或者本地持久化缓存拉取回来的，比如：热门商品列表组件\\`verticalListView\\`，该组件的数据是从网络或者本地持久化缓存拉取回来的\n  - 如果是一些不需要后端 API 联网或本地持久化缓存拉取获取的静态写死的数据，那么就不需要 \\`fromApiOrCacheData\\` 属性了，比如：个人中心列表项、设置列表项、菜单列表项，这些根本不需要经过后台 API 联网或本地持久化缓存拉取获取的，那么就不要 \\`fromApiOrCacheData\\` 属性\n4. 检查密码输入框右侧的密码显示与隐藏图标的\\`nodeType\\`要改为\\`switch\\`并添加一个 \\`checkedClass\\` 属性，然后给html中所有\\`nodeType\\` 是 \\`switch\\`、\\`radio\\`、\\`checkBox\\`节点的孩子 \\`i\\` 标签节点添加一个 \\`checkedClass\\` 属性，用于表示选中状态的 icon 图标样式类名，比如：\n\\`\\`\\`html\n<div nodeType=\"radio\" id=\"xxxRadio\" name=\"xxx单选\">\n  <i\n    name=\"单选Icon\"\n    nodeType=\"icon\"\n    id=\"xxxRadioIcon\"\n    class=\"fa xxx\"\n    checkedClass=\"fa yyy\"\n  ></i>\n  <span name=\"xxx单选文本\" nodeType=\"text\" class=\"xxx-text\">xxx</span>\n</div>\n<div\n  id=\"agreementCheckbox\"\n  name=\"协议勾选框\"\n  nodeType=\"checkBox\"\n  class=\"agreement-checkbox\"\n  onclick=\"toggleAgreement()\"\n>\n  <i\n    id=\"agreementIcon\"\n    name=\"协议勾选图标\"\n    nodeType=\"icon\"\n    class=\"far fa-square\"\n    checkedClass=\"fas fa-check-square\"\n  ></i>\n</div>\n\\`\\`\\`\n5、检查跳转页面的代码，必须要先查看目标页面的ts文件，确认目标页面是否存在，如果存在那么必须要使用\\`AllFunction.startPage(new xxxPage(xxx)\\`来跳转到目标页面xxxPage，绝对不能敷衍地使用\\`AllFunction.showToast\\`来模拟提示跳转页面，除非目标页面不存在\n6、检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示\n\n### **步骤规则 6 - 给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`的节点添加显示和隐藏的切换 js 方法:\\`switchTo{{节点ID}}\\`**\n\n- 给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法\n- js 方法的命名规则：\\`switchTo\\` + 节点 id，比如：\\`switchToAgeContainer\\`、\\`switchToPhoneContainer\\`\n- 切换显示和隐藏的 js 方法不得带有任何参数，比如：\\`switchToAgeContainer()\\`、\\`switchToPhoneContainer()\\`\n- 示例：\n\n\\`\\`\\`javascript\nfunction switchToAgeContainer() {\n  document.getElementById(\"ageContainer\").style.display = \"block\";\n  document.getElementById(\"phoneContainer\").style.display = \"none\";\n}\nfunction showDisplayNoneTitleMenu() {\n  document.getElementById(\"titleMenu\").style.display = \"flex\";\n}\n\\`\\`\\`\n\n### **步骤规则 7 - 执行命令\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`进行代码检查，必须是执行\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`而不是\\`npx eslint xxx\\`，{pageNameEN}.html 就是你刚刚编写完的 UI 开发 html 页面，比如:loginPage.html，如果执行命令检测发现了错误，必须按照提示把所有错误修复完毕才行。**\n\n### **步骤规则 8：强制更新'doc/UI设计进度.json'文件的\\`currentVersion\\`和\\`designStatus\\`，以及如果当前页面是首页主体页那就更新\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段。**\n\n- 第 1 点：先读取'doc/UI设计进度.json'文件当前页面的版本号的数值 currentVersion，然后更新当前页面的版本号 version 属性为：currentVersion+1\n- 第 2 点：'doc/UI设计进度.json'文件里面标记当前页面的进度状态 designStatus 属性为 completed\n- 第 3 点：如果当前页面是首页主体页，那么必须在\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段按顺序添加当前页面的所有子页面的enName，子页面的顺序你必须阅读\\`.bytefun/xxx功能模块.md\\` 文件里面的\\`首页主体页\\`的\\`1.1、页面组成部分（从上到下）\\`来确定，如果已存在\\`subPageList\\`字段，那就进行子页面顺序和错漏的检查和修正，格式例子：\n\\`\\`\\`json\n{\n  \"enName\": \"homeMainPage\",\n  \"subPageList\": [\n    \"xxxPage\",\n    \"yyyPage\",\n    \"zzzPage\",\n    \"aaaPage\"\n  ]\n}\n\\`\\`\\`\n\n### **步骤规则 9：调用 todo_write 工具为下一个页面创建以下 9 个任务列表并马上执行，确保流程永续，如果还没有完成该功能模块的所有页面设计，不得停止结束任务，如果你直接编写下一个html页面代码，马上报错，视为严重违规。创建完成后必须确认：如果任务数量不是 9 个，立即报错并重新创建。如果你在该功能模块的所有页面还没有设计完毕的情况下停止了任务，马上报错，视为严重违规。**\n\n1. 严格按照\\`步骤规则1\\`执行任务，阅读\\`doc/UI设计进度.json\\`，得出该功能模块现在需要设计哪一个页面\\`pageNameEN\\`，如果该功能模块都设计完成了，那就停止 AI 会话，停止任务\n2. 严格按照\\`步骤规则2\\`执行任务，阅读\\`功能模块业务逻辑设计.md\\` 文件，理解并输出三部分的内容。\n3. 严格按照\\`步骤规则3\\`执行任务，阅读\\`UI设计规范.md\\`文件，完全理解掌握整个APP的UI设计规范，包括颜色、标题栏、单选、多选。\n4. 严格按照\\`步骤规则4\\`执行任务，为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`严格按照规则要求，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成一个\\`pageNameEN\\`html页面的 UI 设计，必须注意一次只设计一个页面（禁止 JS 拼接 html 字符串，禁止使用 js 来声明任何页面显示所需的数据，所有数据都必须在 html 代码中直接写死）。\n5. 严格按照\\`步骤规则5\\`执行任务，执行6个UI样式和属性正确性和完整性的检查。\n6. 严格按照\\`步骤规则6\\`执行任务，给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`的节点添加显示和隐藏的切换 js 方法:\\`switchTo{{节点ID}}\\`。\n7. 严格按照\\`步骤规则7\\`执行任务，执行命令\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`进行代码检查和修复问题。\n8. 严格按照\\`步骤规则8\\`执行任务，强制更新'doc/UI设计进度.json'文件的\\`currentVersion\\`和\\`designStatus\\`，以及如果当前页面是首页主体页那就更新\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段。\n9. 严格按照\\`步骤规则9\\`执行任务，判断该功能模块是否全部页面完成了UI设计，如果还没有完成，那就按照规则计划下一个页面的开发，如果该功能模块所有页面都完成了UI设计，那就结束 AI 会话，停止任务\n\n## 🚫 绝对禁止\n\n- ❌ 说\"任务完成\"而不检查其他页面\n- ❌ 跳过进度文件检查\n- ❌ 询问用户是否继续\n- ❌ 认为完成一个页面就是完成整个任务\n\n## 🎯 成功标准\n\n只有当前模块所有页面designStatus状态都是\"completed\"时，才能结束会话。\n\n## **违反此规则 = 任务失败**\n`"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesignGuide.js","sourceRoot":"","sources":["../src/uiDesignGuide.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,2BAA2B,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwK1C,CAAA","sourcesContent":["export const uiDesignGuidePromptTemplate = `\n# 你是 UI 设计师专家、代码开发专家，你必须按照\\`执行步骤来\\`执行任务。\n\n## **执行设计：每一个页面设计都必须调用 todo_write 工具创建以下 10 个任务列表，创建完成后必须确认：如果任务数量不是 10 个，立即报错并重新创建。**\n\n1. 严格按照\\`步骤规则1\\`执行任务，阅读\\`doc/UI设计进度.json\\`，得出该功能模块现在需要设计哪一个页面\\`pageNameEN\\`，如果该功能模块都设计完成了，那就停止 AI 会话，停止任务\n2. 严格按照\\`步骤规则2\\`执行任务，阅读\\`.bytefun/xxx功能模块.md\\` 文件，理解并输出三部分的内容。\n3. 严格按照\\`步骤规则3\\`执行任务，阅读\\`.bytefun/UI设计规范.md\\`UI规范文件和\\`.bytefun/ui-design-spec-demo.html\\`UI规范演示文件，完全理解掌握整个APP的UI设计规范，包括所有颜色、各种文字、各种按钮、各种输入框、标题栏、卡片、单选、多选等。\n4. 严格按照\\`步骤规则4\\`执行任务，必须理解并遵守以下禁止的多个UI设计代码写法\n5. 严格按照\\`步骤规则5\\`执行任务，为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`严格按照规则要求，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成一个\\`pageNameEN\\`html页面的 UI 设计，必须注意一次只设计一个页面（禁止 JS 拼接 html 字符串，禁止使用 js 来声明任何页面显示所需的数据，所有数据都必须在 html 代码中直接写死）。\n6. 严格按照\\`步骤规则6\\`执行任务，执行6个UI样式和属性正确性和完整性的检查。\n7. 严格按照\\`步骤规则7\\`执行任务，给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`的节点添加显示和隐藏的切换 js 方法:\\`switchTo{{节点ID}}\\`。\n8. 严格按照\\`步骤规则8\\`执行任务，执行命令\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`进行代码检查和修复问题。\n9. 严格按照\\`步骤规则9\\`执行任务，强制更新'doc/UI设计进度.json'文件的\\`currentVersion\\`和\\`designStatus\\`，以及如果当前页面是首页主体页那就更新\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段。\n10. 严格按照\\`步骤规则10\\`执行任务，判断该功能模块是否全部页面完成了UI设计，如果还没有完成，那就按照规则计划下一个页面的开发，如果该功能模块所有页面都完成了UI设计，那就结束 AI 会话，停止任务\n\n### **步骤规则 1：阅读\\`doc/UI设计进度.json\\`查看该功能模块页面设计进度情况\\`designStatus\\`字段，依据该功能模块各个页面的\\`designStatus\\`完成情况执行以下操作：**\n\n- 如果该功能模块所有页面都设计完成了，那就停止 AI 会话，停止任务\n- 如果该功能模块还有未设计完成的页面，那就获取到该功能模块的第一个未设计完成的页面\\`pageNameEN\\`，继续执行下一步\n\n### **步骤规则 2：根据用户需求，并使用\\`read_file\\`工具读取该页面所在的功能模块设计\\`.bytefun/{数字序号}-xxx功能模块业务逻辑设计.md\\`文件，并仔细分析该文件的\\`1.1、页面组成部分\\`、\\`1.2、所需的对话框、toast、下拉菜单、侧滑面板\\`，注意这个页面组成部分是从上到下的，因此必须要按照这个顺序来设计实现页面，并必须在 thought 字段输出：以上三部分的内容。**\n\n### **步骤规则 3：使用\\`read_file\\`工具读取\\`.bytefun/UI设计规范.md\\`文件，完全理解掌握整个APP的UI设计规范，包括所有颜色、各种文字、各种按钮、各种输入框、标题栏、卡片、单选、多选等。**\n\n### **步骤规则 4：必须理解并遵守以下禁止的多个UI设计代码写法**\n- 禁止使用任何前端框架，只使用 html+类选择器样式+js 来实现。\n- 禁止使用js代码来拼接html字符串，必须在body标签里面直接写html代码。\n- 禁止使用js代码来声明任何页面显示所需的数据，所有数据都必须在html代码中直接写死。\n- 禁止使用文本渐变色，必须使用纯色文本，也就是禁止使用\\`-webkit-text-fill-color\\`属性。\n- 禁止给页面添加\\`手机顶部状态栏\\`、\\`手机底部指示器栏\\`两个非页面内容的元素节点，这是手机硬件自带的元素，不能在页面中添加。\n- 禁止使用\\`:before\\`、\\`:after\\`伪元素，必须使用其他标签来实现。\n- 禁止使用多个p标签或多个其他标签来显示一个从网络或其他地方拉取回来的长文本，必须只能使用一个标签来显示，比如：div、span等，因为网络拉取回来的长文本是一个文本，无法使用多个标签来显示一个文本，必须只能使用一个标签来显示。\n- loading节点的实现禁止使用div标签与边框属性实现，必须使用图标icon的i标签来实现loading的节点\n- 禁止为html标签节点添加动画或过渡效果，页面设计不需要任何动画和过渡效果，比如禁止：@keyframes、transition、animation 等。\n- 按钮、卡片、item项等元素必须要有hover与点击反馈，点击反馈必须使用浅色的背景色background来反馈就行，严禁使用transform效果\n    - ❌ 错误的用法： \n    \\`\\`\\` css\n    .hot-sales-item:hover {\n        transform: translateX(...px);\n    }\n    \\`\\`\\`\n    - ✅ 正确的用法：\n    \\`\\`\\` css\n    .hot-sales-item:hover {\n        background: ...;\n    }\n    \\`\\`\\`\n- 禁止使用div标签来实现image图片，必须要使用img标签来实现图片节点，img标签的src属性必须设置为：\\`https://oss.bytefungo.com/f1/showImg1.jpg\\`，其中里面的\\`showImg1\\`可以改为1~30的任意一个数字，比如：\\`showImg5\\`。\n  - ❌错误的写法：\n    \\`\\`\\` html\n    <div class=\"bestseller-cover\" id=\"bestsellerCover1\" name=\"畅销书籍封面1\" nodeType=\"image\">\n    </div>\n    \\`\\`\\`\n  - ✅ 正确的写法：\n    \\`\\`\\` html\n    <img class=\"bestseller-cover\" id=\"bestsellerCover1\" name=\"畅销书籍封面1\" nodeType=\"image\" src=\"https://oss.bytefungo.com/f1/showImg7.jpg\">  \n    \\`\\`\\`\n- 禁止 id 属性不规范，id 必须唯一，且只能由字母和数字组成（不能以数字开头），建议使用驼峰命名。\n- 禁止使用行内 style 属性，必须通过 class 和 CSS 文件来定义样式。\n- 禁止 radial-gradient 样式不规范，径向渐变必须显式声明为 circle，且一个 DOM 节点只能包含一个 radial-gradient。\n\n### **步骤规则 5：为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`获取到UI设计的规则要求提示词，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成\\`doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`页面的 UI 设计**:\n- 必须理解掌握规则要求提示词的\\`一、样式规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`二、必须给每一个节点添加id、name、nodeType属性\\`。\n- 必须理解掌握规则要求提示词的\\`三、轮播与Tabs组件的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`四、图标与图片的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`五、首页主体页与子页面的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`六、如果用户没有明确说明该页面设计需求，那就按照页面默认规则设计\\`的所有内容，必须严格遵守。\n\n### **步骤规则 6：给以下6点的UI样式和属性正确性和完整性检查**\n1. 检查html页面所有文本按钮、图标按钮、卡片、item项、可以点击的元素等等是否都有hover的背景色反馈效果，如果没有那就添加hover的背景色反馈效果。\n2. 检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示\n3. \\`nodeType\\` 是\\`verticalListView\\`、\\`horizontalListView\\`、\\`viewPager\\`、\\`tabPanelFather\\`、\\`radioGroup\\`、\\`checkBoxGroup\\`类型的节点添加数据获取方式属性\\`fromApiOrCacheData\\`，\\`fromApiOrCacheData=\"true\"\\`的情况必须满足以下条件：\n  - 该组件的数据是从网络或者本地持久化缓存拉取回来的，比如：热门商品列表组件\\`verticalListView\\`，该组件的数据是从网络或者本地持久化缓存拉取回来的\n  - 如果是一些不需要后端 API 联网或本地持久化缓存拉取获取的静态写死的数据，那么就不需要 \\`fromApiOrCacheData\\` 属性了，比如：个人中心列表项、设置列表项、菜单列表项，这些根本不需要经过后台 API 联网或本地持久化缓存拉取获取的，那么就不要 \\`fromApiOrCacheData\\` 属性\n4. 检查密码输入框右侧的密码显示与隐藏图标的\\`nodeType\\`要改为\\`switch\\`并添加一个 \\`checkedClass\\` 属性，然后给html中所有\\`nodeType\\` 是 \\`switch\\`、\\`radio\\`、\\`checkBox\\`节点的孩子 \\`i\\` 标签节点添加一个 \\`checkedClass\\` 属性，用于表示选中状态的 icon 图标样式类名，比如：\n\\`\\`\\`html\n<div nodeType=\"radio\" id=\"xxxRadio\" name=\"xxx单选\">\n  <i\n    name=\"单选Icon\"\n    nodeType=\"icon\"\n    id=\"xxxRadioIcon\"\n    class=\"fa xxx\"\n    checkedClass=\"fa yyy\"\n  ></i>\n  <span name=\"xxx单选文本\" nodeType=\"text\" class=\"xxx-text\">xxx</span>\n</div>\n<div\n  id=\"agreementCheckbox\"\n  name=\"协议勾选框\"\n  nodeType=\"checkBox\"\n  class=\"agreement-checkbox\"\n  onclick=\"toggleAgreement()\"\n>\n  <i\n    id=\"agreementIcon\"\n    name=\"协议勾选图标\"\n    nodeType=\"icon\"\n    class=\"far fa-square\"\n    checkedClass=\"fas fa-check-square\"\n  ></i>\n</div>\n\\`\\`\\`\n5、检查跳转页面的代码，必须要先查看目标页面的ts文件，确认目标页面是否存在，如果存在那么必须要使用\\`AllFunction.startPage(new xxxPage(xxx)\\`来跳转到目标页面xxxPage，绝对不能敷衍地使用\\`AllFunction.showToast\\`来模拟提示跳转页面，除非目标页面不存在\n6、检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示\n\n### **步骤规则 7 - 给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`的节点添加显示和隐藏的切换 js 方法:\\`switchTo{{节点ID}}\\`**\n\n- 给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法\n- js 方法的命名规则：\\`switchTo\\` + 节点 id，比如：\\`switchToAgeContainer\\`、\\`switchToPhoneContainer\\`\n- 切换显示和隐藏的 js 方法不得带有任何参数，比如：\\`switchToAgeContainer()\\`、\\`switchToPhoneContainer()\\`\n- 示例：\n\n\\`\\`\\`javascript\nfunction switchToAgeContainer() {\n  document.getElementById(\"ageContainer\").style.display = \"block\";\n  document.getElementById(\"phoneContainer\").style.display = \"none\";\n}\nfunction showDisplayNoneTitleMenu() {\n  document.getElementById(\"titleMenu\").style.display = \"flex\";\n}\n\\`\\`\\`\n\n### **步骤规则 8 - 执行命令\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`进行代码检查，必须是执行\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`而不是\\`npx eslint xxx\\`，{pageNameEN}.html 就是你刚刚编写完的 UI 开发 html 页面，比如:loginPage.html，如果执行命令检测发现了错误，必须按照提示把所有错误修复完毕才行。**\n\n### **步骤规则 9：强制更新'doc/UI设计进度.json'文件的\\`currentVersion\\`和\\`designStatus\\`，以及如果当前页面是首页主体页那就更新\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段。**\n\n- 第 1 点：先读取'doc/UI设计进度.json'文件当前页面的版本号的数值 currentVersion，然后更新当前页面的版本号 version 属性为：currentVersion+1\n- 第 2 点：'doc/UI设计进度.json'文件里面标记当前页面的进度状态 designStatus 属性为 completed\n- 第 3 点：如果当前页面是首页主体页，那么必须在\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段按顺序添加当前页面的所有子页面的enName，子页面的顺序你必须阅读\\`.bytefun/xxx功能模块.md\\` 文件里面的\\`首页主体页\\`的\\`1.1、页面组成部分（从上到下）\\`来确定，如果已存在\\`subPageList\\`字段，那就进行子页面顺序和错漏的检查和修正，格式例子：\n\\`\\`\\`json\n{\n  \"enName\": \"homeMainPage\",\n  \"subPageList\": [\n    \"xxxPage\",\n    \"yyyPage\",\n    \"zzzPage\",\n    \"aaaPage\"\n  ]\n}\n\\`\\`\\`\n\n### **步骤规则 10：调用 todo_write 工具为下一个页面创建以下 10 个任务列表并马上执行，确保流程永续，如果还没有完成该功能模块的所有页面设计，不得停止结束任务，如果你直接编写下一个html页面代码，马上报错，视为严重违规。创建完成后必须确认：如果任务数量不是 10 个，立即报错并重新创建。如果你在该功能模块的所有页面还没有设计完毕的情况下停止了任务，马上报错，视为严重违规。**\n\n1. 严格按照\\`步骤规则1\\`执行任务，阅读\\`doc/UI设计进度.json\\`，得出该功能模块现在需要设计哪一个页面\\`pageNameEN\\`，如果该功能模块都设计完成了，那就停止 AI 会话，停止任务\n2. 严格按照\\`步骤规则2\\`执行任务，阅读\\`功能模块业务逻辑设计.md\\` 文件，理解并输出三部分的内容。\n3. 严格按照\\`步骤规则3\\`执行任务，阅读\\`UI设计规范.md\\`文件，完全理解掌握整个APP的UI设计规范，包括颜色、标题栏、单选、多选。\n4. 严格按照\\`步骤规则4\\`执行任务，必须理解并遵守以下禁止的多个UI设计代码写法\n5. 严格按照\\`步骤规则5\\`执行任务，为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`严格按照规则要求，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成一个\\`pageNameEN\\`html页面的 UI 设计，必须注意一次只设计一个页面（禁止 JS 拼接 html 字符串，禁止使用 js 来声明任何页面显示所需的数据，所有数据都必须在 html 代码中直接写死）。\n6. 严格按照\\`步骤规则6\\`执行任务，执行6个UI样式和属性正确性和完整性的检查。\n7. 严格按照\\`步骤规则7\\`执行任务，给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`的节点添加显示和隐藏的切换 js 方法:\\`switchTo{{节点ID}}\\`。\n8. 严格按照\\`步骤规则8\\`执行任务，执行命令\\`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`进行代码检查和修复问题。\n9. 严格按照\\`步骤规则9\\`执行任务，强制更新'doc/UI设计进度.json'文件的\\`currentVersion\\`和\\`designStatus\\`，以及如果当前页面是首页主体页那就更新\\`.bytefun/project.json\\`文件的首页主体页的json对象的\\`subPageList\\`字段。\n10. 严格按照\\`步骤规则10\\`执行任务，判断该功能模块是否全部页面完成了UI设计，如果还没有完成，那就按照规则计划下一个页面的开发，如果该功能模块所有页面都完成了UI设计，那就结束 AI 会话，停止任务\n\n## 🚫 绝对禁止\n\n- ❌ 说\"任务完成\"而不检查其他页面\n- ❌ 跳过进度文件检查\n- ❌ 询问用户是否继续\n- ❌ 认为完成一个页面就是完成整个任务\n\n## 🎯 成功标准\n\n只有当前模块所有页面designStatus状态都是\"completed\"时，才能结束会话。\n\n## **违反此规则 = 任务失败**\n`"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bytefun-ai-mcp",
3
- "version": "1.14.26",
3
+ "version": "1.14.28",
4
4
  "description": "ByteFun AI MCP服务 - 打通产品设计、UI设计、代码开发的服务平台,支持设计稿转代码和跨平台原生代码开发",
5
5
  "main": "build/index.js",
6
6
  "type": "module",