bytefun-ai-mcp 1.14.43 → 1.14.45

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/build/uiDesign.js CHANGED
@@ -43,7 +43,7 @@ export const uiDesignPromptTemplate = `# UI设计规则,特别注意必须使
43
43
  - tab选项卡:\`tabPanelFather\`与\`tabMenuBar\`组合实现tab选项卡,注意tabMenuBar支持横向和竖向的tab选项卡,比如分类竖向的tab选项卡菜单栏,一般分类都使用tab选项卡来实现,禁止使用\`verticalListView\`和\`horizontalListView\`列表来代替tab选项卡。
44
44
  - 网格容器:gridContainer用于布局多个网格项,里面包含N个gridItem,比如:分类网格入口
45
45
  - 流式容器:用于布局多个子项,子项可以在一行显示,当位置不够时就换行显示,比如:一组标签tag的排版布局
46
- - 多状态容器:\`multiStateContainer\`, \`oneStateContentContainer\`,用于不是通过交互,而是通过逻辑状态变量变化而显示不同状态的内容容器,比如:登录状态和未登录状态分别显示不同的内容、加载中/加载失败/加载成功有数据/没有数据等状态切换、不同权限/等级/时期等等显示不同的功能,等等这些通过逻辑状态变量变化而显示不同状态的内容容器,都必须使用\`multiStateContainer\`和\`oneStateContentContainer\`来实现,特别注意脱离文档流的弹窗/Toast窗口容器类别的loading,不得使用\`oneStateContentContainer\`,应该使用\`dialogOverlay/dialog\`或者\`toast\`。
46
+ - 多状态容器:\`multiStateContainer\`, \`oneStateContentContainer\`,用于不是通过交互,而是通过逻辑状态变量变化而显示不同状态的内容容器,比如:登录状态和未登录状态分别显示不同的内容、不同权限/等级/时期等等显示不同的功能,等等这些通过逻辑状态变量变化而显示不同状态的内容容器,都必须使用\`multiStateContainer\`和\`oneStateContentContainer\`来实现,特别注意脱离文档流的弹窗/Toast窗口容器类别的loading,不得使用\`oneStateContentContainer\`,应该使用\`dialogOverlay/dialog\`或者\`toast\`。
47
47
  - 高级组件节点的nodeType结构规则:
48
48
  - 对话框:\`dialogOverlay\`是弹窗/Toast窗口容器的遮罩层,\`dialog\`是对话框的内容容器,\`dialogOverlay\`包含一个\`dialog\`,\`dialog\`一般屏幕居中显示
49
49
  - tab 选项卡:\`tabMenuBar\`是tab选项卡菜单栏,里面包含N个\`tabMenuBarItem\`,\`tabPanelFather\`是tab选项卡内容容器,里面包含N个\`tabPanel\`,\`tabMenuBar\`和\`tabPanelFather\`必须同时存在,\`tabPanel\`的数量必须和\`tabMenuBarItem\`的数量相同,注意tabMenuBar支持横向和竖向的tab选项卡,比如分类竖向的tab选项卡菜单栏,一般分类都使用tab选项卡来实现,禁止使用\`verticalListView\`和\`horizontalListView\`列表来代替tab选项卡。
@@ -101,43 +101,13 @@ export const uiDesignPromptTemplate = `# UI设计规则,特别注意必须使
101
101
  </tabPanelFather>
102
102
  \`\`\`
103
103
 
104
- ## 四、列表组件规则
105
- - 如果该列表的数据是从网络接口拉取的,那么必须使用多状态容器\`multiStateContainer\`将loading、联网失败、没有数据、有数据的四个状态使用\`oneStateContentContainer\`包起来并展示出来,其中有数据状态的\`oneStateContentContainer\`包含的就是该列表组件。
106
- - 如果列表数据只是网络聚合业务接口的一部分,那么该列表不需要loading和联网失败状态,只需要有数据状态和没有数据状态,比如首页的推荐列表、分类列表、最新动态列表等这些是首页业务聚合接口获取的,这些列表数据只是业务接口的一部分,不是独立的接口,所以不需要loading和联网失败状态。
107
- - 例子:
108
- \`\`\`html
109
- <multiStateContainer nodeType="multiStateContainer" id="listMultiStateContainer" name="列表多状态容器">
110
- <!-- 有数据状态的oneStateContentContainer -->
111
- <oneStateContentContainer nodeType="oneStateContentContainer" id="hasDataStateContainer" name="有数据状态的容器">
112
- <!-- 列表组件 -->
113
- <verticalListView nodeType="verticalListView" id="listView" fromApiOrCacheData="true" name="列表组件">
114
- <!-- 列表项 -->
115
- <listItemCard nodeType="listItemCard" id="listItem1" name="列表项1">
116
- <!-- 列表项内容 -->
117
- <text nodeType="text" id="listItem1Text" name="列表项1的文本">列表项1</text>
118
- </listItemCard>
119
- <!-- 更多列表项... -->
120
- </verticalListView>
121
- </oneStateContentContainer>
122
- <oneStateContentContainer nodeType="oneStateContentContainer" id="noDataStateContainer" name="没有数据状态的容器">
123
- <!-- 没有数据状态的提示 -->
124
- </oneStateContentContainer>
125
- <oneStateContentContainer nodeType="oneStateContentContainer" id="loadingStateContainer" name="loading状态的容器">
126
- <!-- loading状态的提示 -->
127
- </oneStateContentContainer>
128
- <oneStateContentContainer nodeType="oneStateContentContainer" id="networkErrorStateContainer" name="联网失败状态的容器">
129
- <!-- 联网失败状态的提示 -->
130
- </oneStateContentContainer>
131
- </multiStateContainer>
132
- \`\`\`
133
-
134
- ## 五、图标与图片的规则
104
+ ## 四、图标与图片的规则
135
105
  - 当需要icon图标时必须使用FontAwesome图标,比如:\`<i name="微信Icon" vtype="icon" id="wxIcon" class="fab fa-weixin"></i>\`,并且注意图标的颜色,比如微信图标一般使用绿色系,QQ图标一般使用蓝色系,微博图标一般使用红色系,支付宝图标一般使用浅蓝色系等等
136
106
  - 绝对不能使用 emoji 表情符号,不得使用任何 emoji 表情符号,请使用FontAwesome字体图标来代替。
137
107
  - LOGO图片和引导页的引导图片必须使用\`doc/res/svgMap.json\`文件中json对象正确字段的https链接值,禁止使用本地图片路径\`doc/res/logo.svg\`文件,而是使用类似:\`https://editor.bytefungo.com/dfile/img/xxxxx.svg\`这样的图片链接地址,比如闪屏页、登录页、注册页用到的LOGO图片,引导页的引导图片等。
138
108
  - jpg、jpeg类型图片必须使用图片地址:\`https://oss.bytefungo.com/f1/showImg1.jpg\`),其中结尾的’showImg1'可以换为从 1 到 30 的数字,1~30 的数字必须随机挑选,不得每个页面每个图片都使用同一个数字。写法比如:\`<img src="https://oss.bytefungo.com/f1/showImg17.jpg" alt="xxx" class="xxx" nodeType="image">\`
139
109
 
140
- ## 六、必须理解并遵守以下禁止的多个UI设计代码写法
110
+ ## 五、必须理解并遵守以下禁止的多个UI设计代码写法
141
111
  - 禁止使用任何前端框架,只使用 html+类选择器样式+js 来实现。
142
112
  - 禁止使用js代码来拼接html字符串,必须在body标签里面直接写html代码。
143
113
  - 禁止使用js代码来声明任何页面显示所需的数据,所有数据都必须在html代码中直接写死。
@@ -175,13 +145,13 @@ export const uiDesignPromptTemplate = `# UI设计规则,特别注意必须使
175
145
  - 禁止使用行内 style 属性,必须通过 class 和 CSS 文件来定义样式。
176
146
  - 禁止 radial-gradient 样式不规范,径向渐变必须显式声明为 circle,且一个 DOM 节点只能包含一个 radial-gradient。
177
147
 
178
- ## 七、首页主体页与子页面的规则
148
+ ## 六、首页主体页与子页面的规则
179
149
  - 首页主体页嵌套了多个子页面,每一个子页面都不需要填充内容,空白就行,后面会有专门的任务来设计具体的子页面。
180
150
  - 任何子页面都必须禁止添加底部导航栏节点到页面,因为子页面是嵌套在首页主体页中的,父页面已经有底部导航栏了,子页面不需要再添加底部导航栏,也不得添加二级页面的标题栏到子页面中,因为子页面是嵌套在首页主体页中的,首页主体页和它的子页面都是一级页面,因此不得添加二级页面的标题栏到子页面中。
181
151
 
182
- ## 八、如果用户没有明确说明该页面设计需求,那就按照以下页面默认规则设计
152
+ ## 七、如果用户没有明确说明该页面设计需求,那就按照以下页面默认规则设计
183
153
  - 闪屏页:禁止使用全屏图片,一般使用主题相关的渐变色,然后带有一些额外的背景元素增强界面层次感,比如:梦幻圆圈泡泡、玻璃效果的圆形径向渐变等等元素
184
154
  - 引导页:尽量不使用全屏图片,一般每一页引导页背景色也可以渐变,然后每一页功能说明一般有非全屏图片、标题、副标题等等,你可以带入其他元素,让页面更加美观,并且引导页的引导图片需要自己绘制svg图片,并存放在\`doc/res\`文件夹下面,并在html中使用
185
155
  - 背景色为了增强层次感,添加的梦幻泡泡或者圆形径向渐变元素的div,必须只能声明为\`circle\`,并且一个div的\`background:\`只能声明一个\`radial-gradient\`,比如正确的写法:background: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);,如果需要多个\`radial-gradient\`径向渐变背景,每个径向渐变背景都必须声明为一个div节点,每个div的\`background:\`只能声明一个\`radial-gradient\`。
186
156
  `;
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesign.js","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,sBAAsB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyLrC,CAAA","sourcesContent":["export const uiDesignPromptTemplate = `# UI设计规则，特别注意必须使用UI规范\\`.bytefun/UI设计规范.md\\`里面默认的主题皮肤来设计，不得使用其他主题皮肤。\n\n## 一、样式规则\n- 样式代码必须使用类选择器样式Class-based Style / Class Selector Style方式，不得使用行内样式Inline Style或外部文件。\n- 遵循手机尺寸规格(宽度 393px 高度 808px)\n- 首页/推荐tab的分类/功能各个入口的图标一般需要使用不一样的颜色，很少会统一全部使用品牌主题色\n- 所有radio、checkBox都必须使用i标签设置FontAwesome图标来实现，不得使用系统的input标签实现。\n- 如用户没有明确描述说明页面背景色，只有闪屏页面的背景色允许设置品牌主色或品牌主色与品牌次色的渐变色，其他页面必须使用非 品牌主色 与非 品牌次色 的纯色做页面背景色，比如一般使用白色系，如果是暗黑风那就是黑色系。\n- 输入框\\`input\\`如果需要展示文字 label，尽量使用 icon 代替文字 label，并且 icon 重叠在输入框的左侧，这样整个页面的空间利用率高。\n- 如果主题风格是暗黑风格的话，默认可以给每个页面添加多个玻璃效果的圆形径向渐变背景，类似这样：\\`background: radial-gradient(circle, rgba(0, 242, 255, 0.1) 0%, rgba(0, 0, 0, 0) 70%);\\`，里面的颜色和渐变范围可以根据实际情况调整。\n- 背景色为了增强层次感，添加的梦幻泡泡或者圆形径向渐变元素的div，必须只能声明为\\`circle\\`，并且一个div的\\`background:\\`只能声明一个\\`radial-gradient\\`，比如正确的写法：background: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);，如果需要多个\\`radial-gradient\\`径向渐变背景，每个径向渐变背景都必须声明为一个div节点，每个div的\\`background:\\`只能声明一个\\`radial-gradient\\`。\n- 按钮、卡片、item项等元素必须要有一个hover后改变背景色的反馈效果，不能使用transform效果，只能使用背景色效果。\n- css样式里面的\\`background-image\\`属性的值必须是远程图片，不能设置不是远程图片的任何值，比如不能设置'base64'、渐变'radial-gradient'等。\n\n## 二、必须给每一个节点添加id、name、nodeType属性\n- 特别注意，\\`i\\`和\\`div\\`等标签也必须添加 id、name、nodeType 属性，每一个节点都需要添加这三个属性，千万别漏掉了，这是必要条件\n- id 属性必须只能使用英文或数字组成，且不能以数字开头，并且整个页面 id 属性的值必须唯一，使用驼峰的命名方式\n- name 属性必须是中文或数字，并且不能包含特殊字符\n- 如果是通过点击item项切换展示内容的，那么item项的nodeType必须是\\`tabMenuBarItem\\`，tab panel的nodeType必须是\\`tabPanel\\`，\\`tabMenuBarItem\\`的父亲容器是\\`tabMenuBar\\`，不得使用\\`horizontalListView\\`来代替\\`tabMenuBar\\`\n- 页面的header标题栏nodeType必须是\\`titleBar\\`或者\\`topNavigateBar\\`，而不是\\`container\\`\n- nodeType 属性的值必须是\\`组件类型枚举 (nodeType)枚举\\` 中的一个，一些布局容器需要遵守以下说明来选择正确的nodeType：\n  - 开关组件：\\`switch\\`，用于两个状态切换的场景，比如：打开/关闭、显示/隐藏、同意/拒绝等等，具体场景比如：设置中的开关功能、同意/拒绝协议、密码显示与隐藏图标开关等，比如：\n  \\`\\`\\` html\n    <div\n      id=\"passwordShowHideCheckbox\"\n      name=\"密码显示隐藏切换开关\"\n      nodeType=\"switch\"\n      class=\"password-show-hide-checkbox\"\n      onclick=\"togglePasswordShowHide()\"\n    >\n      <i\n        id=\"passwordShowHideIcon\"\n        name=\"密码显示隐藏切换图标\"\n        nodeType=\"icon\"\n        class=\"far fa-eye\"\n        checkedClass=\"far fa-eye-slash\"\n      ></i>\n    </div>\n  \\`\\`\\`\n  - 脱离文档流的弹窗/Toast窗口容器：\\`dialogOverlay\\`、\\`dialog\\`、\\`toast\\`，用于展示弹窗/Toast类别的loading，不得使用\\`oneStateContentContainer\\`，应该Toast类别使用\\`toast\\`，弹窗类别使用\\`dialogOverlay\\`包含1个\\`dialog\\`，\\`dialog\\`是对话框的内容容器，一般屏幕居中显示。\n  - 列表容器：\\`verticalListView\\`、\\`horizontalListView\\`、\\`listItemCard\\`，用于布局多个列表项，比如：商品列表、分类列表、标签列表等，可以支持多行多列的列表布局\n  - 列表页脚容器：\\`listFooterContainer\\`，用于布局列表的页脚，比如：加载更多、没有更多了等\n  - tab选项卡：\\`tabPanelFather\\`与\\`tabMenuBar\\`组合实现tab选项卡，注意tabMenuBar支持横向和竖向的tab选项卡，比如分类竖向的tab选项卡菜单栏，一般分类都使用tab选项卡来实现，禁止使用\\`verticalListView\\`和\\`horizontalListView\\`列表来代替tab选项卡。\n  - 网格容器：gridContainer用于布局多个网格项，里面包含N个gridItem，比如：分类网格入口\n  - 流式容器：用于布局多个子项，子项可以在一行显示，当位置不够时就换行显示，比如：一组标签tag的排版布局\n  - 多状态容器：\\`multiStateContainer\\`, \\`oneStateContentContainer\\`，用于不是通过交互，而是通过逻辑状态变量变化而显示不同状态的内容容器，比如：登录状态和未登录状态分别显示不同的内容、加载中/加载失败/加载成功有数据/没有数据等状态切换、不同权限/等级/时期等等显示不同的功能，等等这些通过逻辑状态变量变化而显示不同状态的内容容器，都必须使用\\`multiStateContainer\\`和\\`oneStateContentContainer\\`来实现，特别注意脱离文档流的弹窗/Toast窗口容器类别的loading，不得使用\\`oneStateContentContainer\\`，应该使用\\`dialogOverlay/dialog\\`或者\\`toast\\`。\n- 高级组件节点的nodeType结构规则：\n  - 对话框：\\`dialogOverlay\\`是弹窗/Toast窗口容器的遮罩层，\\`dialog\\`是对话框的内容容器，\\`dialogOverlay\\`包含一个\\`dialog\\`，\\`dialog\\`一般屏幕居中显示\n  - tab 选项卡：\\`tabMenuBar\\`是tab选项卡菜单栏，里面包含N个\\`tabMenuBarItem\\`，\\`tabPanelFather\\`是tab选项卡内容容器，里面包含N个\\`tabPanel\\`，\\`tabMenuBar\\`和\\`tabPanelFather\\`必须同时存在，\\`tabPanel\\`的数量必须和\\`tabMenuBarItem\\`的数量相同，注意tabMenuBar支持横向和竖向的tab选项卡，比如分类竖向的tab选项卡菜单栏，一般分类都使用tab选项卡来实现，禁止使用\\`verticalListView\\`和\\`horizontalListView\\`列表来代替tab选项卡。\n  - viewPager 轮播：\\`viewPager\\`是轮播容器，里面包含N个\\`viewPagerItem\\`，\\`viewPagerIndicatorContainer\\`是轮播指示器容器，\\`viewPager\\`与\\`viewPagerIndicatorContainer\\`必须同时存在\n  - 一行不够位置显示就换行的容器：\\`inlineBlockAndWrap\\`，里面包含N个\\`blockItem\\`，\\`blockItem\\`是它的子项\n  - 多状态容器：一个\\`multiStateContainer\\`多状态容器包含多个\\`oneStateContentContainer\\`\n\n- 组件类型枚举 (nodeType)枚举：\n\n  - 形状：\\`rect\\`, \\`circle\\`, \\`line\\`\n  - 基础组件：\\`text\\`、\\`button\\`、\\`input\\`、\\`icon\\`、\\`image\\`\n  - 基础容器：\\`container\\`\n  - 网格容器：\\`gridContainer\\`、\\`gridItem\\`\n  - 流式容器：\\`inlineBlockAndWrap\\`、\\`blockItem\\`\n  - 开关：\\`switch\\`\n  - 单选：\\`radioGroup\\`、\\`radio\\`\n  - 多选：\\`checkBoxGroup\\`、\\`checkBox\\`\n  - 顶部导航栏：\\`titleBar\\`、\\`topNavigateBar\\`\n  - 底部操作栏：\\`bottomOperateBar\\`\n  - 多状态容器：\\`multiStateContainer\\`, \\`oneStateContentContainer\\`\n  - 列表：\\`verticalListView\\`, \\`horizontalListView\\`, \\`listItemCard\\`、\\`listFooterContainer\\`\n  - 轮播：\\`viewPager\\`, \\`viewPagerItem\\`, \\`viewPagerIndicatorContainer\\`\n  - tab 选项卡：\\`tabPanelFather\\`, \\`tabPanel\\`, \\`tabMenuBar\\`, \\`tabMenuBarItem\\`\n  - 底部导航: \\`bottomTabContentContainer\\`, \\`subPage\\`, \\`bottomTabNavigateBar\\`, \\`bottomTabNavigateBarItem\\`\n  - 对话框：\\`dialogOverlay\\`, \\`dialogContent\\`\n  - toast 提示：\\`toast\\`\n  - 下拉菜单：\\`dropDownMenu\\`\n  - 侧滑面板：\\`sideSlidePanel\\`\n  - 手机硬件元素：\\`phoneTopStatusBar\\`、\\`phoneBottomIndicatorBar\\`，这两个元素是手机硬件自带的元素，不能在页面中添加。\n\n## 三、轮播与Tabs组件的规则\n- 轮播的每一个Slide和Tabs选项卡组件每一个Tab Panel都必须使用\\`display: none\\`和\\`display: block/flex\\`来实现隐藏和显示的互斥切换\n- 轮播的每一个Slide必须有html代码实现，不得只写第1个Slide的具体内容的html代码，其他Slide的具体内容的html代码也必须要写，绝对禁止敷衍地使用\\`Placeholder content/待开发/开发中/即将上线\\`等等来敷衍地展示轮播的每一个Slide，必须每一个Slide都有具体真实的内容展示实现。\n- Tabs选项卡组件需要添加点击切换Tab Panel的功能，不得只写第1个Tab Panel的html代码，其他Tab Panel的具体内容的html代码也必须要写，绝对禁止敷衍地使用\\`Placeholder content/待开发/开发中/即将上线\\`等等来敷衍地展示Tabs选项卡组件的每一个Tab Panel，必须每一个Tab Panel都有具体真实的内容展示实现。\n- 例子：\n\\`\\`\\`html\n<tabPanelFather nodeType=\"tabPanelFather\" id=\"tabPanelFather\" name=\"Tabs选项卡内容容器\">\n  <!-- Tab Panel 1 -->\n  <tabPanel nodeType=\"tabPanel\" id=\"tabPanel1\" name=\"Tabs选项卡1\">\n    <text nodeType=\"text\" id=\"tabPanel1Text\" name=\"Tabs选项卡1的文本\">Tabs选项卡1的内容</text>\n    ...\n    <div nodeType=\"div\" id=\"tabPanel1Div\" name=\"Tabs选项卡1的div容器\">\n      ...\n    </div>\n  </tabPanel>\n  <!-- Tab Panel 2 -->\n  <tabPanel nodeType=\"tabPanel\" id=\"tabPanel2\" name=\"Tabs选项卡2\">\n    <text nodeType=\"text\" id=\"tabPanel2Text\" name=\"Tabs选项卡2的文本\">Tabs选项卡2的内容</text>\n    ...\n    <div nodeType=\"div\" id=\"tabPanel2Div\" name=\"Tabs选项卡2的div容器\">\n      ...\n    </div>\n  </tabPanel>\n  <!-- 更多Tab Panel和具体内容... -->\n</tabPanelFather>\n\\`\\`\\`\n\n## 四、列表组件规则\n- 如果该列表的数据是从网络接口拉取的，那么必须使用多状态容器\\`multiStateContainer\\`将loading、联网失败、没有数据、有数据的四个状态使用\\`oneStateContentContainer\\`包起来并展示出来，其中有数据状态的\\`oneStateContentContainer\\`包含的就是该列表组件。\n- 如果列表数据只是网络聚合业务接口的一部分，那么该列表不需要loading和联网失败状态，只需要有数据状态和没有数据状态，比如首页的推荐列表、分类列表、最新动态列表等这些是首页业务聚合接口获取的，这些列表数据只是业务接口的一部分，不是独立的接口，所以不需要loading和联网失败状态。\n- 例子：\n\\`\\`\\`html\n<multiStateContainer nodeType=\"multiStateContainer\" id=\"listMultiStateContainer\" name=\"列表多状态容器\">\n<!-- 有数据状态的oneStateContentContainer -->\n  <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"hasDataStateContainer\" name=\"有数据状态的容器\">\n    <!-- 列表组件 -->\n    <verticalListView nodeType=\"verticalListView\" id=\"listView\" fromApiOrCacheData=\"true\" name=\"列表组件\">\n      <!-- 列表项 -->\n      <listItemCard nodeType=\"listItemCard\" id=\"listItem1\" name=\"列表项1\">\n        <!-- 列表项内容 -->\n        <text nodeType=\"text\" id=\"listItem1Text\" name=\"列表项1的文本\">列表项1</text>\n      </listItemCard>\n      <!-- 更多列表项... -->\n    </verticalListView>\n  </oneStateContentContainer>\n  <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"noDataStateContainer\" name=\"没有数据状态的容器\">\n    <!-- 没有数据状态的提示 -->\n  </oneStateContentContainer>\n  <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"loadingStateContainer\" name=\"loading状态的容器\">\n    <!-- loading状态的提示 -->\n  </oneStateContentContainer>\n  <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"networkErrorStateContainer\" name=\"联网失败状态的容器\">\n    <!-- 联网失败状态的提示 -->\n  </oneStateContentContainer>\n</multiStateContainer>\n\\`\\`\\`\n\n## 五、图标与图片的规则\n- 当需要icon图标时必须使用FontAwesome图标，比如：\\`<i name=\"微信Icon\" vtype=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>\\`，并且注意图标的颜色，比如微信图标一般使用绿色系，QQ图标一般使用蓝色系，微博图标一般使用红色系，支付宝图标一般使用浅蓝色系等等\n- 绝对不能使用 emoji 表情符号，不得使用任何 emoji 表情符号，请使用FontAwesome字体图标来代替。\n- LOGO图片和引导页的引导图片必须使用\\`doc/res/svgMap.json\\`文件中json对象正确字段的https链接值，禁止使用本地图片路径\\`doc/res/logo.svg\\`文件，而是使用类似：\\`https://editor.bytefungo.com/dfile/img/xxxxx.svg\\`这样的图片链接地址，比如闪屏页、登录页、注册页用到的LOGO图片，引导页的引导图片等。\n- jpg、jpeg类型图片必须使用图片地址：\\`https://oss.bytefungo.com/f1/showImg1.jpg\\`)，其中结尾的’showImg1'可以换为从 1 到 30 的数字，1~30 的数字必须随机挑选，不得每个页面每个图片都使用同一个数字。写法比如：\\`<img src=\"https://oss.bytefungo.com/f1/showImg17.jpg\" alt=\"xxx\" class=\"xxx\" nodeType=\"image\">\\`\n\n## 六、必须理解并遵守以下禁止的多个UI设计代码写法\n- 禁止使用任何前端框架，只使用 html+类选择器样式+js 来实现。\n- 禁止使用js代码来拼接html字符串，必须在body标签里面直接写html代码。\n- 禁止使用js代码来声明任何页面显示所需的数据，所有数据都必须在html代码中直接写死。\n- 禁止使用文本渐变色，必须使用纯色文本，也就是禁止使用\\`-webkit-text-fill-color\\`属性。\n- 禁止给页面添加\\`手机顶部状态栏\\`、\\`手机底部指示器栏\\`两个非页面内容的元素节点，这是手机硬件自带的元素，不能在页面中添加。\n- 禁止使用\\`:before\\`、\\`:after\\`伪元素，必须使用其他标签来实现。\n- 禁止使用\\`backdrop-filter\\`等玻璃效果，必须删除掉所有使用到玻璃效果的代码。\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## 七、首页主体页与子页面的规则\n- 首页主体页嵌套了多个子页面，每一个子页面都不需要填充内容，空白就行，后面会有专门的任务来设计具体的子页面。\n- 任何子页面都必须禁止添加底部导航栏节点到页面，因为子页面是嵌套在首页主体页中的，父页面已经有底部导航栏了，子页面不需要再添加底部导航栏，也不得添加二级页面的标题栏到子页面中，因为子页面是嵌套在首页主体页中的，首页主体页和它的子页面都是一级页面，因此不得添加二级页面的标题栏到子页面中。\n\n## 八、如果用户没有明确说明该页面设计需求，那就按照以下页面默认规则设计\n- 闪屏页：禁止使用全屏图片，一般使用主题相关的渐变色，然后带有一些额外的背景元素增强界面层次感，比如：梦幻圆圈泡泡、玻璃效果的圆形径向渐变等等元素\n- 引导页：尽量不使用全屏图片，一般每一页引导页背景色也可以渐变，然后每一页功能说明一般有非全屏图片、标题、副标题等等，你可以带入其他元素，让页面更加美观，并且引导页的引导图片需要自己绘制svg图片，并存放在\\`doc/res\\`文件夹下面，并在html中使用\n- 背景色为了增强层次感，添加的梦幻泡泡或者圆形径向渐变元素的div，必须只能声明为\\`circle\\`，并且一个div的\\`background:\\`只能声明一个\\`radial-gradient\\`，比如正确的写法：background: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);，如果需要多个\\`radial-gradient\\`径向渐变背景，每个径向渐变背景都必须声明为一个div节点，每个div的\\`background:\\`只能声明一个\\`radial-gradient\\`。\n`"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesign.js","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,sBAAsB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2JrC,CAAA","sourcesContent":["export const uiDesignPromptTemplate = `# UI设计规则，特别注意必须使用UI规范\\`.bytefun/UI设计规范.md\\`里面默认的主题皮肤来设计，不得使用其他主题皮肤。\n\n## 一、样式规则\n- 样式代码必须使用类选择器样式Class-based Style / Class Selector Style方式，不得使用行内样式Inline Style或外部文件。\n- 遵循手机尺寸规格(宽度 393px 高度 808px)\n- 首页/推荐tab的分类/功能各个入口的图标一般需要使用不一样的颜色，很少会统一全部使用品牌主题色\n- 所有radio、checkBox都必须使用i标签设置FontAwesome图标来实现，不得使用系统的input标签实现。\n- 如用户没有明确描述说明页面背景色，只有闪屏页面的背景色允许设置品牌主色或品牌主色与品牌次色的渐变色，其他页面必须使用非 品牌主色 与非 品牌次色 的纯色做页面背景色，比如一般使用白色系，如果是暗黑风那就是黑色系。\n- 输入框\\`input\\`如果需要展示文字 label，尽量使用 icon 代替文字 label，并且 icon 重叠在输入框的左侧，这样整个页面的空间利用率高。\n- 如果主题风格是暗黑风格的话，默认可以给每个页面添加多个玻璃效果的圆形径向渐变背景，类似这样：\\`background: radial-gradient(circle, rgba(0, 242, 255, 0.1) 0%, rgba(0, 0, 0, 0) 70%);\\`，里面的颜色和渐变范围可以根据实际情况调整。\n- 背景色为了增强层次感，添加的梦幻泡泡或者圆形径向渐变元素的div，必须只能声明为\\`circle\\`，并且一个div的\\`background:\\`只能声明一个\\`radial-gradient\\`，比如正确的写法：background: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);，如果需要多个\\`radial-gradient\\`径向渐变背景，每个径向渐变背景都必须声明为一个div节点，每个div的\\`background:\\`只能声明一个\\`radial-gradient\\`。\n- 按钮、卡片、item项等元素必须要有一个hover后改变背景色的反馈效果，不能使用transform效果，只能使用背景色效果。\n- css样式里面的\\`background-image\\`属性的值必须是远程图片，不能设置不是远程图片的任何值，比如不能设置'base64'、渐变'radial-gradient'等。\n\n## 二、必须给每一个节点添加id、name、nodeType属性\n- 特别注意，\\`i\\`和\\`div\\`等标签也必须添加 id、name、nodeType 属性，每一个节点都需要添加这三个属性，千万别漏掉了，这是必要条件\n- id 属性必须只能使用英文或数字组成，且不能以数字开头，并且整个页面 id 属性的值必须唯一，使用驼峰的命名方式\n- name 属性必须是中文或数字，并且不能包含特殊字符\n- 如果是通过点击item项切换展示内容的，那么item项的nodeType必须是\\`tabMenuBarItem\\`，tab panel的nodeType必须是\\`tabPanel\\`，\\`tabMenuBarItem\\`的父亲容器是\\`tabMenuBar\\`，不得使用\\`horizontalListView\\`来代替\\`tabMenuBar\\`\n- 页面的header标题栏nodeType必须是\\`titleBar\\`或者\\`topNavigateBar\\`，而不是\\`container\\`\n- nodeType 属性的值必须是\\`组件类型枚举 (nodeType)枚举\\` 中的一个，一些布局容器需要遵守以下说明来选择正确的nodeType：\n  - 开关组件：\\`switch\\`，用于两个状态切换的场景，比如：打开/关闭、显示/隐藏、同意/拒绝等等，具体场景比如：设置中的开关功能、同意/拒绝协议、密码显示与隐藏图标开关等，比如：\n  \\`\\`\\` html\n    <div\n      id=\"passwordShowHideCheckbox\"\n      name=\"密码显示隐藏切换开关\"\n      nodeType=\"switch\"\n      class=\"password-show-hide-checkbox\"\n      onclick=\"togglePasswordShowHide()\"\n    >\n      <i\n        id=\"passwordShowHideIcon\"\n        name=\"密码显示隐藏切换图标\"\n        nodeType=\"icon\"\n        class=\"far fa-eye\"\n        checkedClass=\"far fa-eye-slash\"\n      ></i>\n    </div>\n  \\`\\`\\`\n  - 脱离文档流的弹窗/Toast窗口容器：\\`dialogOverlay\\`、\\`dialog\\`、\\`toast\\`，用于展示弹窗/Toast类别的loading，不得使用\\`oneStateContentContainer\\`，应该Toast类别使用\\`toast\\`，弹窗类别使用\\`dialogOverlay\\`包含1个\\`dialog\\`，\\`dialog\\`是对话框的内容容器，一般屏幕居中显示。\n  - 列表容器：\\`verticalListView\\`、\\`horizontalListView\\`、\\`listItemCard\\`，用于布局多个列表项，比如：商品列表、分类列表、标签列表等，可以支持多行多列的列表布局\n  - 列表页脚容器：\\`listFooterContainer\\`，用于布局列表的页脚，比如：加载更多、没有更多了等\n  - tab选项卡：\\`tabPanelFather\\`与\\`tabMenuBar\\`组合实现tab选项卡，注意tabMenuBar支持横向和竖向的tab选项卡，比如分类竖向的tab选项卡菜单栏，一般分类都使用tab选项卡来实现，禁止使用\\`verticalListView\\`和\\`horizontalListView\\`列表来代替tab选项卡。\n  - 网格容器：gridContainer用于布局多个网格项，里面包含N个gridItem，比如：分类网格入口\n  - 流式容器：用于布局多个子项，子项可以在一行显示，当位置不够时就换行显示，比如：一组标签tag的排版布局\n  - 多状态容器：\\`multiStateContainer\\`, \\`oneStateContentContainer\\`，用于不是通过交互，而是通过逻辑状态变量变化而显示不同状态的内容容器，比如：登录状态和未登录状态分别显示不同的内容、不同权限/等级/时期等等显示不同的功能，等等这些通过逻辑状态变量变化而显示不同状态的内容容器，都必须使用\\`multiStateContainer\\`和\\`oneStateContentContainer\\`来实现，特别注意脱离文档流的弹窗/Toast窗口容器类别的loading，不得使用\\`oneStateContentContainer\\`，应该使用\\`dialogOverlay/dialog\\`或者\\`toast\\`。\n- 高级组件节点的nodeType结构规则：\n  - 对话框：\\`dialogOverlay\\`是弹窗/Toast窗口容器的遮罩层，\\`dialog\\`是对话框的内容容器，\\`dialogOverlay\\`包含一个\\`dialog\\`，\\`dialog\\`一般屏幕居中显示\n  - tab 选项卡：\\`tabMenuBar\\`是tab选项卡菜单栏，里面包含N个\\`tabMenuBarItem\\`，\\`tabPanelFather\\`是tab选项卡内容容器，里面包含N个\\`tabPanel\\`，\\`tabMenuBar\\`和\\`tabPanelFather\\`必须同时存在，\\`tabPanel\\`的数量必须和\\`tabMenuBarItem\\`的数量相同，注意tabMenuBar支持横向和竖向的tab选项卡，比如分类竖向的tab选项卡菜单栏，一般分类都使用tab选项卡来实现，禁止使用\\`verticalListView\\`和\\`horizontalListView\\`列表来代替tab选项卡。\n  - viewPager 轮播：\\`viewPager\\`是轮播容器，里面包含N个\\`viewPagerItem\\`，\\`viewPagerIndicatorContainer\\`是轮播指示器容器，\\`viewPager\\`与\\`viewPagerIndicatorContainer\\`必须同时存在\n  - 一行不够位置显示就换行的容器：\\`inlineBlockAndWrap\\`，里面包含N个\\`blockItem\\`，\\`blockItem\\`是它的子项\n  - 多状态容器：一个\\`multiStateContainer\\`多状态容器包含多个\\`oneStateContentContainer\\`\n\n- 组件类型枚举 (nodeType)枚举：\n\n  - 形状：\\`rect\\`, \\`circle\\`, \\`line\\`\n  - 基础组件：\\`text\\`、\\`button\\`、\\`input\\`、\\`icon\\`、\\`image\\`\n  - 基础容器：\\`container\\`\n  - 网格容器：\\`gridContainer\\`、\\`gridItem\\`\n  - 流式容器：\\`inlineBlockAndWrap\\`、\\`blockItem\\`\n  - 开关：\\`switch\\`\n  - 单选：\\`radioGroup\\`、\\`radio\\`\n  - 多选：\\`checkBoxGroup\\`、\\`checkBox\\`\n  - 顶部导航栏：\\`titleBar\\`、\\`topNavigateBar\\`\n  - 底部操作栏：\\`bottomOperateBar\\`\n  - 多状态容器：\\`multiStateContainer\\`, \\`oneStateContentContainer\\`\n  - 列表：\\`verticalListView\\`, \\`horizontalListView\\`, \\`listItemCard\\`、\\`listFooterContainer\\`\n  - 轮播：\\`viewPager\\`, \\`viewPagerItem\\`, \\`viewPagerIndicatorContainer\\`\n  - tab 选项卡：\\`tabPanelFather\\`, \\`tabPanel\\`, \\`tabMenuBar\\`, \\`tabMenuBarItem\\`\n  - 底部导航: \\`bottomTabContentContainer\\`, \\`subPage\\`, \\`bottomTabNavigateBar\\`, \\`bottomTabNavigateBarItem\\`\n  - 对话框：\\`dialogOverlay\\`, \\`dialogContent\\`\n  - toast 提示：\\`toast\\`\n  - 下拉菜单：\\`dropDownMenu\\`\n  - 侧滑面板：\\`sideSlidePanel\\`\n  - 手机硬件元素：\\`phoneTopStatusBar\\`、\\`phoneBottomIndicatorBar\\`，这两个元素是手机硬件自带的元素，不能在页面中添加。\n\n## 三、轮播与Tabs组件的规则\n- 轮播的每一个Slide和Tabs选项卡组件每一个Tab Panel都必须使用\\`display: none\\`和\\`display: block/flex\\`来实现隐藏和显示的互斥切换\n- 轮播的每一个Slide必须有html代码实现，不得只写第1个Slide的具体内容的html代码，其他Slide的具体内容的html代码也必须要写，绝对禁止敷衍地使用\\`Placeholder content/待开发/开发中/即将上线\\`等等来敷衍地展示轮播的每一个Slide，必须每一个Slide都有具体真实的内容展示实现。\n- Tabs选项卡组件需要添加点击切换Tab Panel的功能，不得只写第1个Tab Panel的html代码，其他Tab Panel的具体内容的html代码也必须要写，绝对禁止敷衍地使用\\`Placeholder content/待开发/开发中/即将上线\\`等等来敷衍地展示Tabs选项卡组件的每一个Tab Panel，必须每一个Tab Panel都有具体真实的内容展示实现。\n- 例子：\n\\`\\`\\`html\n<tabPanelFather nodeType=\"tabPanelFather\" id=\"tabPanelFather\" name=\"Tabs选项卡内容容器\">\n  <!-- Tab Panel 1 -->\n  <tabPanel nodeType=\"tabPanel\" id=\"tabPanel1\" name=\"Tabs选项卡1\">\n    <text nodeType=\"text\" id=\"tabPanel1Text\" name=\"Tabs选项卡1的文本\">Tabs选项卡1的内容</text>\n    ...\n    <div nodeType=\"div\" id=\"tabPanel1Div\" name=\"Tabs选项卡1的div容器\">\n      ...\n    </div>\n  </tabPanel>\n  <!-- Tab Panel 2 -->\n  <tabPanel nodeType=\"tabPanel\" id=\"tabPanel2\" name=\"Tabs选项卡2\">\n    <text nodeType=\"text\" id=\"tabPanel2Text\" name=\"Tabs选项卡2的文本\">Tabs选项卡2的内容</text>\n    ...\n    <div nodeType=\"div\" id=\"tabPanel2Div\" name=\"Tabs选项卡2的div容器\">\n      ...\n    </div>\n  </tabPanel>\n  <!-- 更多Tab Panel和具体内容... -->\n</tabPanelFather>\n\\`\\`\\`\n\n## 四、图标与图片的规则\n- 当需要icon图标时必须使用FontAwesome图标，比如：\\`<i name=\"微信Icon\" vtype=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>\\`，并且注意图标的颜色，比如微信图标一般使用绿色系，QQ图标一般使用蓝色系，微博图标一般使用红色系，支付宝图标一般使用浅蓝色系等等\n- 绝对不能使用 emoji 表情符号，不得使用任何 emoji 表情符号，请使用FontAwesome字体图标来代替。\n- LOGO图片和引导页的引导图片必须使用\\`doc/res/svgMap.json\\`文件中json对象正确字段的https链接值，禁止使用本地图片路径\\`doc/res/logo.svg\\`文件，而是使用类似：\\`https://editor.bytefungo.com/dfile/img/xxxxx.svg\\`这样的图片链接地址，比如闪屏页、登录页、注册页用到的LOGO图片，引导页的引导图片等。\n- jpg、jpeg类型图片必须使用图片地址：\\`https://oss.bytefungo.com/f1/showImg1.jpg\\`)，其中结尾的’showImg1'可以换为从 1 到 30 的数字，1~30 的数字必须随机挑选，不得每个页面每个图片都使用同一个数字。写法比如：\\`<img src=\"https://oss.bytefungo.com/f1/showImg17.jpg\" alt=\"xxx\" class=\"xxx\" nodeType=\"image\">\\`\n\n## 五、必须理解并遵守以下禁止的多个UI设计代码写法\n- 禁止使用任何前端框架，只使用 html+类选择器样式+js 来实现。\n- 禁止使用js代码来拼接html字符串，必须在body标签里面直接写html代码。\n- 禁止使用js代码来声明任何页面显示所需的数据，所有数据都必须在html代码中直接写死。\n- 禁止使用文本渐变色，必须使用纯色文本，也就是禁止使用\\`-webkit-text-fill-color\\`属性。\n- 禁止给页面添加\\`手机顶部状态栏\\`、\\`手机底部指示器栏\\`两个非页面内容的元素节点，这是手机硬件自带的元素，不能在页面中添加。\n- 禁止使用\\`:before\\`、\\`:after\\`伪元素，必须使用其他标签来实现。\n- 禁止使用\\`backdrop-filter\\`等玻璃效果，必须删除掉所有使用到玻璃效果的代码。\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## 六、首页主体页与子页面的规则\n- 首页主体页嵌套了多个子页面，每一个子页面都不需要填充内容，空白就行，后面会有专门的任务来设计具体的子页面。\n- 任何子页面都必须禁止添加底部导航栏节点到页面，因为子页面是嵌套在首页主体页中的，父页面已经有底部导航栏了，子页面不需要再添加底部导航栏，也不得添加二级页面的标题栏到子页面中，因为子页面是嵌套在首页主体页中的，首页主体页和它的子页面都是一级页面，因此不得添加二级页面的标题栏到子页面中。\n\n## 七、如果用户没有明确说明该页面设计需求，那就按照以下页面默认规则设计\n- 闪屏页：禁止使用全屏图片，一般使用主题相关的渐变色，然后带有一些额外的背景元素增强界面层次感，比如：梦幻圆圈泡泡、玻璃效果的圆形径向渐变等等元素\n- 引导页：尽量不使用全屏图片，一般每一页引导页背景色也可以渐变，然后每一页功能说明一般有非全屏图片、标题、副标题等等，你可以带入其他元素，让页面更加美观，并且引导页的引导图片需要自己绘制svg图片，并存放在\\`doc/res\\`文件夹下面，并在html中使用\n- 背景色为了增强层次感，添加的梦幻泡泡或者圆形径向渐变元素的div，必须只能声明为\\`circle\\`，并且一个div的\\`background:\\`只能声明一个\\`radial-gradient\\`，比如正确的写法：background: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);，如果需要多个\\`radial-gradient\\`径向渐变背景，每个径向渐变背景都必须声明为一个div节点，每个div的\\`background:\\`只能声明一个\\`radial-gradient\\`。\n`"]}
@@ -1,2 +1,2 @@
1
- export declare const uiDesignGuidePromptTemplate = "\n# \u4F60\u662F UI \u8BBE\u8BA1\u5E08\u4E13\u5BB6\u3001\u4EE3\u7801\u5F00\u53D1\u4E13\u5BB6\uFF0C\u4F60\u5FC5\u987B\u6309\u7167`\u6267\u884C\u6B65\u9AA4\u6765`\u6267\u884C\u4EFB\u52A1\u3002\n\n## **\u6267\u884C\u8BBE\u8BA1\uFF1A\u6BCF\u4E00\u4E2A\u9875\u9762\u8BBE\u8BA1\u90FD\u5FC5\u987B\u8C03\u7528 todo_write \u5DE5\u5177\u521B\u5EFA\u4EE5\u4E0B 10 \u4E2A\u4EFB\u52A1\u5217\u8868\uFF0C\u521B\u5EFA\u5B8C\u6210\u540E\u5FC5\u987B\u786E\u8BA4\uFF1A\u5982\u679C\u4EFB\u52A1\u6570\u91CF\u4E0D\u662F 10 \u4E2A\uFF0C\u7ACB\u5373\u62A5\u9519\u5E76\u91CD\u65B0\u521B\u5EFA\u3002**\n\n1. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52191`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json`\uFF0C\u5F97\u51FA\u8BE5\u529F\u80FD\u6A21\u5757\u73B0\u5728\u9700\u8981\u8BBE\u8BA1\u54EA\u4E00\u4E2A\u9875\u9762`pageNameEN`\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u90FD\u8BBE\u8BA1\u5B8C\u6210\u4E86\uFF0C\u90A3\u5C31\u505C\u6B62 AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n2. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52192`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/xxx\u529F\u80FD\u6A21\u5757.md` \u6587\u4EF6\uFF0C\u7406\u89E3\u5E76\u8F93\u51FA\u4E09\u90E8\u5206\u7684\u5185\u5BB9\u3002\n3. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52193`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md`UI\u89C4\u8303\u6587\u4EF6\u548C`.bytefun/ui-design-spec-demo.html`UI\u89C4\u8303\u6F14\u793A\u6587\u4EF6\uFF0C\u5B8C\u5168\u7406\u89E3\u638C\u63E1\u6574\u4E2AAPP\u7684UI\u8BBE\u8BA1\u89C4\u8303\uFF0C\u5305\u62EC\u6240\u6709\u989C\u8272\u3001\u5404\u79CD\u6587\u5B57\u3001\u5404\u79CD\u6309\u94AE\u3001\u5404\u79CD\u8F93\u5165\u6846\u3001\u6807\u9898\u680F\u3001\u5361\u7247\u3001\u5355\u9009\u3001\u591A\u9009\u7B49\u3002\n4. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52194`\u6267\u884C\u4EFB\u52A1\uFF0C\u4E3A\u5237\u65B0\u8BB0\u5FC6\u7F13\u5B58\uFF0C\u4F60\u5FC5\u987B\u91CD\u65B0\u8C03\u7528MCP\u5DE5\u5177`optimize_ui_design_prompt`\u4E25\u683C\u6309\u7167\u89C4\u5219\u8981\u6C42\uFF0C\u7136\u540E\u4E25\u683C\u9075\u5B88`optimize_ui_design_prompt`\u8FD4\u56DE\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u5B8C\u6210\u4E00\u4E2A`pageNameEN`html\u9875\u9762\u7684 UI \u8BBE\u8BA1\uFF0C\u5FC5\u987B\u6CE8\u610F\u4E00\u6B21\u53EA\u8BBE\u8BA1\u4E00\u4E2A\u9875\u9762\uFF08\u7981\u6B62 JS \u62FC\u63A5 html \u5B57\u7B26\u4E32\uFF0C\u7981\u6B62\u4F7F\u7528 js \u6765\u58F0\u660E\u4EFB\u4F55\u9875\u9762\u663E\u793A\u6240\u9700\u7684\u6570\u636E\uFF0C\u6240\u6709\u6570\u636E\u90FD\u5FC5\u987B\u5728 html \u4EE3\u7801\u4E2D\u76F4\u63A5\u5199\u6B7B\uFF09\u3002\n5. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52195`\u6267\u884C\u4EFB\u52A1\uFF0C\u6307\u5B9A`nodeType`\u7684\u8282\u70B9\u5224\u65AD\u662F\u5426\u9700\u8981\u4ECE\u540E\u7AEFapi\u63A5\u53E3\u83B7\u53D6\u6570\u636E\uFF0C\u5982\u679C\u662F\u90A3\u5C31\u5FC5\u987B\u6DFB\u52A0\u5C5E\u6027`fromApiOrCacheData=\"true\"`\n6. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52196`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C5\u4E2AUI\u6837\u5F0F\u548C\u5C5E\u6027\u6B63\u786E\u6027\u548C\u5B8C\u6574\u6027\u7684\u68C0\u67E5\u3002\n7. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52197`\u6267\u884C\u4EFB\u52A1\uFF0C\u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\uFF0C\u7ED9 `nodeType` \u662F`oneStateContentContainer`\u3001`viewPagerItem`\u3001`tabPanel`\u7684\u8282\u70B9\u6DFB\u52A0\u663E\u793A\u548C\u9690\u85CF\u7684\u5207\u6362 js \u65B9\u6CD5:`switchTo{{\u8282\u70B9ID}}`\u3002\n8. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52198`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C\u547D\u4EE4`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u8FDB\u884C\u4EE3\u7801\u68C0\u67E5\u548C\u4FEE\u590D\u95EE\u9898\u3002\n9. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52199`\u6267\u884C\u4EFB\u52A1\uFF0C\u5F3A\u5236\u66F4\u65B0'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u7684`currentVersion`\u548C`designStatus`\uFF0C\u4EE5\u53CA\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\u90A3\u5C31\u66F4\u65B0`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u3002\n10. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u521910`\u6267\u884C\u4EFB\u52A1\uFF0C\u5224\u65AD\u8BE5\u529F\u80FD\u6A21\u5757\u662F\u5426\u5168\u90E8\u9875\u9762\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u5982\u679C\u8FD8\u6CA1\u6709\u5B8C\u6210\uFF0C\u90A3\u5C31\u6309\u7167\u89C4\u5219\u8BA1\u5212\u4E0B\u4E00\u4E2A\u9875\u9762\u7684\u5F00\u53D1\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u6240\u6709\u9875\u9762\u90FD\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u90A3\u5C31\u7ED3\u675F AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n\n### **\u6B65\u9AA4\u89C4\u5219 1\uFF1A\u9605\u8BFB`doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json`\u67E5\u770B\u8BE5\u529F\u80FD\u6A21\u5757\u9875\u9762\u8BBE\u8BA1\u8FDB\u5EA6\u60C5\u51B5`designStatus`\u5B57\u6BB5\uFF0C\u4F9D\u636E\u8BE5\u529F\u80FD\u6A21\u5757\u5404\u4E2A\u9875\u9762\u7684`designStatus`\u5B8C\u6210\u60C5\u51B5\u6267\u884C\u4EE5\u4E0B\u64CD\u4F5C\uFF1A**\n\n- \u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u6240\u6709\u9875\u9762\u90FD\u8BBE\u8BA1\u5B8C\u6210\u4E86\uFF0C\u90A3\u5C31\u505C\u6B62 AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n- \u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u8FD8\u6709\u672A\u8BBE\u8BA1\u5B8C\u6210\u7684\u9875\u9762\uFF0C\u90A3\u5C31\u83B7\u53D6\u5230\u8BE5\u529F\u80FD\u6A21\u5757\u7684\u7B2C\u4E00\u4E2A\u672A\u8BBE\u8BA1\u5B8C\u6210\u7684\u9875\u9762`pageNameEN`\uFF0C\u7EE7\u7EED\u6267\u884C\u4E0B\u4E00\u6B65\n\n### **\u6B65\u9AA4\u89C4\u5219 2\uFF1A\u6839\u636E\u7528\u6237\u9700\u6C42\uFF0C\u5E76\u4F7F\u7528`read_file`\u5DE5\u5177\u8BFB\u53D6\u8BE5\u9875\u9762\u6240\u5728\u7684\u529F\u80FD\u6A21\u5757\u8BBE\u8BA1`.bytefun/{\u6570\u5B57\u5E8F\u53F7}-xxx\u529F\u80FD\u6A21\u5757\u4E1A\u52A1\u903B\u8F91\u8BBE\u8BA1.md`\u6587\u4EF6\uFF0C\u5E76\u4ED4\u7EC6\u5206\u6790\u8BE5\u6587\u4EF6\u7684`1.1\u3001\u9875\u9762\u7EC4\u6210\u90E8\u5206`\u3001`1.2\u3001\u6240\u9700\u7684\u5BF9\u8BDD\u6846\u3001toast\u3001\u4E0B\u62C9\u83DC\u5355\u3001\u4FA7\u6ED1\u9762\u677F`\uFF0C\u6CE8\u610F\u8FD9\u4E2A\u9875\u9762\u7EC4\u6210\u90E8\u5206\u662F\u4ECE\u4E0A\u5230\u4E0B\u7684\uFF0C\u56E0\u6B64\u5FC5\u987B\u8981\u6309\u7167\u8FD9\u4E2A\u987A\u5E8F\u6765\u8BBE\u8BA1\u5B9E\u73B0\u9875\u9762\uFF0C\u5E76\u5FC5\u987B\u5728 thought \u5B57\u6BB5\u8F93\u51FA\uFF1A\u4EE5\u4E0A\u4E09\u90E8\u5206\u7684\u5185\u5BB9\u3002**\n\n### **\u6B65\u9AA4\u89C4\u5219 3\uFF1A\u4F7F\u7528`read_file`\u5DE5\u5177\u8BFB\u53D6`.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md`\u6587\u4EF6\uFF0C\u5B8C\u5168\u7406\u89E3\u638C\u63E1\u6574\u4E2AAPP\u7684UI\u8BBE\u8BA1\u89C4\u8303\uFF0C\u5305\u62EC\u6240\u6709\u989C\u8272\u3001\u5404\u79CD\u6587\u5B57\u3001\u5404\u79CD\u6309\u94AE\u3001\u5404\u79CD\u8F93\u5165\u6846\u3001\u6807\u9898\u680F\u3001\u5361\u7247\u3001\u5355\u9009\u3001\u591A\u9009\u7B49\u3002**\n\n### **\u6B65\u9AA4\u89C4\u5219 4\uFF1A\u4E3A\u5237\u65B0\u8BB0\u5FC6\u7F13\u5B58\uFF0C\u4F60\u5FC5\u987B\u91CD\u65B0\u8C03\u7528MCP\u5DE5\u5177`optimize_ui_design_prompt`\u83B7\u53D6\u5230UI\u8BBE\u8BA1\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\uFF0C\u7136\u540E\u4E25\u683C\u9075\u5B88`optimize_ui_design_prompt`\u8FD4\u56DE\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u5B8C\u6210`doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u9875\u9762\u7684 UI \u8BBE\u8BA1**:\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E00\u3001\u6837\u5F0F\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E8C\u3001\u5FC5\u987B\u7ED9\u6BCF\u4E00\u4E2A\u8282\u70B9\u6DFB\u52A0id\u3001name\u3001nodeType\u5C5E\u6027`\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E09\u3001\u8F6E\u64AD\u4E0ETabs\u7EC4\u4EF6\u7684\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u56DB\u3001\u5217\u8868\u7EC4\u4EF6\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\uFF1A\u5982\u679C\u8BE5\u5217\u8868\u7684\u6570\u636E\u662F\u4ECE\u7F51\u7EDC\u62C9\u53D6\u7684\uFF0C\u90A3\u4E48\u5FC5\u987B\u4F7F\u7528\u591A\u72B6\u6001\u5BB9\u5668`multiStateContainer`\u5C06loading\u3001\u8054\u7F51\u5931\u8D25\u3001\u6CA1\u6709\u6570\u636E\u3001\u6709\u6570\u636E\u7684\u56DB\u4E2A\u72B6\u6001\u4F7F\u7528`oneStateContentContainer`\u5305\u8D77\u6765\u5E76\u5C55\u793A\u51FA\u6765\uFF0C\u5176\u4E2D\u6709\u6570\u636E\u72B6\u6001\u7684`oneStateContentContainer`\u5305\u542B\u7684\u5C31\u662F\u8BE5\u5217\u8868\u7EC4\u4EF6\u3002\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E94\u3001\u56FE\u6807\u4E0E\u56FE\u7247\u7684\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u516D\u3001\u9996\u9875\u4E3B\u4F53\u9875\u4E0E\u5B50\u9875\u9762\u7684\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E03\u3001\u5982\u679C\u7528\u6237\u6CA1\u6709\u660E\u786E\u8BF4\u660E\u8BE5\u9875\u9762\u8BBE\u8BA1\u9700\u6C42\uFF0C\u90A3\u5C31\u6309\u7167\u9875\u9762\u9ED8\u8BA4\u89C4\u5219\u8BBE\u8BA1`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n\n### **\u6B65\u9AA4\u89C4\u5219 5\uFF1A\u6307\u5B9A`nodeType`\u7684\u8282\u70B9\u5224\u65AD\u662F\u5426\u9700\u8981\u4ECE\u540E\u7AEFapi\u63A5\u53E3\u83B7\u53D6\u6570\u636E\uFF0C\u5982\u679C\u662F\u90A3\u5C31\u5FC5\u987B\u6DFB\u52A0\u5C5E\u6027`fromApiOrCacheData=\"true\"`**\n- \u5982\u679C`nodeType` \u662F`verticalListView`\u3001`horizontalListView`\u3001`viewPager`\u3001`tabPanelFather`\u3001`radioGroup`\u3001`checkBoxGroup`\u3001`gridContainer`\u3001`inlineBlockAndWrap`\u7C7B\u578B\u7684\u8282\u70B9\u6DFB\u52A0\u6570\u636E\u83B7\u53D6\u65B9\u5F0F\u5C5E\u6027`fromApiOrCacheData`\uFF0C`fromApiOrCacheData=\"true\"`\u7684\u60C5\u51B5\u5FC5\u987B\u6EE1\u8DB3\u4EE5\u4E0B\u6761\u4EF6\uFF1A\n - \u8BE5\u7EC4\u4EF6\u7684\u6570\u636E\u662F\u4ECE\u7F51\u7EDC\u6216\u8005\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u56DE\u6765\u7684\uFF0C\u6BD4\u5982\uFF1A\u70ED\u95E8\u5546\u54C1\u5217\u8868\u7EC4\u4EF6`verticalListView`\uFF0C\u8BE5\u7EC4\u4EF6\u7684\u6570\u636E\u662F\u4ECE\u7F51\u7EDC\u6216\u8005\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u56DE\u6765\u7684\n - \u5982\u679C\u662F\u4E00\u4E9B\u4E0D\u9700\u8981\u540E\u7AEF API \u8054\u7F51\u6216\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u83B7\u53D6\u7684\u9759\u6001\u5199\u6B7B\u7684\u6570\u636E\uFF0C\u90A3\u4E48\u5C31\u4E0D\u9700\u8981 `fromApiOrCacheData` \u5C5E\u6027\u4E86\uFF0C\u6BD4\u5982\uFF1A\u4E2A\u4EBA\u4E2D\u5FC3\u5217\u8868\u9879\u3001\u8BBE\u7F6E\u5217\u8868\u9879\u3001\u83DC\u5355\u5217\u8868\u9879\uFF0C\u8FD9\u4E9B\u6839\u672C\u4E0D\u9700\u8981\u7ECF\u8FC7\u540E\u53F0 API \u8054\u7F51\u6216\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u83B7\u53D6\u7684\uFF0C\u90A3\u4E48\u5C31\u4E0D\u8981 `fromApiOrCacheData` \u5C5E\u6027\n\n### **\u6B65\u9AA4\u89C4\u5219 6\uFF1A\u7ED9\u4EE5\u4E0B4\u70B9\u7684UI\u6837\u5F0F\u548C\u5C5E\u6027\u6B63\u786E\u6027\u548C\u5B8C\u6574\u6027\u68C0\u67E5**\n1. \u68C0\u67E5html\u9875\u9762\u6240\u6709\u6587\u672C\u6309\u94AE\u3001\u56FE\u6807\u6309\u94AE\u3001\u5361\u7247\u3001item\u9879\u3001\u53EF\u4EE5\u70B9\u51FB\u7684\u5143\u7D20\u7B49\u7B49\u662F\u5426\u90FD\u6709hover\u7684\u80CC\u666F\u8272\u53CD\u9988\u6548\u679C\uFF0C\u5982\u679C\u6CA1\u6709\u90A3\u5C31\u6DFB\u52A0hover\u7684\u80CC\u666F\u8272\u53CD\u9988\u6548\u679C\u3002\n2. \u68C0\u67E5tab\u9009\u9879\u5361\u6BCF\u4E00\u4E2Atab panel\u662F\u5426\u90FD\u6709\u5BF9\u5E94\u7684html\u4EE3\u7801\u5B9E\u73B0\u5B8C\u6574\u7684\u5185\u5BB9\u5C55\u793A\n4\u3001\u68C0\u67E5tab\u9009\u9879\u5361\u6BCF\u4E00\u4E2Atab panel\u662F\u5426\u90FD\u6709\u5BF9\u5E94\u7684html\u4EE3\u7801\u5B9E\u73B0\u5B8C\u6574\u7684\u5185\u5BB9\u5C55\u793A\uFF0C\u7EDD\u5BF9\u7981\u6B62\u6577\u884D\u5730\u4F7F\u7528`Placeholder content/\u5F85\u5F00\u53D1/\u5F00\u53D1\u4E2D/\u5373\u5C06\u4E0A\u7EBF`\u7B49\u7B49\u6765\u6577\u884D\u5730\u5C55\u793ATabs\u9009\u9879\u5361\u7EC4\u4EF6\u7684\u6BCF\u4E00\u4E2ATab Panel\uFF0C\u5FC5\u987B\u6BCF\u4E00\u4E2ATab Panel\u90FD\u6709\u5177\u4F53\u771F\u5B9E\u7684\u5185\u5BB9\u5C55\u793A\u5B9E\u73B0\u3002\n5. \u68C0\u67E5\u5BC6\u7801\u8F93\u5165\u6846\u53F3\u4FA7\u7684\u5BC6\u7801\u663E\u793A\u4E0E\u9690\u85CF\u56FE\u6807\u7684`nodeType`\u8981\u6539\u4E3A`switch`\u5E76\u6DFB\u52A0\u4E00\u4E2A `checkedClass` \u5C5E\u6027\uFF0C\u7136\u540E\u7ED9html\u4E2D\u6240\u6709`nodeType` \u662F `switch`\u3001`radio`\u3001`checkBox`\u8282\u70B9\u7684\u5B69\u5B50 `i` \u6807\u7B7E\u8282\u70B9\u6DFB\u52A0\u4E00\u4E2A `checkedClass` \u5C5E\u6027\uFF0C\u7528\u4E8E\u8868\u793A\u9009\u4E2D\u72B6\u6001\u7684 icon \u56FE\u6807\u6837\u5F0F\u7C7B\u540D\uFF0C\u6BD4\u5982\uFF1A\n```html\n<div nodeType=\"radio\" id=\"xxxRadio\" name=\"xxx\u5355\u9009\">\n <i\n name=\"\u5355\u9009Icon\"\n nodeType=\"icon\"\n id=\"xxxRadioIcon\"\n class=\"fa xxx\"\n checkedClass=\"fa yyy\"\n ></i>\n <span name=\"xxx\u5355\u9009\u6587\u672C\" nodeType=\"text\" class=\"xxx-text\">xxx</span>\n</div>\n<div\n id=\"agreementCheckbox\"\n name=\"\u534F\u8BAE\u52FE\u9009\u6846\"\n nodeType=\"checkBox\"\n class=\"agreement-checkbox\"\n onclick=\"toggleAgreement()\"\n>\n <i\n id=\"agreementIcon\"\n name=\"\u534F\u8BAE\u52FE\u9009\u56FE\u6807\"\n nodeType=\"icon\"\n class=\"far fa-square\"\n checkedClass=\"fas fa-check-square\"\n ></i>\n</div>\n```\n\n### **\u6B65\u9AA4\u89C4\u5219 7 - \u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\uFF0C\u7ED9 `nodeType` \u662F`oneStateContentContainer`\u3001`viewPagerItem`\u3001`tabPanel`\u3001`dialogOverlay`\u3001`toast`\u3001`dropDownMenu`\u3001`sideSlidePanel`\u7684\u8282\u70B9\u6DFB\u52A0\u663E\u793A\u548C\u9690\u85CF\u7684\u5207\u6362 js \u65B9\u6CD5:`switchTo{{\u8282\u70B9ID}}`**\n\n- \u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\n- js \u65B9\u6CD5\u7684\u547D\u540D\u89C4\u5219\uFF1A`switchTo` + \u8282\u70B9 id\uFF0C\u6BD4\u5982\uFF1A`switchToAgeContainer`\u3001`switchToPhoneContainer`\n- \u5207\u6362\u663E\u793A\u548C\u9690\u85CF\u7684 js \u65B9\u6CD5\u4E0D\u5F97\u5E26\u6709\u4EFB\u4F55\u53C2\u6570\uFF0C\u6BD4\u5982\uFF1A`switchToAgeContainer()`\u3001`switchToPhoneContainer()`\n- \u793A\u4F8B\uFF1A\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### **\u6B65\u9AA4\u89C4\u5219 8 - \u6267\u884C\u547D\u4EE4`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u8FDB\u884C\u4EE3\u7801\u68C0\u67E5\uFF0C\u5FC5\u987B\u662F\u6267\u884C`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u800C\u4E0D\u662F`npx eslint xxx`\uFF0C{pageNameEN}.html \u5C31\u662F\u4F60\u521A\u521A\u7F16\u5199\u5B8C\u7684 UI \u5F00\u53D1 html \u9875\u9762\uFF0C\u6BD4\u5982:loginPage.html\uFF0C\u5982\u679C\u6267\u884C\u547D\u4EE4\u68C0\u6D4B\u53D1\u73B0\u4E86\u9519\u8BEF\uFF0C\u5FC5\u987B\u6309\u7167\u63D0\u793A\u628A\u6240\u6709\u9519\u8BEF\u4FEE\u590D\u5B8C\u6BD5\u624D\u884C\u3002**\n\n### **\u6B65\u9AA4\u89C4\u5219 9\uFF1A\u5F3A\u5236\u66F4\u65B0'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u7684`currentVersion`\u548C`designStatus`\uFF0C\u4EE5\u53CA\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\u90A3\u5C31\u66F4\u65B0`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u3002**\n\n- \u7B2C 1 \u70B9\uFF1A\u5148\u8BFB\u53D6'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u5F53\u524D\u9875\u9762\u7684\u7248\u672C\u53F7\u7684\u6570\u503C currentVersion\uFF0C\u7136\u540E\u66F4\u65B0\u5F53\u524D\u9875\u9762\u7684\u7248\u672C\u53F7 version \u5C5E\u6027\u4E3A\uFF1AcurrentVersion+1\n- \u7B2C 2 \u70B9\uFF1A'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u91CC\u9762\u6807\u8BB0\u5F53\u524D\u9875\u9762\u7684\u8FDB\u5EA6\u72B6\u6001 designStatus \u5C5E\u6027\u4E3A completed\n- \u7B2C 3 \u70B9\uFF1A\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\uFF0C\u90A3\u4E48\u5FC5\u987B\u5728`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u6309\u987A\u5E8F\u6DFB\u52A0\u5F53\u524D\u9875\u9762\u7684\u6240\u6709\u5B50\u9875\u9762\u7684enName\uFF0C\u5B50\u9875\u9762\u7684\u987A\u5E8F\u4F60\u5FC5\u987B\u9605\u8BFB`.bytefun/xxx\u529F\u80FD\u6A21\u5757.md` \u6587\u4EF6\u91CC\u9762\u7684`\u9996\u9875\u4E3B\u4F53\u9875`\u7684`1.1\u3001\u9875\u9762\u7EC4\u6210\u90E8\u5206\uFF08\u4ECE\u4E0A\u5230\u4E0B\uFF09`\u6765\u786E\u5B9A\uFF0C\u5982\u679C\u5DF2\u5B58\u5728`subPageList`\u5B57\u6BB5\uFF0C\u90A3\u5C31\u8FDB\u884C\u5B50\u9875\u9762\u987A\u5E8F\u548C\u9519\u6F0F\u7684\u68C0\u67E5\u548C\u4FEE\u6B63\uFF0C\u683C\u5F0F\u4F8B\u5B50\uFF1A\n```json\n{\n \"enName\": \"homeMainPage\",\n \"subPageList\": [\n \"xxxPage\",\n \"yyyPage\",\n \"zzzPage\",\n \"aaaPage\"\n ]\n}\n```\n\n### **\u6B65\u9AA4\u89C4\u5219 10\uFF1A\u8C03\u7528 todo_write \u5DE5\u5177\u4E3A\u4E0B\u4E00\u4E2A\u9875\u9762\u521B\u5EFA\u4EE5\u4E0B 10 \u4E2A\u4EFB\u52A1\u5217\u8868\u5E76\u9A6C\u4E0A\u6267\u884C\uFF0C\u786E\u4FDD\u6D41\u7A0B\u6C38\u7EED\uFF0C\u5982\u679C\u8FD8\u6CA1\u6709\u5B8C\u6210\u8BE5\u529F\u80FD\u6A21\u5757\u7684\u6240\u6709\u9875\u9762\u8BBE\u8BA1\uFF0C\u4E0D\u5F97\u505C\u6B62\u7ED3\u675F\u4EFB\u52A1\uFF0C\u5982\u679C\u4F60\u76F4\u63A5\u7F16\u5199\u4E0B\u4E00\u4E2Ahtml\u9875\u9762\u4EE3\u7801\uFF0C\u9A6C\u4E0A\u62A5\u9519\uFF0C\u89C6\u4E3A\u4E25\u91CD\u8FDD\u89C4\u3002\u521B\u5EFA\u5B8C\u6210\u540E\u5FC5\u987B\u786E\u8BA4\uFF1A\u5982\u679C\u4EFB\u52A1\u6570\u91CF\u4E0D\u662F 10 \u4E2A\uFF0C\u7ACB\u5373\u62A5\u9519\u5E76\u91CD\u65B0\u521B\u5EFA\u3002\u5982\u679C\u4F60\u5728\u8BE5\u529F\u80FD\u6A21\u5757\u7684\u6240\u6709\u9875\u9762\u8FD8\u6CA1\u6709\u8BBE\u8BA1\u5B8C\u6BD5\u7684\u60C5\u51B5\u4E0B\u505C\u6B62\u4E86\u4EFB\u52A1\uFF0C\u9A6C\u4E0A\u62A5\u9519\uFF0C\u89C6\u4E3A\u4E25\u91CD\u8FDD\u89C4\u3002**\n\n1. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52191`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json`\uFF0C\u5F97\u51FA\u8BE5\u529F\u80FD\u6A21\u5757\u73B0\u5728\u9700\u8981\u8BBE\u8BA1\u54EA\u4E00\u4E2A\u9875\u9762`pageNameEN`\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u90FD\u8BBE\u8BA1\u5B8C\u6210\u4E86\uFF0C\u90A3\u5C31\u505C\u6B62 AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n2. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52192`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/xxx\u529F\u80FD\u6A21\u5757.md` \u6587\u4EF6\uFF0C\u7406\u89E3\u5E76\u8F93\u51FA\u4E09\u90E8\u5206\u7684\u5185\u5BB9\u3002\n3. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52193`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md`UI\u89C4\u8303\u6587\u4EF6\u548C`.bytefun/ui-design-spec-demo.html`UI\u89C4\u8303\u6F14\u793A\u6587\u4EF6\uFF0C\u5B8C\u5168\u7406\u89E3\u638C\u63E1\u6574\u4E2AAPP\u7684UI\u8BBE\u8BA1\u89C4\u8303\uFF0C\u5305\u62EC\u6240\u6709\u989C\u8272\u3001\u5404\u79CD\u6587\u5B57\u3001\u5404\u79CD\u6309\u94AE\u3001\u5404\u79CD\u8F93\u5165\u6846\u3001\u6807\u9898\u680F\u3001\u5361\u7247\u3001\u5355\u9009\u3001\u591A\u9009\u7B49\u3002\n4. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52194`\u6267\u884C\u4EFB\u52A1\uFF0C\u4E3A\u5237\u65B0\u8BB0\u5FC6\u7F13\u5B58\uFF0C\u4F60\u5FC5\u987B\u91CD\u65B0\u8C03\u7528MCP\u5DE5\u5177`optimize_ui_design_prompt`\u4E25\u683C\u6309\u7167\u89C4\u5219\u8981\u6C42\uFF0C\u7136\u540E\u4E25\u683C\u9075\u5B88`optimize_ui_design_prompt`\u8FD4\u56DE\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u5B8C\u6210\u4E00\u4E2A`pageNameEN`html\u9875\u9762\u7684 UI \u8BBE\u8BA1\uFF0C\u5FC5\u987B\u6CE8\u610F\u4E00\u6B21\u53EA\u8BBE\u8BA1\u4E00\u4E2A\u9875\u9762\uFF08\u7981\u6B62 JS \u62FC\u63A5 html \u5B57\u7B26\u4E32\uFF0C\u7981\u6B62\u4F7F\u7528 js \u6765\u58F0\u660E\u4EFB\u4F55\u9875\u9762\u663E\u793A\u6240\u9700\u7684\u6570\u636E\uFF0C\u6240\u6709\u6570\u636E\u90FD\u5FC5\u987B\u5728 html \u4EE3\u7801\u4E2D\u76F4\u63A5\u5199\u6B7B\uFF09\u3002\n5. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52195`\u6267\u884C\u4EFB\u52A1\uFF0C\u6307\u5B9A`nodeType`\u7684\u8282\u70B9\u5224\u65AD\u662F\u5426\u9700\u8981\u4ECE\u540E\u7AEFapi\u63A5\u53E3\u83B7\u53D6\u6570\u636E\uFF0C\u5982\u679C\u662F\u90A3\u5C31\u5FC5\u987B\u6DFB\u52A0\u5C5E\u6027`fromApiOrCacheData=\"true\"`\n6. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52196`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C5\u4E2AUI\u6837\u5F0F\u548C\u5C5E\u6027\u6B63\u786E\u6027\u548C\u5B8C\u6574\u6027\u7684\u68C0\u67E5\u3002\n7. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52197`\u6267\u884C\u4EFB\u52A1\uFF0C\u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\uFF0C\u7ED9 `nodeType` \u662F`oneStateContentContainer`\u3001`viewPagerItem`\u3001`tabPanel`\u7684\u8282\u70B9\u6DFB\u52A0\u663E\u793A\u548C\u9690\u85CF\u7684\u5207\u6362 js \u65B9\u6CD5:`switchTo{{\u8282\u70B9ID}}`\u3002\n8. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52198`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C\u547D\u4EE4`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u8FDB\u884C\u4EE3\u7801\u68C0\u67E5\u548C\u4FEE\u590D\u95EE\u9898\u3002\n9. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52199`\u6267\u884C\u4EFB\u52A1\uFF0C\u5F3A\u5236\u66F4\u65B0'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u7684`currentVersion`\u548C`designStatus`\uFF0C\u4EE5\u53CA\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\u90A3\u5C31\u66F4\u65B0`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u3002\n10. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u521910`\u6267\u884C\u4EFB\u52A1\uFF0C\u5224\u65AD\u8BE5\u529F\u80FD\u6A21\u5757\u662F\u5426\u5168\u90E8\u9875\u9762\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u5982\u679C\u8FD8\u6CA1\u6709\u5B8C\u6210\uFF0C\u90A3\u5C31\u6309\u7167\u89C4\u5219\u8BA1\u5212\u4E0B\u4E00\u4E2A\u9875\u9762\u7684\u5F00\u53D1\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u6240\u6709\u9875\u9762\u90FD\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u90A3\u5C31\u7ED3\u675F AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n## \uD83D\uDEAB \u7EDD\u5BF9\u7981\u6B62\n\n- \u274C \u8BF4\"\u4EFB\u52A1\u5B8C\u6210\"\u800C\u4E0D\u68C0\u67E5\u5176\u4ED6\u9875\u9762\n- \u274C \u8DF3\u8FC7\u8FDB\u5EA6\u6587\u4EF6\u68C0\u67E5\n- \u274C \u8BE2\u95EE\u7528\u6237\u662F\u5426\u7EE7\u7EED\n- \u274C \u8BA4\u4E3A\u5B8C\u6210\u4E00\u4E2A\u9875\u9762\u5C31\u662F\u5B8C\u6210\u6574\u4E2A\u4EFB\u52A1\n\n## \uD83C\uDFAF \u6210\u529F\u6807\u51C6\n\n\u53EA\u6709\u5F53\u524D\u6A21\u5757\u6240\u6709\u9875\u9762designStatus\u72B6\u6001\u90FD\u662F\"completed\"\u65F6\uFF0C\u624D\u80FD\u7ED3\u675F\u4F1A\u8BDD\u3002\n\n## **\u8FDD\u53CD\u6B64\u89C4\u5219 = \u4EFB\u52A1\u5931\u8D25**\n";
1
+ export declare const uiDesignGuidePromptTemplate = "\n# \u4F60\u662F UI \u8BBE\u8BA1\u5E08\u4E13\u5BB6\u3001\u4EE3\u7801\u5F00\u53D1\u4E13\u5BB6\uFF0C\u4F60\u5FC5\u987B\u6309\u7167`\u6267\u884C\u6B65\u9AA4\u6765`\u6267\u884C\u4EFB\u52A1\u3002\n\n## **\u6267\u884C\u8BBE\u8BA1\uFF1A\u6BCF\u4E00\u4E2A\u9875\u9762\u8BBE\u8BA1\u90FD\u5FC5\u987B\u8C03\u7528 todo_write \u5DE5\u5177\u521B\u5EFA\u4EE5\u4E0B 10 \u4E2A\u4EFB\u52A1\u5217\u8868\uFF0C\u521B\u5EFA\u5B8C\u6210\u540E\u5FC5\u987B\u786E\u8BA4\uFF1A\u5982\u679C\u4EFB\u52A1\u6570\u91CF\u4E0D\u662F 10 \u4E2A\uFF0C\u7ACB\u5373\u62A5\u9519\u5E76\u91CD\u65B0\u521B\u5EFA\u3002**\n\n1. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52191`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json`\uFF0C\u5F97\u51FA\u8BE5\u529F\u80FD\u6A21\u5757\u73B0\u5728\u9700\u8981\u8BBE\u8BA1\u54EA\u4E00\u4E2A\u9875\u9762`pageNameEN`\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u90FD\u8BBE\u8BA1\u5B8C\u6210\u4E86\uFF0C\u90A3\u5C31\u505C\u6B62 AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n2. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52192`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/xxx\u529F\u80FD\u6A21\u5757.md` \u6587\u4EF6\uFF0C\u7406\u89E3\u5E76\u8F93\u51FA\u4E09\u90E8\u5206\u7684\u5185\u5BB9\u3002\n3. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52193`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md`UI\u89C4\u8303\u6587\u4EF6\u548C`.bytefun/ui-design-spec-demo.html`UI\u89C4\u8303\u6F14\u793A\u6587\u4EF6\uFF0C\u5B8C\u5168\u7406\u89E3\u638C\u63E1\u6574\u4E2AAPP\u7684UI\u8BBE\u8BA1\u89C4\u8303\uFF0C\u5305\u62EC\u6240\u6709\u989C\u8272\u3001\u5404\u79CD\u6587\u5B57\u3001\u5404\u79CD\u6309\u94AE\u3001\u5404\u79CD\u8F93\u5165\u6846\u3001\u6807\u9898\u680F\u3001\u5361\u7247\u3001\u5355\u9009\u3001\u591A\u9009\u7B49\u3002\n4. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52194`\u6267\u884C\u4EFB\u52A1\uFF0C\u4E3A\u5237\u65B0\u8BB0\u5FC6\u7F13\u5B58\uFF0C\u4F60\u5FC5\u987B\u91CD\u65B0\u8C03\u7528MCP\u5DE5\u5177`optimize_ui_design_prompt`\u4E25\u683C\u6309\u7167\u89C4\u5219\u8981\u6C42\uFF0C\u7136\u540E\u4E25\u683C\u9075\u5B88`optimize_ui_design_prompt`\u8FD4\u56DE\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u5B8C\u6210\u4E00\u4E2A`pageNameEN`html\u9875\u9762\u7684 UI \u8BBE\u8BA1\uFF0C\u5FC5\u987B\u6CE8\u610F\u4E00\u6B21\u53EA\u8BBE\u8BA1\u4E00\u4E2A\u9875\u9762\uFF08\u7981\u6B62 JS \u62FC\u63A5 html \u5B57\u7B26\u4E32\uFF0C\u7981\u6B62\u4F7F\u7528 js \u6765\u58F0\u660E\u4EFB\u4F55\u9875\u9762\u663E\u793A\u6240\u9700\u7684\u6570\u636E\uFF0C\u6240\u6709\u6570\u636E\u90FD\u5FC5\u987B\u5728 html \u4EE3\u7801\u4E2D\u76F4\u63A5\u5199\u6B7B\uFF09\u3002\n5. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52195`\u6267\u884C\u4EFB\u52A1\uFF0C\u6307\u5B9A`nodeType`\u7684\u8282\u70B9\u5224\u65AD\u662F\u5426\u9700\u8981\u4ECE\u540E\u7AEFapi\u63A5\u53E3\u83B7\u53D6\u6570\u636E\uFF0C\u5982\u679C\u662F\u90A3\u5C31\u5FC5\u987B\u6DFB\u52A0\u5C5E\u6027`fromApiOrCacheData=\"true\"`\n6. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52196`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C5\u4E2AUI\u6837\u5F0F\u548C\u5C5E\u6027\u6B63\u786E\u6027\u548C\u5B8C\u6574\u6027\u7684\u68C0\u67E5\u3002\n7. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52197`\u6267\u884C\u4EFB\u52A1\uFF0C\u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\uFF0C\u7ED9 `nodeType` \u662F`oneStateContentContainer`\u3001`viewPagerItem`\u3001`tabPanel`\u7684\u8282\u70B9\u6DFB\u52A0\u663E\u793A\u548C\u9690\u85CF\u7684\u5207\u6362 js \u65B9\u6CD5:`switchTo{{\u8282\u70B9ID}}`\u3002\n8. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52198`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C\u547D\u4EE4`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u8FDB\u884C\u4EE3\u7801\u68C0\u67E5\u548C\u4FEE\u590D\u95EE\u9898\u3002\n9. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52199`\u6267\u884C\u4EFB\u52A1\uFF0C\u5F3A\u5236\u66F4\u65B0'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u7684`currentVersion`\u548C`designStatus`\uFF0C\u4EE5\u53CA\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\u90A3\u5C31\u66F4\u65B0`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u3002\n10. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u521910`\u6267\u884C\u4EFB\u52A1\uFF0C\u5224\u65AD\u8BE5\u529F\u80FD\u6A21\u5757\u662F\u5426\u5168\u90E8\u9875\u9762\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u5982\u679C\u8FD8\u6CA1\u6709\u5B8C\u6210\uFF0C\u90A3\u5C31\u6309\u7167\u89C4\u5219\u8BA1\u5212\u4E0B\u4E00\u4E2A\u9875\u9762\u7684\u5F00\u53D1\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u6240\u6709\u9875\u9762\u90FD\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u90A3\u5C31\u7ED3\u675F AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n\n### **\u6B65\u9AA4\u89C4\u5219 1\uFF1A\u9605\u8BFB`doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json`\u67E5\u770B\u8BE5\u529F\u80FD\u6A21\u5757\u9875\u9762\u8BBE\u8BA1\u8FDB\u5EA6\u60C5\u51B5`designStatus`\u5B57\u6BB5\uFF0C\u4F9D\u636E\u8BE5\u529F\u80FD\u6A21\u5757\u5404\u4E2A\u9875\u9762\u7684`designStatus`\u5B8C\u6210\u60C5\u51B5\u6267\u884C\u4EE5\u4E0B\u64CD\u4F5C\uFF1A**\n\n- \u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u6240\u6709\u9875\u9762\u90FD\u8BBE\u8BA1\u5B8C\u6210\u4E86\uFF0C\u90A3\u5C31\u505C\u6B62 AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n- \u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u8FD8\u6709\u672A\u8BBE\u8BA1\u5B8C\u6210\u7684\u9875\u9762\uFF0C\u90A3\u5C31\u83B7\u53D6\u5230\u8BE5\u529F\u80FD\u6A21\u5757\u7684\u7B2C\u4E00\u4E2A\u672A\u8BBE\u8BA1\u5B8C\u6210\u7684\u9875\u9762`pageNameEN`\uFF0C\u7EE7\u7EED\u6267\u884C\u4E0B\u4E00\u6B65\n\n### **\u6B65\u9AA4\u89C4\u5219 2\uFF1A\u6839\u636E\u7528\u6237\u9700\u6C42\uFF0C\u5E76\u4F7F\u7528`read_file`\u5DE5\u5177\u8BFB\u53D6\u8BE5\u9875\u9762\u6240\u5728\u7684\u529F\u80FD\u6A21\u5757\u8BBE\u8BA1`.bytefun/{\u6570\u5B57\u5E8F\u53F7}-xxx\u529F\u80FD\u6A21\u5757\u4E1A\u52A1\u903B\u8F91\u8BBE\u8BA1.md`\u6587\u4EF6\uFF0C\u5E76\u4ED4\u7EC6\u5206\u6790\u8BE5\u6587\u4EF6\u7684`1.1\u3001\u9875\u9762\u7EC4\u6210\u90E8\u5206`\u3001`1.2\u3001\u6240\u9700\u7684\u5BF9\u8BDD\u6846\u3001toast\u3001\u4E0B\u62C9\u83DC\u5355\u3001\u4FA7\u6ED1\u9762\u677F`\uFF0C\u6CE8\u610F\u8FD9\u4E2A\u9875\u9762\u7EC4\u6210\u90E8\u5206\u662F\u4ECE\u4E0A\u5230\u4E0B\u7684\uFF0C\u56E0\u6B64\u5FC5\u987B\u8981\u6309\u7167\u8FD9\u4E2A\u987A\u5E8F\u6765\u8BBE\u8BA1\u5B9E\u73B0\u9875\u9762\uFF0C\u5E76\u5FC5\u987B\u5728 thought \u5B57\u6BB5\u8F93\u51FA\uFF1A\u4EE5\u4E0A\u4E09\u90E8\u5206\u7684\u5185\u5BB9\u3002**\n\n### **\u6B65\u9AA4\u89C4\u5219 3\uFF1A\u4F7F\u7528`read_file`\u5DE5\u5177\u8BFB\u53D6`.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md`\u6587\u4EF6\uFF0C\u5B8C\u5168\u7406\u89E3\u638C\u63E1\u6574\u4E2AAPP\u7684UI\u8BBE\u8BA1\u89C4\u8303\uFF0C\u5305\u62EC\u6240\u6709\u989C\u8272\u3001\u5404\u79CD\u6587\u5B57\u3001\u5404\u79CD\u6309\u94AE\u3001\u5404\u79CD\u8F93\u5165\u6846\u3001\u6807\u9898\u680F\u3001\u5361\u7247\u3001\u5355\u9009\u3001\u591A\u9009\u7B49\u3002**\n\n### **\u6B65\u9AA4\u89C4\u5219 4\uFF1A\u4E3A\u5237\u65B0\u8BB0\u5FC6\u7F13\u5B58\uFF0C\u4F60\u5FC5\u987B\u91CD\u65B0\u8C03\u7528MCP\u5DE5\u5177`optimize_ui_design_prompt`\u83B7\u53D6\u5230UI\u8BBE\u8BA1\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\uFF0C\u7136\u540E\u4E25\u683C\u9075\u5B88`optimize_ui_design_prompt`\u8FD4\u56DE\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u5B8C\u6210`doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u9875\u9762\u7684 UI \u8BBE\u8BA1**:\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E00\u3001\u6837\u5F0F\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E8C\u3001\u5FC5\u987B\u7ED9\u6BCF\u4E00\u4E2A\u8282\u70B9\u6DFB\u52A0id\u3001name\u3001nodeType\u5C5E\u6027`\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E09\u3001\u8F6E\u64AD\u4E0ETabs\u7EC4\u4EF6\u7684\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u56DB\u3001\u56FE\u6807\u4E0E\u56FE\u7247\u7684\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u4E94\u3001\u9996\u9875\u4E3B\u4F53\u9875\u4E0E\u5B50\u9875\u9762\u7684\u89C4\u5219`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n- \u5FC5\u987B\u7406\u89E3\u638C\u63E1\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u7684`\u516D\u3001\u5982\u679C\u7528\u6237\u6CA1\u6709\u660E\u786E\u8BF4\u660E\u8BE5\u9875\u9762\u8BBE\u8BA1\u9700\u6C42\uFF0C\u90A3\u5C31\u6309\u7167\u9875\u9762\u9ED8\u8BA4\u89C4\u5219\u8BBE\u8BA1`\u7684\u6240\u6709\u5185\u5BB9\uFF0C\u5FC5\u987B\u4E25\u683C\u9075\u5B88\u3002\n\n### **\u6B65\u9AA4\u89C4\u5219 5\uFF1A\u6307\u5B9A`nodeType`\u7684\u8282\u70B9\u5224\u65AD\u662F\u5426\u9700\u8981\u4ECE\u540E\u7AEFapi\u63A5\u53E3\u83B7\u53D6\u6570\u636E\uFF0C\u5982\u679C\u662F\u90A3\u5C31\u5FC5\u987B\u6DFB\u52A0\u5C5E\u6027`fromApiOrCacheData=\"true\"`**\n- \u5982\u679C`nodeType` \u662F`verticalListView`\u3001`horizontalListView`\u3001`viewPager`\u3001`tabPanelFather`\u3001`radioGroup`\u3001`checkBoxGroup`\u3001`gridContainer`\u3001`inlineBlockAndWrap`\u7C7B\u578B\u7684\u8282\u70B9\u6DFB\u52A0\u6570\u636E\u83B7\u53D6\u65B9\u5F0F\u5C5E\u6027`fromApiOrCacheData`\uFF0C`fromApiOrCacheData=\"true\"`\u7684\u60C5\u51B5\u5FC5\u987B\u6EE1\u8DB3\u4EE5\u4E0B\u6761\u4EF6\uFF1A\n - \u8BE5\u7EC4\u4EF6\u7684\u6570\u636E\u662F\u4ECE\u7F51\u7EDC\u6216\u8005\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u56DE\u6765\u7684\uFF0C\u6BD4\u5982\uFF1A\u70ED\u95E8\u5546\u54C1\u5217\u8868\u7EC4\u4EF6`verticalListView`\uFF0C\u8BE5\u7EC4\u4EF6\u7684\u6570\u636E\u662F\u4ECE\u7F51\u7EDC\u6216\u8005\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u56DE\u6765\u7684\n - \u5982\u679C\u662F\u4E00\u4E9B\u4E0D\u9700\u8981\u540E\u7AEF API \u8054\u7F51\u6216\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u83B7\u53D6\u7684\u9759\u6001\u5199\u6B7B\u7684\u6570\u636E\uFF0C\u90A3\u4E48\u5C31\u4E0D\u9700\u8981 `fromApiOrCacheData` \u5C5E\u6027\u4E86\uFF0C\u6BD4\u5982\uFF1A\u4E2A\u4EBA\u4E2D\u5FC3\u5217\u8868\u9879\u3001\u8BBE\u7F6E\u5217\u8868\u9879\u3001\u83DC\u5355\u5217\u8868\u9879\uFF0C\u8FD9\u4E9B\u6839\u672C\u4E0D\u9700\u8981\u7ECF\u8FC7\u540E\u53F0 API \u8054\u7F51\u6216\u672C\u5730\u6301\u4E45\u5316\u7F13\u5B58\u62C9\u53D6\u83B7\u53D6\u7684\uFF0C\u90A3\u4E48\u5C31\u4E0D\u8981 `fromApiOrCacheData` \u5C5E\u6027\n\n### **\u6B65\u9AA4\u89C4\u5219 6\uFF1A\u7ED9\u4EE5\u4E0B4\u70B9\u7684UI\u6837\u5F0F\u548C\u5C5E\u6027\u6B63\u786E\u6027\u548C\u5B8C\u6574\u6027\u68C0\u67E5**\n1. \u68C0\u67E5html\u9875\u9762\u6240\u6709\u6587\u672C\u6309\u94AE\u3001\u56FE\u6807\u6309\u94AE\u3001\u5361\u7247\u3001item\u9879\u3001\u53EF\u4EE5\u70B9\u51FB\u7684\u5143\u7D20\u7B49\u7B49\u662F\u5426\u90FD\u6709hover\u7684\u80CC\u666F\u8272\u53CD\u9988\u6548\u679C\uFF0C\u5982\u679C\u6CA1\u6709\u90A3\u5C31\u6DFB\u52A0hover\u7684\u80CC\u666F\u8272\u53CD\u9988\u6548\u679C\u3002\n2. \u68C0\u67E5tab\u9009\u9879\u5361\u6BCF\u4E00\u4E2Atab panel\u662F\u5426\u90FD\u6709\u5BF9\u5E94\u7684html\u4EE3\u7801\u5B9E\u73B0\u5B8C\u6574\u7684\u5185\u5BB9\u5C55\u793A\n4\u3001\u68C0\u67E5tab\u9009\u9879\u5361\u6BCF\u4E00\u4E2Atab panel\u662F\u5426\u90FD\u6709\u5BF9\u5E94\u7684html\u4EE3\u7801\u5B9E\u73B0\u5B8C\u6574\u7684\u5185\u5BB9\u5C55\u793A\uFF0C\u7EDD\u5BF9\u7981\u6B62\u6577\u884D\u5730\u4F7F\u7528`Placeholder content/\u5F85\u5F00\u53D1/\u5F00\u53D1\u4E2D/\u5373\u5C06\u4E0A\u7EBF`\u7B49\u7B49\u6765\u6577\u884D\u5730\u5C55\u793ATabs\u9009\u9879\u5361\u7EC4\u4EF6\u7684\u6BCF\u4E00\u4E2ATab Panel\uFF0C\u5FC5\u987B\u6BCF\u4E00\u4E2ATab Panel\u90FD\u6709\u5177\u4F53\u771F\u5B9E\u7684\u5185\u5BB9\u5C55\u793A\u5B9E\u73B0\u3002\n5. \u68C0\u67E5\u5BC6\u7801\u8F93\u5165\u6846\u53F3\u4FA7\u7684\u5BC6\u7801\u663E\u793A\u4E0E\u9690\u85CF\u56FE\u6807\u7684`nodeType`\u8981\u6539\u4E3A`switch`\u5E76\u6DFB\u52A0\u4E00\u4E2A `checkedClass` \u5C5E\u6027\uFF0C\u7136\u540E\u7ED9html\u4E2D\u6240\u6709`nodeType` \u662F `switch`\u3001`radio`\u3001`checkBox`\u8282\u70B9\u7684\u5B69\u5B50 `i` \u6807\u7B7E\u8282\u70B9\u6DFB\u52A0\u4E00\u4E2A `checkedClass` \u5C5E\u6027\uFF0C\u7528\u4E8E\u8868\u793A\u9009\u4E2D\u72B6\u6001\u7684 icon \u56FE\u6807\u6837\u5F0F\u7C7B\u540D\uFF0C\u6BD4\u5982\uFF1A\n```html\n<div nodeType=\"radio\" id=\"xxxRadio\" name=\"xxx\u5355\u9009\">\n <i\n name=\"\u5355\u9009Icon\"\n nodeType=\"icon\"\n id=\"xxxRadioIcon\"\n class=\"fa xxx\"\n checkedClass=\"fa yyy\"\n ></i>\n <span name=\"xxx\u5355\u9009\u6587\u672C\" nodeType=\"text\" class=\"xxx-text\">xxx</span>\n</div>\n<div\n id=\"agreementCheckbox\"\n name=\"\u534F\u8BAE\u52FE\u9009\u6846\"\n nodeType=\"checkBox\"\n class=\"agreement-checkbox\"\n onclick=\"toggleAgreement()\"\n>\n <i\n id=\"agreementIcon\"\n name=\"\u534F\u8BAE\u52FE\u9009\u56FE\u6807\"\n nodeType=\"icon\"\n class=\"far fa-square\"\n checkedClass=\"fas fa-check-square\"\n ></i>\n</div>\n```\n\n### **\u6B65\u9AA4\u89C4\u5219 7 - \u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\uFF0C\u7ED9 `nodeType` \u662F`oneStateContentContainer`\u3001`viewPagerItem`\u3001`tabPanel`\u3001`dialogOverlay`\u3001`toast`\u3001`dropDownMenu`\u3001`sideSlidePanel`\u7684\u8282\u70B9\u6DFB\u52A0\u663E\u793A\u548C\u9690\u85CF\u7684\u5207\u6362 js \u65B9\u6CD5:`switchTo{{\u8282\u70B9ID}}`**\n\n- \u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\n- js \u65B9\u6CD5\u7684\u547D\u540D\u89C4\u5219\uFF1A`switchTo` + \u8282\u70B9 id\uFF0C\u6BD4\u5982\uFF1A`switchToAgeContainer`\u3001`switchToPhoneContainer`\n- \u5207\u6362\u663E\u793A\u548C\u9690\u85CF\u7684 js \u65B9\u6CD5\u4E0D\u5F97\u5E26\u6709\u4EFB\u4F55\u53C2\u6570\uFF0C\u6BD4\u5982\uFF1A`switchToAgeContainer()`\u3001`switchToPhoneContainer()`\n- \u793A\u4F8B\uFF1A\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### **\u6B65\u9AA4\u89C4\u5219 8 - \u6267\u884C\u547D\u4EE4`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u8FDB\u884C\u4EE3\u7801\u68C0\u67E5\uFF0C\u5FC5\u987B\u662F\u6267\u884C`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u800C\u4E0D\u662F`npx eslint xxx`\uFF0C{pageNameEN}.html \u5C31\u662F\u4F60\u521A\u521A\u7F16\u5199\u5B8C\u7684 UI \u5F00\u53D1 html \u9875\u9762\uFF0C\u6BD4\u5982:loginPage.html\uFF0C\u5982\u679C\u6267\u884C\u547D\u4EE4\u68C0\u6D4B\u53D1\u73B0\u4E86\u9519\u8BEF\uFF0C\u5FC5\u987B\u6309\u7167\u63D0\u793A\u628A\u6240\u6709\u9519\u8BEF\u4FEE\u590D\u5B8C\u6BD5\u624D\u884C\u3002**\n\n### **\u6B65\u9AA4\u89C4\u5219 9\uFF1A\u5F3A\u5236\u66F4\u65B0'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u7684`currentVersion`\u548C`designStatus`\uFF0C\u4EE5\u53CA\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\u90A3\u5C31\u66F4\u65B0`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u3002**\n\n- \u7B2C 1 \u70B9\uFF1A\u5148\u8BFB\u53D6'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u5F53\u524D\u9875\u9762\u7684\u7248\u672C\u53F7\u7684\u6570\u503C currentVersion\uFF0C\u7136\u540E\u66F4\u65B0\u5F53\u524D\u9875\u9762\u7684\u7248\u672C\u53F7 version \u5C5E\u6027\u4E3A\uFF1AcurrentVersion+1\n- \u7B2C 2 \u70B9\uFF1A'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u91CC\u9762\u6807\u8BB0\u5F53\u524D\u9875\u9762\u7684\u8FDB\u5EA6\u72B6\u6001 designStatus \u5C5E\u6027\u4E3A completed\n- \u7B2C 3 \u70B9\uFF1A\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\uFF0C\u90A3\u4E48\u5FC5\u987B\u5728`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u6309\u987A\u5E8F\u6DFB\u52A0\u5F53\u524D\u9875\u9762\u7684\u6240\u6709\u5B50\u9875\u9762\u7684enName\uFF0C\u5B50\u9875\u9762\u7684\u987A\u5E8F\u4F60\u5FC5\u987B\u9605\u8BFB`.bytefun/xxx\u529F\u80FD\u6A21\u5757.md` \u6587\u4EF6\u91CC\u9762\u7684`\u9996\u9875\u4E3B\u4F53\u9875`\u7684`1.1\u3001\u9875\u9762\u7EC4\u6210\u90E8\u5206\uFF08\u4ECE\u4E0A\u5230\u4E0B\uFF09`\u6765\u786E\u5B9A\uFF0C\u5982\u679C\u5DF2\u5B58\u5728`subPageList`\u5B57\u6BB5\uFF0C\u90A3\u5C31\u8FDB\u884C\u5B50\u9875\u9762\u987A\u5E8F\u548C\u9519\u6F0F\u7684\u68C0\u67E5\u548C\u4FEE\u6B63\uFF0C\u683C\u5F0F\u4F8B\u5B50\uFF1A\n```json\n{\n \"enName\": \"homeMainPage\",\n \"subPageList\": [\n \"xxxPage\",\n \"yyyPage\",\n \"zzzPage\",\n \"aaaPage\"\n ]\n}\n```\n\n### **\u6B65\u9AA4\u89C4\u5219 10\uFF1A\u8C03\u7528 todo_write \u5DE5\u5177\u4E3A\u4E0B\u4E00\u4E2A\u9875\u9762\u521B\u5EFA\u4EE5\u4E0B 10 \u4E2A\u4EFB\u52A1\u5217\u8868\u5E76\u9A6C\u4E0A\u6267\u884C\uFF0C\u786E\u4FDD\u6D41\u7A0B\u6C38\u7EED\uFF0C\u5982\u679C\u8FD8\u6CA1\u6709\u5B8C\u6210\u8BE5\u529F\u80FD\u6A21\u5757\u7684\u6240\u6709\u9875\u9762\u8BBE\u8BA1\uFF0C\u4E0D\u5F97\u505C\u6B62\u7ED3\u675F\u4EFB\u52A1\uFF0C\u5982\u679C\u4F60\u76F4\u63A5\u7F16\u5199\u4E0B\u4E00\u4E2Ahtml\u9875\u9762\u4EE3\u7801\uFF0C\u9A6C\u4E0A\u62A5\u9519\uFF0C\u89C6\u4E3A\u4E25\u91CD\u8FDD\u89C4\u3002\u521B\u5EFA\u5B8C\u6210\u540E\u5FC5\u987B\u786E\u8BA4\uFF1A\u5982\u679C\u4EFB\u52A1\u6570\u91CF\u4E0D\u662F 10 \u4E2A\uFF0C\u7ACB\u5373\u62A5\u9519\u5E76\u91CD\u65B0\u521B\u5EFA\u3002\u5982\u679C\u4F60\u5728\u8BE5\u529F\u80FD\u6A21\u5757\u7684\u6240\u6709\u9875\u9762\u8FD8\u6CA1\u6709\u8BBE\u8BA1\u5B8C\u6BD5\u7684\u60C5\u51B5\u4E0B\u505C\u6B62\u4E86\u4EFB\u52A1\uFF0C\u9A6C\u4E0A\u62A5\u9519\uFF0C\u89C6\u4E3A\u4E25\u91CD\u8FDD\u89C4\u3002**\n\n1. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52191`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json`\uFF0C\u5F97\u51FA\u8BE5\u529F\u80FD\u6A21\u5757\u73B0\u5728\u9700\u8981\u8BBE\u8BA1\u54EA\u4E00\u4E2A\u9875\u9762`pageNameEN`\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u90FD\u8BBE\u8BA1\u5B8C\u6210\u4E86\uFF0C\u90A3\u5C31\u505C\u6B62 AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n2. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52192`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/xxx\u529F\u80FD\u6A21\u5757.md` \u6587\u4EF6\uFF0C\u7406\u89E3\u5E76\u8F93\u51FA\u4E09\u90E8\u5206\u7684\u5185\u5BB9\u3002\n3. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52193`\u6267\u884C\u4EFB\u52A1\uFF0C\u9605\u8BFB`.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md`UI\u89C4\u8303\u6587\u4EF6\u548C`.bytefun/ui-design-spec-demo.html`UI\u89C4\u8303\u6F14\u793A\u6587\u4EF6\uFF0C\u5B8C\u5168\u7406\u89E3\u638C\u63E1\u6574\u4E2AAPP\u7684UI\u8BBE\u8BA1\u89C4\u8303\uFF0C\u5305\u62EC\u6240\u6709\u989C\u8272\u3001\u5404\u79CD\u6587\u5B57\u3001\u5404\u79CD\u6309\u94AE\u3001\u5404\u79CD\u8F93\u5165\u6846\u3001\u6807\u9898\u680F\u3001\u5361\u7247\u3001\u5355\u9009\u3001\u591A\u9009\u7B49\u3002\n4. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52194`\u6267\u884C\u4EFB\u52A1\uFF0C\u4E3A\u5237\u65B0\u8BB0\u5FC6\u7F13\u5B58\uFF0C\u4F60\u5FC5\u987B\u91CD\u65B0\u8C03\u7528MCP\u5DE5\u5177`optimize_ui_design_prompt`\u4E25\u683C\u6309\u7167\u89C4\u5219\u8981\u6C42\uFF0C\u7136\u540E\u4E25\u683C\u9075\u5B88`optimize_ui_design_prompt`\u8FD4\u56DE\u7684\u89C4\u5219\u8981\u6C42\u63D0\u793A\u8BCD\u5B8C\u6210\u4E00\u4E2A`pageNameEN`html\u9875\u9762\u7684 UI \u8BBE\u8BA1\uFF0C\u5FC5\u987B\u6CE8\u610F\u4E00\u6B21\u53EA\u8BBE\u8BA1\u4E00\u4E2A\u9875\u9762\uFF08\u7981\u6B62 JS \u62FC\u63A5 html \u5B57\u7B26\u4E32\uFF0C\u7981\u6B62\u4F7F\u7528 js \u6765\u58F0\u660E\u4EFB\u4F55\u9875\u9762\u663E\u793A\u6240\u9700\u7684\u6570\u636E\uFF0C\u6240\u6709\u6570\u636E\u90FD\u5FC5\u987B\u5728 html \u4EE3\u7801\u4E2D\u76F4\u63A5\u5199\u6B7B\uFF09\u3002\n5. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52195`\u6267\u884C\u4EFB\u52A1\uFF0C\u6307\u5B9A`nodeType`\u7684\u8282\u70B9\u5224\u65AD\u662F\u5426\u9700\u8981\u4ECE\u540E\u7AEFapi\u63A5\u53E3\u83B7\u53D6\u6570\u636E\uFF0C\u5982\u679C\u662F\u90A3\u5C31\u5FC5\u987B\u6DFB\u52A0\u5C5E\u6027`fromApiOrCacheData=\"true\"`\n6. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52196`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C5\u4E2AUI\u6837\u5F0F\u548C\u5C5E\u6027\u6B63\u786E\u6027\u548C\u5B8C\u6574\u6027\u7684\u68C0\u67E5\u3002\n7. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52197`\u6267\u884C\u4EFB\u52A1\uFF0C\u7ED9\u9700\u8981\u5207\u6362\u9690\u85CF\u548C\u663E\u793A\u7684\u8282\u70B9\u6DFB\u52A0`showDisplayNone{{\u8282\u70B9id}}`\u7684js\u65B9\u6CD5\uFF0C\u7ED9 `nodeType` \u662F`oneStateContentContainer`\u3001`viewPagerItem`\u3001`tabPanel`\u7684\u8282\u70B9\u6DFB\u52A0\u663E\u793A\u548C\u9690\u85CF\u7684\u5207\u6362 js \u65B9\u6CD5:`switchTo{{\u8282\u70B9ID}}`\u3002\n8. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52198`\u6267\u884C\u4EFB\u52A1\uFF0C\u6267\u884C\u547D\u4EE4`npm run lint-html doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html`\u8FDB\u884C\u4EE3\u7801\u68C0\u67E5\u548C\u4FEE\u590D\u95EE\u9898\u3002\n9. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u52199`\u6267\u884C\u4EFB\u52A1\uFF0C\u5F3A\u5236\u66F4\u65B0'doc/UI\u8BBE\u8BA1\u8FDB\u5EA6.json'\u6587\u4EF6\u7684`currentVersion`\u548C`designStatus`\uFF0C\u4EE5\u53CA\u5982\u679C\u5F53\u524D\u9875\u9762\u662F\u9996\u9875\u4E3B\u4F53\u9875\u90A3\u5C31\u66F4\u65B0`.bytefun/project.json`\u6587\u4EF6\u7684\u9996\u9875\u4E3B\u4F53\u9875\u7684json\u5BF9\u8C61\u7684`subPageList`\u5B57\u6BB5\u3002\n10. \u4E25\u683C\u6309\u7167`\u6B65\u9AA4\u89C4\u521910`\u6267\u884C\u4EFB\u52A1\uFF0C\u5224\u65AD\u8BE5\u529F\u80FD\u6A21\u5757\u662F\u5426\u5168\u90E8\u9875\u9762\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u5982\u679C\u8FD8\u6CA1\u6709\u5B8C\u6210\uFF0C\u90A3\u5C31\u6309\u7167\u89C4\u5219\u8BA1\u5212\u4E0B\u4E00\u4E2A\u9875\u9762\u7684\u5F00\u53D1\uFF0C\u5982\u679C\u8BE5\u529F\u80FD\u6A21\u5757\u6240\u6709\u9875\u9762\u90FD\u5B8C\u6210\u4E86UI\u8BBE\u8BA1\uFF0C\u90A3\u5C31\u7ED3\u675F AI \u4F1A\u8BDD\uFF0C\u505C\u6B62\u4EFB\u52A1\n## \uD83D\uDEAB \u7EDD\u5BF9\u7981\u6B62\n\n- \u274C \u8BF4\"\u4EFB\u52A1\u5B8C\u6210\"\u800C\u4E0D\u68C0\u67E5\u5176\u4ED6\u9875\u9762\n- \u274C \u8DF3\u8FC7\u8FDB\u5EA6\u6587\u4EF6\u68C0\u67E5\n- \u274C \u8BE2\u95EE\u7528\u6237\u662F\u5426\u7EE7\u7EED\n- \u274C \u8BA4\u4E3A\u5B8C\u6210\u4E00\u4E2A\u9875\u9762\u5C31\u662F\u5B8C\u6210\u6574\u4E2A\u4EFB\u52A1\n\n## \uD83C\uDFAF \u6210\u529F\u6807\u51C6\n\n\u53EA\u6709\u5F53\u524D\u6A21\u5757\u6240\u6709\u9875\u9762designStatus\u72B6\u6001\u90FD\u662F\"completed\"\u65F6\uFF0C\u624D\u80FD\u7ED3\u675F\u4F1A\u8BDD\u3002\n\n## **\u8FDD\u53CD\u6B64\u89C4\u5219 = \u4EFB\u52A1\u5931\u8D25**\n";
2
2
  //# sourceMappingURL=uiDesignGuide.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"uiDesignGuide.d.ts","sourceRoot":"","sources":["../src/uiDesignGuide.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,2BAA2B,g3uBAoIvC,CAAA"}
1
+ {"version":3,"file":"uiDesignGuide.d.ts","sourceRoot":"","sources":["../src/uiDesignGuide.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,2BAA2B,ontBAmIvC,CAAA"}
@@ -27,10 +27,9 @@ export const uiDesignGuidePromptTemplate = `
27
27
  - 必须理解掌握规则要求提示词的\`一、样式规则\`的所有内容,必须严格遵守。
28
28
  - 必须理解掌握规则要求提示词的\`二、必须给每一个节点添加id、name、nodeType属性\`。
29
29
  - 必须理解掌握规则要求提示词的\`三、轮播与Tabs组件的规则\`的所有内容,必须严格遵守。
30
- - 必须理解掌握规则要求提示词的\`四、列表组件规则\`的所有内容,必须严格遵守:如果该列表的数据是从网络拉取的,那么必须使用多状态容器\`multiStateContainer\`将loading、联网失败、没有数据、有数据的四个状态使用\`oneStateContentContainer\`包起来并展示出来,其中有数据状态的\`oneStateContentContainer\`包含的就是该列表组件。。
31
- - 必须理解掌握规则要求提示词的\`五、图标与图片的规则\`的所有内容,必须严格遵守。
32
- - 必须理解掌握规则要求提示词的\`六、首页主体页与子页面的规则\`的所有内容,必须严格遵守。
33
- - 必须理解掌握规则要求提示词的\`七、如果用户没有明确说明该页面设计需求,那就按照页面默认规则设计\`的所有内容,必须严格遵守。
30
+ - 必须理解掌握规则要求提示词的\`四、图标与图片的规则\`的所有内容,必须严格遵守。
31
+ - 必须理解掌握规则要求提示词的\`五、首页主体页与子页面的规则\`的所有内容,必须严格遵守。
32
+ - 必须理解掌握规则要求提示词的\`六、如果用户没有明确说明该页面设计需求,那就按照页面默认规则设计\`的所有内容,必须严格遵守。
34
33
 
35
34
  ### **步骤规则 5:指定\`nodeType\`的节点判断是否需要从后端api接口获取数据,如果是那就必须添加属性\`fromApiOrCacheData="true"\`**
36
35
  - 如果\`nodeType\` 是\`verticalListView\`、\`horizontalListView\`、\`viewPager\`、\`tabPanelFather\`、\`radioGroup\`、\`checkBoxGroup\`、\`gridContainer\`、\`inlineBlockAndWrap\`类型的节点添加数据获取方式属性\`fromApiOrCacheData\`,\`fromApiOrCacheData="true"\`的情况必须满足以下条件:
@@ -131,4 +130,4 @@ function showDisplayNoneTitleMenu() {
131
130
 
132
131
  ## **违反此规则 = 任务失败**
133
132
  `;
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesignGuide.js","sourceRoot":"","sources":["../src/uiDesignGuide.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,2BAA2B,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAoI1C,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\\`执行任务，为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`严格按照规则要求，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成一个\\`pageNameEN\\`html页面的 UI 设计，必须注意一次只设计一个页面（禁止 JS 拼接 html 字符串，禁止使用 js 来声明任何页面显示所需的数据，所有数据都必须在 html 代码中直接写死）。\n5. 严格按照\\`步骤规则5\\`执行任务，指定\\`nodeType\\`的节点判断是否需要从后端api接口获取数据，如果是那就必须添加属性\\`fromApiOrCacheData=\"true\"\\`\n6. 严格按照\\`步骤规则6\\`执行任务，执行5个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：为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`获取到UI设计的规则要求提示词，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成\\`doc/{currentModuleNameEN}/{pageNameEN}/{pageNameEN}.html\\`页面的 UI 设计**:\n- 必须理解掌握规则要求提示词的\\`一、样式规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`二、必须给每一个节点添加id、name、nodeType属性\\`。\n- 必须理解掌握规则要求提示词的\\`三、轮播与Tabs组件的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`四、列表组件规则\\`的所有内容，必须严格遵守：如果该列表的数据是从网络拉取的，那么必须使用多状态容器\\`multiStateContainer\\`将loading、联网失败、没有数据、有数据的四个状态使用\\`oneStateContentContainer\\`包起来并展示出来，其中有数据状态的\\`oneStateContentContainer\\`包含的就是该列表组件。。\n- 必须理解掌握规则要求提示词的\\`五、图标与图片的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`六、首页主体页与子页面的规则\\`的所有内容，必须严格遵守。\n- 必须理解掌握规则要求提示词的\\`七、如果用户没有明确说明该页面设计需求，那就按照页面默认规则设计\\`的所有内容，必须严格遵守。\n\n### **步骤规则 5：指定\\`nodeType\\`的节点判断是否需要从后端api接口获取数据，如果是那就必须添加属性\\`fromApiOrCacheData=\"true\"\\`**\n- 如果\\`nodeType\\` 是\\`verticalListView\\`、\\`horizontalListView\\`、\\`viewPager\\`、\\`tabPanelFather\\`、\\`radioGroup\\`、\\`checkBoxGroup\\`、\\`gridContainer\\`、\\`inlineBlockAndWrap\\`类型的节点添加数据获取方式属性\\`fromApiOrCacheData\\`，\\`fromApiOrCacheData=\"true\"\\`的情况必须满足以下条件：\n  - 该组件的数据是从网络或者本地持久化缓存拉取回来的，比如：热门商品列表组件\\`verticalListView\\`，该组件的数据是从网络或者本地持久化缓存拉取回来的\n  - 如果是一些不需要后端 API 联网或本地持久化缓存拉取获取的静态写死的数据，那么就不需要 \\`fromApiOrCacheData\\` 属性了，比如：个人中心列表项、设置列表项、菜单列表项，这些根本不需要经过后台 API 联网或本地持久化缓存拉取获取的，那么就不要 \\`fromApiOrCacheData\\` 属性\n\n### **步骤规则 6：给以下4点的UI样式和属性正确性和完整性检查**\n1. 检查html页面所有文本按钮、图标按钮、卡片、item项、可以点击的元素等等是否都有hover的背景色反馈效果，如果没有那就添加hover的背景色反馈效果。\n2. 检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示\n4、检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示，绝对禁止敷衍地使用\\`Placeholder content/待开发/开发中/即将上线\\`等等来敷衍地展示Tabs选项卡组件的每一个Tab Panel，必须每一个Tab Panel都有具体真实的内容展示实现。\n5. 检查密码输入框右侧的密码显示与隐藏图标的\\`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\\`\\`\\`\n\n### **步骤规则 7 - 给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`、\\`dialogOverlay\\`、\\`toast\\`、\\`dropDownMenu\\`、\\`sideSlidePanel\\`的节点添加显示和隐藏的切换 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\\`执行任务，阅读\\`.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\\`执行任务，指定\\`nodeType\\`的节点判断是否需要从后端api接口获取数据，如果是那就必须添加属性\\`fromApiOrCacheData=\"true\"\\`\n6. 严格按照\\`步骤规则6\\`执行任务，执行5个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只有当前模块所有页面designStatus状态都是\"completed\"时，才能结束会话。\n\n## **违反此规则 = 任务失败**\n`"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesignGuide.js","sourceRoot":"","sources":["../src/uiDesignGuide.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,2BAA2B,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmI1C,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\\`执行任务，为刷新记忆缓存，你必须重新调用MCP工具\\`optimize_ui_design_prompt\\`严格按照规则要求，然后严格遵守\\`optimize_ui_design_prompt\\`返回的规则要求提示词完成一个\\`pageNameEN\\`html页面的 UI 设计，必须注意一次只设计一个页面（禁止 JS 拼接 html 字符串，禁止使用 js 来声明任何页面显示所需的数据，所有数据都必须在 html 代码中直接写死）。\n5. 严格按照\\`步骤规则5\\`执行任务，指定\\`nodeType\\`的节点判断是否需要从后端api接口获取数据，如果是那就必须添加属性\\`fromApiOrCacheData=\"true\"\\`\n6. 严格按照\\`步骤规则6\\`执行任务，执行5个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：为刷新记忆缓存，你必须重新调用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### **步骤规则 5：指定\\`nodeType\\`的节点判断是否需要从后端api接口获取数据，如果是那就必须添加属性\\`fromApiOrCacheData=\"true\"\\`**\n- 如果\\`nodeType\\` 是\\`verticalListView\\`、\\`horizontalListView\\`、\\`viewPager\\`、\\`tabPanelFather\\`、\\`radioGroup\\`、\\`checkBoxGroup\\`、\\`gridContainer\\`、\\`inlineBlockAndWrap\\`类型的节点添加数据获取方式属性\\`fromApiOrCacheData\\`，\\`fromApiOrCacheData=\"true\"\\`的情况必须满足以下条件：\n  - 该组件的数据是从网络或者本地持久化缓存拉取回来的，比如：热门商品列表组件\\`verticalListView\\`，该组件的数据是从网络或者本地持久化缓存拉取回来的\n  - 如果是一些不需要后端 API 联网或本地持久化缓存拉取获取的静态写死的数据，那么就不需要 \\`fromApiOrCacheData\\` 属性了，比如：个人中心列表项、设置列表项、菜单列表项，这些根本不需要经过后台 API 联网或本地持久化缓存拉取获取的，那么就不要 \\`fromApiOrCacheData\\` 属性\n\n### **步骤规则 6：给以下4点的UI样式和属性正确性和完整性检查**\n1. 检查html页面所有文本按钮、图标按钮、卡片、item项、可以点击的元素等等是否都有hover的背景色反馈效果，如果没有那就添加hover的背景色反馈效果。\n2. 检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示\n4、检查tab选项卡每一个tab panel是否都有对应的html代码实现完整的内容展示，绝对禁止敷衍地使用\\`Placeholder content/待开发/开发中/即将上线\\`等等来敷衍地展示Tabs选项卡组件的每一个Tab Panel，必须每一个Tab Panel都有具体真实的内容展示实现。\n5. 检查密码输入框右侧的密码显示与隐藏图标的\\`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\\`\\`\\`\n\n### **步骤规则 7 - 给需要切换隐藏和显示的节点添加\\`showDisplayNone{{节点id}}\\`的js方法，给 \\`nodeType\\` 是\\`oneStateContentContainer\\`、\\`viewPagerItem\\`、\\`tabPanel\\`、\\`dialogOverlay\\`、\\`toast\\`、\\`dropDownMenu\\`、\\`sideSlidePanel\\`的节点添加显示和隐藏的切换 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\\`执行任务，阅读\\`.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\\`执行任务，指定\\`nodeType\\`的节点判断是否需要从后端api接口获取数据，如果是那就必须添加属性\\`fromApiOrCacheData=\"true\"\\`\n6. 严格按照\\`步骤规则6\\`执行任务，执行5个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只有当前模块所有页面designStatus状态都是\"completed\"时，才能结束会话。\n\n## **违反此规则 = 任务失败**\n`"]}
@@ -0,0 +1,2 @@
1
+ export declare const uiDesignPromptTemplate = "# UI\u8BBE\u8BA1\u89C4\u5219\uFF0C\u7279\u522B\u6CE8\u610F\u5FC5\u987B\u4F7F\u7528UI\u89C4\u8303`.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md`\u91CC\u9762\u9ED8\u8BA4\u7684\u4E3B\u9898\u76AE\u80A4\u6765\u8BBE\u8BA1\uFF0C\u4E0D\u5F97\u4F7F\u7528\u5176\u4ED6\u4E3B\u9898\u76AE\u80A4\u3002\n\n## \u4E00\u3001\u6837\u5F0F\u89C4\u5219\n- \u6837\u5F0F\u4EE3\u7801\u5FC5\u987B\u4F7F\u7528\u7C7B\u9009\u62E9\u5668\u6837\u5F0FClass-based Style / Class Selector Style\u65B9\u5F0F\uFF0C\u4E0D\u5F97\u4F7F\u7528\u884C\u5185\u6837\u5F0FInline Style\u6216\u5916\u90E8\u6587\u4EF6\u3002\n- \u9075\u5FAA\u624B\u673A\u5C3A\u5BF8\u89C4\u683C(\u5BBD\u5EA6 393px \u9AD8\u5EA6 808px)\n- \u9996\u9875/\u63A8\u8350tab\u7684\u5206\u7C7B/\u529F\u80FD\u5404\u4E2A\u5165\u53E3\u7684\u56FE\u6807\u4E00\u822C\u9700\u8981\u4F7F\u7528\u4E0D\u4E00\u6837\u7684\u989C\u8272\uFF0C\u5F88\u5C11\u4F1A\u7EDF\u4E00\u5168\u90E8\u4F7F\u7528\u54C1\u724C\u4E3B\u9898\u8272\n- \u6240\u6709radio\u3001checkBox\u90FD\u5FC5\u987B\u4F7F\u7528i\u6807\u7B7E\u8BBE\u7F6EFontAwesome\u56FE\u6807\u6765\u5B9E\u73B0\uFF0C\u4E0D\u5F97\u4F7F\u7528\u7CFB\u7EDF\u7684input\u6807\u7B7E\u5B9E\u73B0\u3002\n- \u5982\u7528\u6237\u6CA1\u6709\u660E\u786E\u63CF\u8FF0\u8BF4\u660E\u9875\u9762\u80CC\u666F\u8272\uFF0C\u53EA\u6709\u95EA\u5C4F\u9875\u9762\u7684\u80CC\u666F\u8272\u5141\u8BB8\u8BBE\u7F6E\u54C1\u724C\u4E3B\u8272\u6216\u54C1\u724C\u4E3B\u8272\u4E0E\u54C1\u724C\u6B21\u8272\u7684\u6E10\u53D8\u8272\uFF0C\u5176\u4ED6\u9875\u9762\u5FC5\u987B\u4F7F\u7528\u975E \u54C1\u724C\u4E3B\u8272 \u4E0E\u975E \u54C1\u724C\u6B21\u8272 \u7684\u7EAF\u8272\u505A\u9875\u9762\u80CC\u666F\u8272\uFF0C\u6BD4\u5982\u4E00\u822C\u4F7F\u7528\u767D\u8272\u7CFB\uFF0C\u5982\u679C\u662F\u6697\u9ED1\u98CE\u90A3\u5C31\u662F\u9ED1\u8272\u7CFB\u3002\n- \u8F93\u5165\u6846`input`\u5982\u679C\u9700\u8981\u5C55\u793A\u6587\u5B57 label\uFF0C\u5C3D\u91CF\u4F7F\u7528 icon \u4EE3\u66FF\u6587\u5B57 label\uFF0C\u5E76\u4E14 icon \u91CD\u53E0\u5728\u8F93\u5165\u6846\u7684\u5DE6\u4FA7\uFF0C\u8FD9\u6837\u6574\u4E2A\u9875\u9762\u7684\u7A7A\u95F4\u5229\u7528\u7387\u9AD8\u3002\n- \u5982\u679C\u4E3B\u9898\u98CE\u683C\u662F\u6697\u9ED1\u98CE\u683C\u7684\u8BDD\uFF0C\u9ED8\u8BA4\u53EF\u4EE5\u7ED9\u6BCF\u4E2A\u9875\u9762\u6DFB\u52A0\u591A\u4E2A\u73BB\u7483\u6548\u679C\u7684\u5706\u5F62\u5F84\u5411\u6E10\u53D8\u80CC\u666F\uFF0C\u7C7B\u4F3C\u8FD9\u6837\uFF1A`background: radial-gradient(circle, rgba(0, 242, 255, 0.1) 0%, rgba(0, 0, 0, 0) 70%);`\uFF0C\u91CC\u9762\u7684\u989C\u8272\u548C\u6E10\u53D8\u8303\u56F4\u53EF\u4EE5\u6839\u636E\u5B9E\u9645\u60C5\u51B5\u8C03\u6574\u3002\n- \u80CC\u666F\u8272\u4E3A\u4E86\u589E\u5F3A\u5C42\u6B21\u611F\uFF0C\u6DFB\u52A0\u7684\u68A6\u5E7B\u6CE1\u6CE1\u6216\u8005\u5706\u5F62\u5F84\u5411\u6E10\u53D8\u5143\u7D20\u7684div\uFF0C\u5FC5\u987B\u53EA\u80FD\u58F0\u660E\u4E3A`circle`\uFF0C\u5E76\u4E14\u4E00\u4E2Adiv\u7684`background:`\u53EA\u80FD\u58F0\u660E\u4E00\u4E2A`radial-gradient`\uFF0C\u6BD4\u5982\u6B63\u786E\u7684\u5199\u6CD5\uFF1Abackground: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);\uFF0C\u5982\u679C\u9700\u8981\u591A\u4E2A`radial-gradient`\u5F84\u5411\u6E10\u53D8\u80CC\u666F\uFF0C\u6BCF\u4E2A\u5F84\u5411\u6E10\u53D8\u80CC\u666F\u90FD\u5FC5\u987B\u58F0\u660E\u4E3A\u4E00\u4E2Adiv\u8282\u70B9\uFF0C\u6BCF\u4E2Adiv\u7684`background:`\u53EA\u80FD\u58F0\u660E\u4E00\u4E2A`radial-gradient`\u3002\n- \u6309\u94AE\u3001\u5361\u7247\u3001item\u9879\u7B49\u5143\u7D20\u5FC5\u987B\u8981\u6709\u4E00\u4E2Ahover\u540E\u6539\u53D8\u80CC\u666F\u8272\u7684\u53CD\u9988\u6548\u679C\uFF0C\u4E0D\u80FD\u4F7F\u7528transform\u6548\u679C\uFF0C\u53EA\u80FD\u4F7F\u7528\u80CC\u666F\u8272\u6548\u679C\u3002\n- css\u6837\u5F0F\u91CC\u9762\u7684`background-image`\u5C5E\u6027\u7684\u503C\u5FC5\u987B\u662F\u8FDC\u7A0B\u56FE\u7247\uFF0C\u4E0D\u80FD\u8BBE\u7F6E\u4E0D\u662F\u8FDC\u7A0B\u56FE\u7247\u7684\u4EFB\u4F55\u503C\uFF0C\u6BD4\u5982\u4E0D\u80FD\u8BBE\u7F6E'base64'\u3001\u6E10\u53D8'radial-gradient'\u7B49\u3002\n\n## \u4E8C\u3001\u5FC5\u987B\u7ED9\u6BCF\u4E00\u4E2A\u8282\u70B9\u6DFB\u52A0id\u3001name\u3001nodeType\u5C5E\u6027\n- \u7279\u522B\u6CE8\u610F\uFF0C`i`\u548C`div`\u7B49\u6807\u7B7E\u4E5F\u5FC5\u987B\u6DFB\u52A0 id\u3001name\u3001nodeType \u5C5E\u6027\uFF0C\u6BCF\u4E00\u4E2A\u8282\u70B9\u90FD\u9700\u8981\u6DFB\u52A0\u8FD9\u4E09\u4E2A\u5C5E\u6027\uFF0C\u5343\u4E07\u522B\u6F0F\u6389\u4E86\uFF0C\u8FD9\u662F\u5FC5\u8981\u6761\u4EF6\n- id \u5C5E\u6027\u5FC5\u987B\u53EA\u80FD\u4F7F\u7528\u82F1\u6587\u6216\u6570\u5B57\u7EC4\u6210\uFF0C\u4E14\u4E0D\u80FD\u4EE5\u6570\u5B57\u5F00\u5934\uFF0C\u5E76\u4E14\u6574\u4E2A\u9875\u9762 id \u5C5E\u6027\u7684\u503C\u5FC5\u987B\u552F\u4E00\uFF0C\u4F7F\u7528\u9A7C\u5CF0\u7684\u547D\u540D\u65B9\u5F0F\n- name \u5C5E\u6027\u5FC5\u987B\u662F\u4E2D\u6587\u6216\u6570\u5B57\uFF0C\u5E76\u4E14\u4E0D\u80FD\u5305\u542B\u7279\u6B8A\u5B57\u7B26\n- \u5982\u679C\u662F\u901A\u8FC7\u70B9\u51FBitem\u9879\u5207\u6362\u5C55\u793A\u5185\u5BB9\u7684\uFF0C\u90A3\u4E48item\u9879\u7684nodeType\u5FC5\u987B\u662F`tabMenuBarItem`\uFF0Ctab panel\u7684nodeType\u5FC5\u987B\u662F`tabPanel`\uFF0C`tabMenuBarItem`\u7684\u7236\u4EB2\u5BB9\u5668\u662F`tabMenuBar`\uFF0C\u4E0D\u5F97\u4F7F\u7528`horizontalListView`\u6765\u4EE3\u66FF`tabMenuBar`\n- \u9875\u9762\u7684header\u6807\u9898\u680FnodeType\u5FC5\u987B\u662F`titleBar`\u6216\u8005`topNavigateBar`\uFF0C\u800C\u4E0D\u662F`container`\n- nodeType \u5C5E\u6027\u7684\u503C\u5FC5\u987B\u662F`\u7EC4\u4EF6\u7C7B\u578B\u679A\u4E3E (nodeType)\u679A\u4E3E` \u4E2D\u7684\u4E00\u4E2A\uFF0C\u4E00\u4E9B\u5E03\u5C40\u5BB9\u5668\u9700\u8981\u9075\u5B88\u4EE5\u4E0B\u8BF4\u660E\u6765\u9009\u62E9\u6B63\u786E\u7684nodeType\uFF1A\n - \u5F00\u5173\u7EC4\u4EF6\uFF1A`switch`\uFF0C\u7528\u4E8E\u4E24\u4E2A\u72B6\u6001\u5207\u6362\u7684\u573A\u666F\uFF0C\u6BD4\u5982\uFF1A\u6253\u5F00/\u5173\u95ED\u3001\u663E\u793A/\u9690\u85CF\u3001\u540C\u610F/\u62D2\u7EDD\u7B49\u7B49\uFF0C\u5177\u4F53\u573A\u666F\u6BD4\u5982\uFF1A\u8BBE\u7F6E\u4E2D\u7684\u5F00\u5173\u529F\u80FD\u3001\u540C\u610F/\u62D2\u7EDD\u534F\u8BAE\u3001\u5BC6\u7801\u663E\u793A\u4E0E\u9690\u85CF\u56FE\u6807\u5F00\u5173\u7B49\uFF0C\u6BD4\u5982\uFF1A\n ``` html\n <div\n id=\"passwordShowHideCheckbox\"\n name=\"\u5BC6\u7801\u663E\u793A\u9690\u85CF\u5207\u6362\u5F00\u5173\"\n nodeType=\"switch\"\n class=\"password-show-hide-checkbox\"\n onclick=\"togglePasswordShowHide()\"\n >\n <i\n id=\"passwordShowHideIcon\"\n name=\"\u5BC6\u7801\u663E\u793A\u9690\u85CF\u5207\u6362\u56FE\u6807\"\n nodeType=\"icon\"\n class=\"far fa-eye\"\n checkedClass=\"far fa-eye-slash\"\n ></i>\n </div>\n ```\n - \u8131\u79BB\u6587\u6863\u6D41\u7684\u5F39\u7A97/Toast\u7A97\u53E3\u5BB9\u5668\uFF1A`dialogOverlay`\u3001`dialog`\u3001`toast`\uFF0C\u7528\u4E8E\u5C55\u793A\u5F39\u7A97/Toast\u7C7B\u522B\u7684loading\uFF0C\u4E0D\u5F97\u4F7F\u7528`oneStateContentContainer`\uFF0C\u5E94\u8BE5Toast\u7C7B\u522B\u4F7F\u7528`toast`\uFF0C\u5F39\u7A97\u7C7B\u522B\u4F7F\u7528`dialogOverlay`\u5305\u542B1\u4E2A`dialog`\uFF0C`dialog`\u662F\u5BF9\u8BDD\u6846\u7684\u5185\u5BB9\u5BB9\u5668\uFF0C\u4E00\u822C\u5C4F\u5E55\u5C45\u4E2D\u663E\u793A\u3002\n - \u5217\u8868\u5BB9\u5668\uFF1A`verticalListView`\u3001`horizontalListView`\u3001`listItemCard`\uFF0C\u7528\u4E8E\u5E03\u5C40\u591A\u4E2A\u5217\u8868\u9879\uFF0C\u6BD4\u5982\uFF1A\u5546\u54C1\u5217\u8868\u3001\u5206\u7C7B\u5217\u8868\u3001\u6807\u7B7E\u5217\u8868\u7B49\uFF0C\u53EF\u4EE5\u652F\u6301\u591A\u884C\u591A\u5217\u7684\u5217\u8868\u5E03\u5C40\n - \u5217\u8868\u9875\u811A\u5BB9\u5668\uFF1A`listFooterContainer`\uFF0C\u7528\u4E8E\u5E03\u5C40\u5217\u8868\u7684\u9875\u811A\uFF0C\u6BD4\u5982\uFF1A\u52A0\u8F7D\u66F4\u591A\u3001\u6CA1\u6709\u66F4\u591A\u4E86\u7B49\n - tab\u9009\u9879\u5361\uFF1A`tabPanelFather`\u4E0E`tabMenuBar`\u7EC4\u5408\u5B9E\u73B0tab\u9009\u9879\u5361\uFF0C\u6CE8\u610FtabMenuBar\u652F\u6301\u6A2A\u5411\u548C\u7AD6\u5411\u7684tab\u9009\u9879\u5361\uFF0C\u6BD4\u5982\u5206\u7C7B\u7AD6\u5411\u7684tab\u9009\u9879\u5361\u83DC\u5355\u680F\uFF0C\u4E00\u822C\u5206\u7C7B\u90FD\u4F7F\u7528tab\u9009\u9879\u5361\u6765\u5B9E\u73B0\uFF0C\u7981\u6B62\u4F7F\u7528`verticalListView`\u548C`horizontalListView`\u5217\u8868\u6765\u4EE3\u66FFtab\u9009\u9879\u5361\u3002\n - \u7F51\u683C\u5BB9\u5668\uFF1AgridContainer\u7528\u4E8E\u5E03\u5C40\u591A\u4E2A\u7F51\u683C\u9879\uFF0C\u91CC\u9762\u5305\u542BN\u4E2AgridItem\uFF0C\u6BD4\u5982\uFF1A\u5206\u7C7B\u7F51\u683C\u5165\u53E3\n - \u6D41\u5F0F\u5BB9\u5668\uFF1A\u7528\u4E8E\u5E03\u5C40\u591A\u4E2A\u5B50\u9879\uFF0C\u5B50\u9879\u53EF\u4EE5\u5728\u4E00\u884C\u663E\u793A\uFF0C\u5F53\u4F4D\u7F6E\u4E0D\u591F\u65F6\u5C31\u6362\u884C\u663E\u793A\uFF0C\u6BD4\u5982\uFF1A\u4E00\u7EC4\u6807\u7B7Etag\u7684\u6392\u7248\u5E03\u5C40\n - \u591A\u72B6\u6001\u5BB9\u5668\uFF1A`multiStateContainer`, `oneStateContentContainer`\uFF0C\u7528\u4E8E\u4E0D\u662F\u901A\u8FC7\u4EA4\u4E92\uFF0C\u800C\u662F\u901A\u8FC7\u903B\u8F91\u72B6\u6001\u53D8\u91CF\u53D8\u5316\u800C\u663E\u793A\u4E0D\u540C\u72B6\u6001\u7684\u5185\u5BB9\u5BB9\u5668\uFF0C\u6BD4\u5982\uFF1A\u767B\u5F55\u72B6\u6001\u548C\u672A\u767B\u5F55\u72B6\u6001\u5206\u522B\u663E\u793A\u4E0D\u540C\u7684\u5185\u5BB9\u3001\u52A0\u8F7D\u4E2D/\u52A0\u8F7D\u5931\u8D25/\u52A0\u8F7D\u6210\u529F\u6709\u6570\u636E/\u6CA1\u6709\u6570\u636E\u7B49\u72B6\u6001\u5207\u6362\u3001\u4E0D\u540C\u6743\u9650/\u7B49\u7EA7/\u65F6\u671F\u7B49\u7B49\u663E\u793A\u4E0D\u540C\u7684\u529F\u80FD\uFF0C\u7B49\u7B49\u8FD9\u4E9B\u901A\u8FC7\u903B\u8F91\u72B6\u6001\u53D8\u91CF\u53D8\u5316\u800C\u663E\u793A\u4E0D\u540C\u72B6\u6001\u7684\u5185\u5BB9\u5BB9\u5668\uFF0C\u90FD\u5FC5\u987B\u4F7F\u7528`multiStateContainer`\u548C`oneStateContentContainer`\u6765\u5B9E\u73B0\uFF0C\u7279\u522B\u6CE8\u610F\u8131\u79BB\u6587\u6863\u6D41\u7684\u5F39\u7A97/Toast\u7A97\u53E3\u5BB9\u5668\u7C7B\u522B\u7684loading\uFF0C\u4E0D\u5F97\u4F7F\u7528`oneStateContentContainer`\uFF0C\u5E94\u8BE5\u4F7F\u7528`dialogOverlay/dialog`\u6216\u8005`toast`\u3002\n- \u9AD8\u7EA7\u7EC4\u4EF6\u8282\u70B9\u7684nodeType\u7ED3\u6784\u89C4\u5219\uFF1A\n - \u5BF9\u8BDD\u6846\uFF1A`dialogOverlay`\u662F\u5F39\u7A97/Toast\u7A97\u53E3\u5BB9\u5668\u7684\u906E\u7F69\u5C42\uFF0C`dialog`\u662F\u5BF9\u8BDD\u6846\u7684\u5185\u5BB9\u5BB9\u5668\uFF0C`dialogOverlay`\u5305\u542B\u4E00\u4E2A`dialog`\uFF0C`dialog`\u4E00\u822C\u5C4F\u5E55\u5C45\u4E2D\u663E\u793A\n - tab \u9009\u9879\u5361\uFF1A`tabMenuBar`\u662Ftab\u9009\u9879\u5361\u83DC\u5355\u680F\uFF0C\u91CC\u9762\u5305\u542BN\u4E2A`tabMenuBarItem`\uFF0C`tabPanelFather`\u662Ftab\u9009\u9879\u5361\u5185\u5BB9\u5BB9\u5668\uFF0C\u91CC\u9762\u5305\u542BN\u4E2A`tabPanel`\uFF0C`tabMenuBar`\u548C`tabPanelFather`\u5FC5\u987B\u540C\u65F6\u5B58\u5728\uFF0C`tabPanel`\u7684\u6570\u91CF\u5FC5\u987B\u548C`tabMenuBarItem`\u7684\u6570\u91CF\u76F8\u540C\uFF0C\u6CE8\u610FtabMenuBar\u652F\u6301\u6A2A\u5411\u548C\u7AD6\u5411\u7684tab\u9009\u9879\u5361\uFF0C\u6BD4\u5982\u5206\u7C7B\u7AD6\u5411\u7684tab\u9009\u9879\u5361\u83DC\u5355\u680F\uFF0C\u4E00\u822C\u5206\u7C7B\u90FD\u4F7F\u7528tab\u9009\u9879\u5361\u6765\u5B9E\u73B0\uFF0C\u7981\u6B62\u4F7F\u7528`verticalListView`\u548C`horizontalListView`\u5217\u8868\u6765\u4EE3\u66FFtab\u9009\u9879\u5361\u3002\n - viewPager \u8F6E\u64AD\uFF1A`viewPager`\u662F\u8F6E\u64AD\u5BB9\u5668\uFF0C\u91CC\u9762\u5305\u542BN\u4E2A`viewPagerItem`\uFF0C`viewPagerIndicatorContainer`\u662F\u8F6E\u64AD\u6307\u793A\u5668\u5BB9\u5668\uFF0C`viewPager`\u4E0E`viewPagerIndicatorContainer`\u5FC5\u987B\u540C\u65F6\u5B58\u5728\n - \u4E00\u884C\u4E0D\u591F\u4F4D\u7F6E\u663E\u793A\u5C31\u6362\u884C\u7684\u5BB9\u5668\uFF1A`inlineBlockAndWrap`\uFF0C\u91CC\u9762\u5305\u542BN\u4E2A`blockItem`\uFF0C`blockItem`\u662F\u5B83\u7684\u5B50\u9879\n - \u591A\u72B6\u6001\u5BB9\u5668\uFF1A\u4E00\u4E2A`multiStateContainer`\u591A\u72B6\u6001\u5BB9\u5668\u5305\u542B\u591A\u4E2A`oneStateContentContainer`\n\n- \u7EC4\u4EF6\u7C7B\u578B\u679A\u4E3E (nodeType)\u679A\u4E3E\uFF1A\n\n - \u5F62\u72B6\uFF1A`rect`, `circle`, `line`\n - \u57FA\u7840\u7EC4\u4EF6\uFF1A`text`\u3001`button`\u3001`input`\u3001`icon`\u3001`image`\n - \u57FA\u7840\u5BB9\u5668\uFF1A`container`\n - \u7F51\u683C\u5BB9\u5668\uFF1A`gridContainer`\u3001`gridItem`\n - \u6D41\u5F0F\u5BB9\u5668\uFF1A`inlineBlockAndWrap`\u3001`blockItem`\n - \u5F00\u5173\uFF1A`switch`\n - \u5355\u9009\uFF1A`radioGroup`\u3001`radio`\n - \u591A\u9009\uFF1A`checkBoxGroup`\u3001`checkBox`\n - \u9876\u90E8\u5BFC\u822A\u680F\uFF1A`titleBar`\u3001`topNavigateBar`\n - \u5E95\u90E8\u64CD\u4F5C\u680F\uFF1A`bottomOperateBar`\n - \u591A\u72B6\u6001\u5BB9\u5668\uFF1A`multiStateContainer`, `oneStateContentContainer`\n - \u5217\u8868\uFF1A`verticalListView`, `horizontalListView`, `listItemCard`\u3001`listFooterContainer`\n - \u8F6E\u64AD\uFF1A`viewPager`, `viewPagerItem`, `viewPagerIndicatorContainer`\n - tab \u9009\u9879\u5361\uFF1A`tabPanelFather`, `tabPanel`, `tabMenuBar`, `tabMenuBarItem`\n - \u5E95\u90E8\u5BFC\u822A: `bottomTabContentContainer`, `subPage`, `bottomTabNavigateBar`, `bottomTabNavigateBarItem`\n - \u5BF9\u8BDD\u6846\uFF1A`dialogOverlay`, `dialogContent`\n - toast \u63D0\u793A\uFF1A`toast`\n - \u4E0B\u62C9\u83DC\u5355\uFF1A`dropDownMenu`\n - \u4FA7\u6ED1\u9762\u677F\uFF1A`sideSlidePanel`\n - \u624B\u673A\u786C\u4EF6\u5143\u7D20\uFF1A`phoneTopStatusBar`\u3001`phoneBottomIndicatorBar`\uFF0C\u8FD9\u4E24\u4E2A\u5143\u7D20\u662F\u624B\u673A\u786C\u4EF6\u81EA\u5E26\u7684\u5143\u7D20\uFF0C\u4E0D\u80FD\u5728\u9875\u9762\u4E2D\u6DFB\u52A0\u3002\n\n## \u4E09\u3001\u8F6E\u64AD\u4E0ETabs\u7EC4\u4EF6\u7684\u89C4\u5219\n- \u8F6E\u64AD\u7684\u6BCF\u4E00\u4E2ASlide\u548CTabs\u9009\u9879\u5361\u7EC4\u4EF6\u6BCF\u4E00\u4E2ATab Panel\u90FD\u5FC5\u987B\u4F7F\u7528`display: none`\u548C`display: block/flex`\u6765\u5B9E\u73B0\u9690\u85CF\u548C\u663E\u793A\u7684\u4E92\u65A5\u5207\u6362\n- \u8F6E\u64AD\u7684\u6BCF\u4E00\u4E2ASlide\u5FC5\u987B\u6709html\u4EE3\u7801\u5B9E\u73B0\uFF0C\u4E0D\u5F97\u53EA\u5199\u7B2C1\u4E2ASlide\u7684\u5177\u4F53\u5185\u5BB9\u7684html\u4EE3\u7801\uFF0C\u5176\u4ED6Slide\u7684\u5177\u4F53\u5185\u5BB9\u7684html\u4EE3\u7801\u4E5F\u5FC5\u987B\u8981\u5199\uFF0C\u7EDD\u5BF9\u7981\u6B62\u6577\u884D\u5730\u4F7F\u7528`Placeholder content/\u5F85\u5F00\u53D1/\u5F00\u53D1\u4E2D/\u5373\u5C06\u4E0A\u7EBF`\u7B49\u7B49\u6765\u6577\u884D\u5730\u5C55\u793A\u8F6E\u64AD\u7684\u6BCF\u4E00\u4E2ASlide\uFF0C\u5FC5\u987B\u6BCF\u4E00\u4E2ASlide\u90FD\u6709\u5177\u4F53\u771F\u5B9E\u7684\u5185\u5BB9\u5C55\u793A\u5B9E\u73B0\u3002\n- Tabs\u9009\u9879\u5361\u7EC4\u4EF6\u9700\u8981\u6DFB\u52A0\u70B9\u51FB\u5207\u6362Tab Panel\u7684\u529F\u80FD\uFF0C\u4E0D\u5F97\u53EA\u5199\u7B2C1\u4E2ATab Panel\u7684html\u4EE3\u7801\uFF0C\u5176\u4ED6Tab Panel\u7684\u5177\u4F53\u5185\u5BB9\u7684html\u4EE3\u7801\u4E5F\u5FC5\u987B\u8981\u5199\uFF0C\u7EDD\u5BF9\u7981\u6B62\u6577\u884D\u5730\u4F7F\u7528`Placeholder content/\u5F85\u5F00\u53D1/\u5F00\u53D1\u4E2D/\u5373\u5C06\u4E0A\u7EBF`\u7B49\u7B49\u6765\u6577\u884D\u5730\u5C55\u793ATabs\u9009\u9879\u5361\u7EC4\u4EF6\u7684\u6BCF\u4E00\u4E2ATab Panel\uFF0C\u5FC5\u987B\u6BCF\u4E00\u4E2ATab Panel\u90FD\u6709\u5177\u4F53\u771F\u5B9E\u7684\u5185\u5BB9\u5C55\u793A\u5B9E\u73B0\u3002\n- \u4F8B\u5B50\uFF1A\n```html\n<tabPanelFather nodeType=\"tabPanelFather\" id=\"tabPanelFather\" name=\"Tabs\u9009\u9879\u5361\u5185\u5BB9\u5BB9\u5668\">\n <!-- Tab Panel 1 -->\n <tabPanel nodeType=\"tabPanel\" id=\"tabPanel1\" name=\"Tabs\u9009\u9879\u53611\">\n <text nodeType=\"text\" id=\"tabPanel1Text\" name=\"Tabs\u9009\u9879\u53611\u7684\u6587\u672C\">Tabs\u9009\u9879\u53611\u7684\u5185\u5BB9</text>\n ...\n <div nodeType=\"div\" id=\"tabPanel1Div\" name=\"Tabs\u9009\u9879\u53611\u7684div\u5BB9\u5668\">\n ...\n </div>\n </tabPanel>\n <!-- Tab Panel 2 -->\n <tabPanel nodeType=\"tabPanel\" id=\"tabPanel2\" name=\"Tabs\u9009\u9879\u53612\">\n <text nodeType=\"text\" id=\"tabPanel2Text\" name=\"Tabs\u9009\u9879\u53612\u7684\u6587\u672C\">Tabs\u9009\u9879\u53612\u7684\u5185\u5BB9</text>\n ...\n <div nodeType=\"div\" id=\"tabPanel2Div\" name=\"Tabs\u9009\u9879\u53612\u7684div\u5BB9\u5668\">\n ...\n </div>\n </tabPanel>\n <!-- \u66F4\u591ATab Panel\u548C\u5177\u4F53\u5185\u5BB9... -->\n</tabPanelFather>\n```\n\n## \u56DB\u3001\u5217\u8868\u7EC4\u4EF6\u89C4\u5219\n- \u5982\u679C\u8BE5\u5217\u8868\u7684\u6570\u636E\u662F\u4ECE\u7F51\u7EDC\u63A5\u53E3\u62C9\u53D6\u7684\uFF0C\u90A3\u4E48\u5FC5\u987B\u4F7F\u7528\u591A\u72B6\u6001\u5BB9\u5668`multiStateContainer`\u5C06loading\u3001\u8054\u7F51\u5931\u8D25\u3001\u6CA1\u6709\u6570\u636E\u3001\u6709\u6570\u636E\u7684\u56DB\u4E2A\u72B6\u6001\u4F7F\u7528`oneStateContentContainer`\u5305\u8D77\u6765\u5E76\u5C55\u793A\u51FA\u6765\uFF0C\u5176\u4E2D\u6709\u6570\u636E\u72B6\u6001\u7684`oneStateContentContainer`\u5305\u542B\u7684\u5C31\u662F\u8BE5\u5217\u8868\u7EC4\u4EF6\u3002\n- \u5982\u679C\u5217\u8868\u6570\u636E\u53EA\u662F\u7F51\u7EDC\u805A\u5408\u4E1A\u52A1\u63A5\u53E3\u7684\u4E00\u90E8\u5206\uFF0C\u90A3\u4E48\u8BE5\u5217\u8868\u4E0D\u9700\u8981loading\u548C\u8054\u7F51\u5931\u8D25\u72B6\u6001\uFF0C\u53EA\u9700\u8981\u6709\u6570\u636E\u72B6\u6001\u548C\u6CA1\u6709\u6570\u636E\u72B6\u6001\uFF0C\u6BD4\u5982\u9996\u9875\u7684\u63A8\u8350\u5217\u8868\u3001\u5206\u7C7B\u5217\u8868\u3001\u6700\u65B0\u52A8\u6001\u5217\u8868\u7B49\u8FD9\u4E9B\u662F\u9996\u9875\u4E1A\u52A1\u805A\u5408\u63A5\u53E3\u83B7\u53D6\u7684\uFF0C\u8FD9\u4E9B\u5217\u8868\u6570\u636E\u53EA\u662F\u4E1A\u52A1\u63A5\u53E3\u7684\u4E00\u90E8\u5206\uFF0C\u4E0D\u662F\u72EC\u7ACB\u7684\u63A5\u53E3\uFF0C\u6240\u4EE5\u4E0D\u9700\u8981loading\u548C\u8054\u7F51\u5931\u8D25\u72B6\u6001\u3002\n- \u4F8B\u5B50\uFF1A\n```html\n<multiStateContainer nodeType=\"multiStateContainer\" id=\"listMultiStateContainer\" name=\"\u5217\u8868\u591A\u72B6\u6001\u5BB9\u5668\">\n<!-- \u6709\u6570\u636E\u72B6\u6001\u7684oneStateContentContainer -->\n <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"hasDataStateContainer\" name=\"\u6709\u6570\u636E\u72B6\u6001\u7684\u5BB9\u5668\">\n <!-- \u5217\u8868\u7EC4\u4EF6 -->\n <verticalListView nodeType=\"verticalListView\" id=\"listView\" fromApiOrCacheData=\"true\" name=\"\u5217\u8868\u7EC4\u4EF6\">\n <!-- \u5217\u8868\u9879 -->\n <listItemCard nodeType=\"listItemCard\" id=\"listItem1\" name=\"\u5217\u8868\u98791\">\n <!-- \u5217\u8868\u9879\u5185\u5BB9 -->\n <text nodeType=\"text\" id=\"listItem1Text\" name=\"\u5217\u8868\u98791\u7684\u6587\u672C\">\u5217\u8868\u98791</text>\n </listItemCard>\n <!-- \u66F4\u591A\u5217\u8868\u9879... -->\n </verticalListView>\n </oneStateContentContainer>\n <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"noDataStateContainer\" name=\"\u6CA1\u6709\u6570\u636E\u72B6\u6001\u7684\u5BB9\u5668\">\n <!-- \u6CA1\u6709\u6570\u636E\u72B6\u6001\u7684\u63D0\u793A -->\n </oneStateContentContainer>\n <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"loadingStateContainer\" name=\"loading\u72B6\u6001\u7684\u5BB9\u5668\">\n <!-- loading\u72B6\u6001\u7684\u63D0\u793A -->\n </oneStateContentContainer>\n <oneStateContentContainer nodeType=\"oneStateContentContainer\" id=\"networkErrorStateContainer\" name=\"\u8054\u7F51\u5931\u8D25\u72B6\u6001\u7684\u5BB9\u5668\">\n <!-- \u8054\u7F51\u5931\u8D25\u72B6\u6001\u7684\u63D0\u793A -->\n </oneStateContentContainer>\n</multiStateContainer>\n```\n\n## \u4E94\u3001\u56FE\u6807\u4E0E\u56FE\u7247\u7684\u89C4\u5219\n- \u5F53\u9700\u8981icon\u56FE\u6807\u65F6\u5FC5\u987B\u4F7F\u7528FontAwesome\u56FE\u6807\uFF0C\u6BD4\u5982\uFF1A`<i name=\"\u5FAE\u4FE1Icon\" vtype=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>`\uFF0C\u5E76\u4E14\u6CE8\u610F\u56FE\u6807\u7684\u989C\u8272\uFF0C\u6BD4\u5982\u5FAE\u4FE1\u56FE\u6807\u4E00\u822C\u4F7F\u7528\u7EFF\u8272\u7CFB\uFF0CQQ\u56FE\u6807\u4E00\u822C\u4F7F\u7528\u84DD\u8272\u7CFB\uFF0C\u5FAE\u535A\u56FE\u6807\u4E00\u822C\u4F7F\u7528\u7EA2\u8272\u7CFB\uFF0C\u652F\u4ED8\u5B9D\u56FE\u6807\u4E00\u822C\u4F7F\u7528\u6D45\u84DD\u8272\u7CFB\u7B49\u7B49\n- \u7EDD\u5BF9\u4E0D\u80FD\u4F7F\u7528 emoji \u8868\u60C5\u7B26\u53F7\uFF0C\u4E0D\u5F97\u4F7F\u7528\u4EFB\u4F55 emoji \u8868\u60C5\u7B26\u53F7\uFF0C\u8BF7\u4F7F\u7528FontAwesome\u5B57\u4F53\u56FE\u6807\u6765\u4EE3\u66FF\u3002\n- LOGO\u56FE\u7247\u548C\u5F15\u5BFC\u9875\u7684\u5F15\u5BFC\u56FE\u7247\u5FC5\u987B\u4F7F\u7528`doc/res/svgMap.json`\u6587\u4EF6\u4E2Djson\u5BF9\u8C61\u6B63\u786E\u5B57\u6BB5\u7684https\u94FE\u63A5\u503C\uFF0C\u7981\u6B62\u4F7F\u7528\u672C\u5730\u56FE\u7247\u8DEF\u5F84`doc/res/logo.svg`\u6587\u4EF6\uFF0C\u800C\u662F\u4F7F\u7528\u7C7B\u4F3C\uFF1A`https://editor.bytefungo.com/dfile/img/xxxxx.svg`\u8FD9\u6837\u7684\u56FE\u7247\u94FE\u63A5\u5730\u5740\uFF0C\u6BD4\u5982\u95EA\u5C4F\u9875\u3001\u767B\u5F55\u9875\u3001\u6CE8\u518C\u9875\u7528\u5230\u7684LOGO\u56FE\u7247\uFF0C\u5F15\u5BFC\u9875\u7684\u5F15\u5BFC\u56FE\u7247\u7B49\u3002\n- jpg\u3001jpeg\u7C7B\u578B\u56FE\u7247\u5FC5\u987B\u4F7F\u7528\u56FE\u7247\u5730\u5740\uFF1A`https://oss.bytefungo.com/f1/showImg1.jpg`)\uFF0C\u5176\u4E2D\u7ED3\u5C3E\u7684\u2019showImg1'\u53EF\u4EE5\u6362\u4E3A\u4ECE 1 \u5230 30 \u7684\u6570\u5B57\uFF0C1~30 \u7684\u6570\u5B57\u5FC5\u987B\u968F\u673A\u6311\u9009\uFF0C\u4E0D\u5F97\u6BCF\u4E2A\u9875\u9762\u6BCF\u4E2A\u56FE\u7247\u90FD\u4F7F\u7528\u540C\u4E00\u4E2A\u6570\u5B57\u3002\u5199\u6CD5\u6BD4\u5982\uFF1A`<img src=\"https://oss.bytefungo.com/f1/showImg17.jpg\" alt=\"xxx\" class=\"xxx\" nodeType=\"image\">`\n\n## \u516D\u3001\u5FC5\u987B\u7406\u89E3\u5E76\u9075\u5B88\u4EE5\u4E0B\u7981\u6B62\u7684\u591A\u4E2AUI\u8BBE\u8BA1\u4EE3\u7801\u5199\u6CD5\n- \u7981\u6B62\u4F7F\u7528\u4EFB\u4F55\u524D\u7AEF\u6846\u67B6\uFF0C\u53EA\u4F7F\u7528 html+\u7C7B\u9009\u62E9\u5668\u6837\u5F0F+js \u6765\u5B9E\u73B0\u3002\n- \u7981\u6B62\u4F7F\u7528js\u4EE3\u7801\u6765\u62FC\u63A5html\u5B57\u7B26\u4E32\uFF0C\u5FC5\u987B\u5728body\u6807\u7B7E\u91CC\u9762\u76F4\u63A5\u5199html\u4EE3\u7801\u3002\n- \u7981\u6B62\u4F7F\u7528js\u4EE3\u7801\u6765\u58F0\u660E\u4EFB\u4F55\u9875\u9762\u663E\u793A\u6240\u9700\u7684\u6570\u636E\uFF0C\u6240\u6709\u6570\u636E\u90FD\u5FC5\u987B\u5728html\u4EE3\u7801\u4E2D\u76F4\u63A5\u5199\u6B7B\u3002\n- \u7981\u6B62\u4F7F\u7528\u6587\u672C\u6E10\u53D8\u8272\uFF0C\u5FC5\u987B\u4F7F\u7528\u7EAF\u8272\u6587\u672C\uFF0C\u4E5F\u5C31\u662F\u7981\u6B62\u4F7F\u7528`-webkit-text-fill-color`\u5C5E\u6027\u3002\n- \u7981\u6B62\u7ED9\u9875\u9762\u6DFB\u52A0`\u624B\u673A\u9876\u90E8\u72B6\u6001\u680F`\u3001`\u624B\u673A\u5E95\u90E8\u6307\u793A\u5668\u680F`\u4E24\u4E2A\u975E\u9875\u9762\u5185\u5BB9\u7684\u5143\u7D20\u8282\u70B9\uFF0C\u8FD9\u662F\u624B\u673A\u786C\u4EF6\u81EA\u5E26\u7684\u5143\u7D20\uFF0C\u4E0D\u80FD\u5728\u9875\u9762\u4E2D\u6DFB\u52A0\u3002\n- \u7981\u6B62\u4F7F\u7528`:before`\u3001`:after`\u4F2A\u5143\u7D20\uFF0C\u5FC5\u987B\u4F7F\u7528\u5176\u4ED6\u6807\u7B7E\u6765\u5B9E\u73B0\u3002\n- \u7981\u6B62\u4F7F\u7528`backdrop-filter`\u7B49\u73BB\u7483\u6548\u679C\uFF0C\u5FC5\u987B\u5220\u9664\u6389\u6240\u6709\u4F7F\u7528\u5230\u73BB\u7483\u6548\u679C\u7684\u4EE3\u7801\u3002\n- \u7981\u6B62\u4F7F\u7528\u591A\u4E2Ap\u6807\u7B7E\u6216\u591A\u4E2A\u5176\u4ED6\u6807\u7B7E\u6765\u663E\u793A\u4E00\u4E2A\u4ECE\u7F51\u7EDC\u6216\u5176\u4ED6\u5730\u65B9\u62C9\u53D6\u56DE\u6765\u7684\u957F\u6587\u672C\uFF0C\u5FC5\u987B\u53EA\u80FD\u4F7F\u7528\u4E00\u4E2A\u6807\u7B7E\u6765\u663E\u793A\uFF0C\u6BD4\u5982\uFF1Adiv\u3001span\u7B49\uFF0C\u56E0\u4E3A\u7F51\u7EDC\u62C9\u53D6\u56DE\u6765\u7684\u957F\u6587\u672C\u662F\u4E00\u4E2A\u6587\u672C\uFF0C\u65E0\u6CD5\u4F7F\u7528\u591A\u4E2A\u6807\u7B7E\u6765\u663E\u793A\u4E00\u4E2A\u6587\u672C\uFF0C\u5FC5\u987B\u53EA\u80FD\u4F7F\u7528\u4E00\u4E2A\u6807\u7B7E\u6765\u663E\u793A\u3002\n- loading\u8282\u70B9\u7684\u5B9E\u73B0\u7981\u6B62\u4F7F\u7528div\u6807\u7B7E\u4E0E\u8FB9\u6846\u5C5E\u6027\u5B9E\u73B0\uFF0C\u5FC5\u987B\u4F7F\u7528\u56FE\u6807icon\u7684i\u6807\u7B7E\u6765\u5B9E\u73B0loading\u7684\u8282\u70B9\n- \u7981\u6B62\u4E3Ahtml\u6807\u7B7E\u8282\u70B9\u6DFB\u52A0\u52A8\u753B\u6216\u8FC7\u6E21\u6548\u679C\uFF0C\u9875\u9762\u8BBE\u8BA1\u4E0D\u9700\u8981\u4EFB\u4F55\u52A8\u753B\u548C\u8FC7\u6E21\u6548\u679C\uFF0C\u6BD4\u5982\u7981\u6B62\uFF1A@keyframes\u3001transition\u3001animation \u7B49\u3002\n- \u6309\u94AE\u3001\u5361\u7247\u3001item\u9879\u7B49\u5143\u7D20\u5FC5\u987B\u8981\u6709hover\u4E0E\u70B9\u51FB\u53CD\u9988\uFF0C\u70B9\u51FB\u53CD\u9988\u5FC5\u987B\u4F7F\u7528\u6D45\u8272\u7684\u80CC\u666F\u8272background\u6765\u53CD\u9988\u5C31\u884C\uFF0C\u4E25\u7981\u4F7F\u7528transform\u6548\u679C\n - \u274C \u9519\u8BEF\u7684\u7528\u6CD5\uFF1A \n ``` css\n .hot-sales-item:hover {\n transform: translateX(...px);\n }\n ```\n - \u2705 \u6B63\u786E\u7684\u7528\u6CD5\uFF1A\n ``` css\n .hot-sales-item:hover {\n background: ...;\n }\n ```\n- \u7981\u6B62\u4F7F\u7528div\u6807\u7B7E\u6765\u5B9E\u73B0image\u56FE\u7247\uFF0C\u5FC5\u987B\u8981\u4F7F\u7528img\u6807\u7B7E\u6765\u5B9E\u73B0\u56FE\u7247\u8282\u70B9\uFF0Cimg\u6807\u7B7E\u7684src\u5C5E\u6027\u5FC5\u987B\u8BBE\u7F6E\u4E3A\uFF1A`https://oss.bytefungo.com/f1/showImg1.jpg`\uFF0C\u5176\u4E2D\u91CC\u9762\u7684`showImg1`\u53EF\u4EE5\u6539\u4E3A1~30\u7684\u4EFB\u610F\u4E00\u4E2A\u6570\u5B57\uFF0C\u6BD4\u5982\uFF1A`showImg5`\u3002\n - \u274C\u9519\u8BEF\u7684\u5199\u6CD5\uFF1A\n ``` html\n <div class=\"bestseller-cover\" id=\"bestsellerCover1\" name=\"\u7545\u9500\u4E66\u7C4D\u5C01\u97621\" nodeType=\"image\">\n </div>\n ```\n - \u2705 \u6B63\u786E\u7684\u5199\u6CD5\uFF1A\n ``` html\n <img class=\"bestseller-cover\" id=\"bestsellerCover1\" name=\"\u7545\u9500\u4E66\u7C4D\u5C01\u97621\" nodeType=\"image\" src=\"https://oss.bytefungo.com/f1/showImg7.jpg\"> \n ```\n- \u7981\u6B62 id \u5C5E\u6027\u4E0D\u89C4\u8303\uFF0Cid \u5FC5\u987B\u552F\u4E00\uFF0C\u4E14\u53EA\u80FD\u7531\u5B57\u6BCD\u548C\u6570\u5B57\u7EC4\u6210\uFF08\u4E0D\u80FD\u4EE5\u6570\u5B57\u5F00\u5934\uFF09\uFF0C\u5EFA\u8BAE\u4F7F\u7528\u9A7C\u5CF0\u547D\u540D\u3002\n- \u7981\u6B62\u4F7F\u7528\u884C\u5185 style \u5C5E\u6027\uFF0C\u5FC5\u987B\u901A\u8FC7 class \u548C CSS \u6587\u4EF6\u6765\u5B9A\u4E49\u6837\u5F0F\u3002\n- \u7981\u6B62 radial-gradient \u6837\u5F0F\u4E0D\u89C4\u8303\uFF0C\u5F84\u5411\u6E10\u53D8\u5FC5\u987B\u663E\u5F0F\u58F0\u660E\u4E3A circle\uFF0C\u4E14\u4E00\u4E2A DOM \u8282\u70B9\u53EA\u80FD\u5305\u542B\u4E00\u4E2A radial-gradient\u3002\n\n## \u4E03\u3001\u9996\u9875\u4E3B\u4F53\u9875\u4E0E\u5B50\u9875\u9762\u7684\u89C4\u5219\n- \u9996\u9875\u4E3B\u4F53\u9875\u5D4C\u5957\u4E86\u591A\u4E2A\u5B50\u9875\u9762\uFF0C\u6BCF\u4E00\u4E2A\u5B50\u9875\u9762\u90FD\u4E0D\u9700\u8981\u586B\u5145\u5185\u5BB9\uFF0C\u7A7A\u767D\u5C31\u884C\uFF0C\u540E\u9762\u4F1A\u6709\u4E13\u95E8\u7684\u4EFB\u52A1\u6765\u8BBE\u8BA1\u5177\u4F53\u7684\u5B50\u9875\u9762\u3002\n- \u4EFB\u4F55\u5B50\u9875\u9762\u90FD\u5FC5\u987B\u7981\u6B62\u6DFB\u52A0\u5E95\u90E8\u5BFC\u822A\u680F\u8282\u70B9\u5230\u9875\u9762\uFF0C\u56E0\u4E3A\u5B50\u9875\u9762\u662F\u5D4C\u5957\u5728\u9996\u9875\u4E3B\u4F53\u9875\u4E2D\u7684\uFF0C\u7236\u9875\u9762\u5DF2\u7ECF\u6709\u5E95\u90E8\u5BFC\u822A\u680F\u4E86\uFF0C\u5B50\u9875\u9762\u4E0D\u9700\u8981\u518D\u6DFB\u52A0\u5E95\u90E8\u5BFC\u822A\u680F\uFF0C\u4E5F\u4E0D\u5F97\u6DFB\u52A0\u4E8C\u7EA7\u9875\u9762\u7684\u6807\u9898\u680F\u5230\u5B50\u9875\u9762\u4E2D\uFF0C\u56E0\u4E3A\u5B50\u9875\u9762\u662F\u5D4C\u5957\u5728\u9996\u9875\u4E3B\u4F53\u9875\u4E2D\u7684\uFF0C\u9996\u9875\u4E3B\u4F53\u9875\u548C\u5B83\u7684\u5B50\u9875\u9762\u90FD\u662F\u4E00\u7EA7\u9875\u9762\uFF0C\u56E0\u6B64\u4E0D\u5F97\u6DFB\u52A0\u4E8C\u7EA7\u9875\u9762\u7684\u6807\u9898\u680F\u5230\u5B50\u9875\u9762\u4E2D\u3002\n\n## \u516B\u3001\u5982\u679C\u7528\u6237\u6CA1\u6709\u660E\u786E\u8BF4\u660E\u8BE5\u9875\u9762\u8BBE\u8BA1\u9700\u6C42\uFF0C\u90A3\u5C31\u6309\u7167\u4EE5\u4E0B\u9875\u9762\u9ED8\u8BA4\u89C4\u5219\u8BBE\u8BA1\n- \u95EA\u5C4F\u9875\uFF1A\u7981\u6B62\u4F7F\u7528\u5168\u5C4F\u56FE\u7247\uFF0C\u4E00\u822C\u4F7F\u7528\u4E3B\u9898\u76F8\u5173\u7684\u6E10\u53D8\u8272\uFF0C\u7136\u540E\u5E26\u6709\u4E00\u4E9B\u989D\u5916\u7684\u80CC\u666F\u5143\u7D20\u589E\u5F3A\u754C\u9762\u5C42\u6B21\u611F\uFF0C\u6BD4\u5982\uFF1A\u68A6\u5E7B\u5706\u5708\u6CE1\u6CE1\u3001\u73BB\u7483\u6548\u679C\u7684\u5706\u5F62\u5F84\u5411\u6E10\u53D8\u7B49\u7B49\u5143\u7D20\n- \u5F15\u5BFC\u9875\uFF1A\u5C3D\u91CF\u4E0D\u4F7F\u7528\u5168\u5C4F\u56FE\u7247\uFF0C\u4E00\u822C\u6BCF\u4E00\u9875\u5F15\u5BFC\u9875\u80CC\u666F\u8272\u4E5F\u53EF\u4EE5\u6E10\u53D8\uFF0C\u7136\u540E\u6BCF\u4E00\u9875\u529F\u80FD\u8BF4\u660E\u4E00\u822C\u6709\u975E\u5168\u5C4F\u56FE\u7247\u3001\u6807\u9898\u3001\u526F\u6807\u9898\u7B49\u7B49\uFF0C\u4F60\u53EF\u4EE5\u5E26\u5165\u5176\u4ED6\u5143\u7D20\uFF0C\u8BA9\u9875\u9762\u66F4\u52A0\u7F8E\u89C2\uFF0C\u5E76\u4E14\u5F15\u5BFC\u9875\u7684\u5F15\u5BFC\u56FE\u7247\u9700\u8981\u81EA\u5DF1\u7ED8\u5236svg\u56FE\u7247\uFF0C\u5E76\u5B58\u653E\u5728`doc/res`\u6587\u4EF6\u5939\u4E0B\u9762\uFF0C\u5E76\u5728html\u4E2D\u4F7F\u7528\n- \u80CC\u666F\u8272\u4E3A\u4E86\u589E\u5F3A\u5C42\u6B21\u611F\uFF0C\u6DFB\u52A0\u7684\u68A6\u5E7B\u6CE1\u6CE1\u6216\u8005\u5706\u5F62\u5F84\u5411\u6E10\u53D8\u5143\u7D20\u7684div\uFF0C\u5FC5\u987B\u53EA\u80FD\u58F0\u660E\u4E3A`circle`\uFF0C\u5E76\u4E14\u4E00\u4E2Adiv\u7684`background:`\u53EA\u80FD\u58F0\u660E\u4E00\u4E2A`radial-gradient`\uFF0C\u6BD4\u5982\u6B63\u786E\u7684\u5199\u6CD5\uFF1Abackground: radial-gradient(circle, rgba(0, 229, 255, 0.15) 0%, rgba(0, 0, 0, 0) 70%);\uFF0C\u5982\u679C\u9700\u8981\u591A\u4E2A`radial-gradient`\u5F84\u5411\u6E10\u53D8\u80CC\u666F\uFF0C\u6BCF\u4E2A\u5F84\u5411\u6E10\u53D8\u80CC\u666F\u90FD\u5FC5\u987B\u58F0\u660E\u4E3A\u4E00\u4E2Adiv\u8282\u70B9\uFF0C\u6BCF\u4E2Adiv\u7684`background:`\u53EA\u80FD\u58F0\u660E\u4E00\u4E2A`radial-gradient`\u3002\n";
2
+ //# sourceMappingURL=uiDesignMulStation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"uiDesignMulStation.d.ts","sourceRoot":"","sources":["../src/uiDesignMulStation.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB,mo6BAyLlC,CAAA"}