bytefun-ai-mcp 1.13.66 → 1.13.68

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/index.js CHANGED
@@ -81,34 +81,34 @@ server.setRequestHandler(ListToolsRequestSchema, async () => {
81
81
  required: ['user_input']
82
82
  }
83
83
  },
84
- {
85
- name: 'optimize_hand_drawn_ui_design_prompt',
86
- description: 'Analyze hand-drawn UI design sketches and extract detailed information for UI design',
87
- inputSchema: {
88
- type: 'object',
89
- properties: {
90
- user_input: {
91
- type: 'string',
92
- description: 'User input with hand-drawn UI design sketch that needs to be analyzed'
93
- }
94
- },
95
- required: ['user_input']
96
- }
97
- },
98
- {
99
- name: 'optimize_ui_design_thinking_prompt',
100
- description: 'Optimize prompt for UI design thinking process before actual design work, generating detailed UI design thinking documentation',
101
- inputSchema: {
102
- type: 'object',
103
- properties: {
104
- user_input: {
105
- type: 'string',
106
- description: 'User input prompt that needs to be optimized for UI design thinking process'
107
- }
108
- },
109
- required: ['user_input']
110
- }
111
- },
84
+ // {
85
+ // name: 'optimize_hand_drawn_ui_design_prompt',
86
+ // description: 'Analyze hand-drawn UI design sketches and extract detailed information for UI design',
87
+ // inputSchema: {
88
+ // type: 'object',
89
+ // properties: {
90
+ // user_input: {
91
+ // type: 'string',
92
+ // description: 'User input with hand-drawn UI design sketch that needs to be analyzed'
93
+ // }
94
+ // },
95
+ // required: ['user_input']
96
+ // }
97
+ // },
98
+ // {
99
+ // name: 'optimize_ui_design_thinking_prompt',
100
+ // description: 'Optimize prompt for UI design thinking process before actual design work, generating detailed UI design thinking documentation',
101
+ // inputSchema: {
102
+ // type: 'object',
103
+ // properties: {
104
+ // user_input: {
105
+ // type: 'string',
106
+ // description: 'User input prompt that needs to be optimized for UI design thinking process'
107
+ // }
108
+ // },
109
+ // required: ['user_input']
110
+ // }
111
+ // },
112
112
  {
113
113
  name: 'optimize_backend_design_prompt',
114
114
  description: 'Optimize prompt for backend database and API interface design by reading module business logic documents',
@@ -123,24 +123,24 @@ server.setRequestHandler(ListToolsRequestSchema, async () => {
123
123
  required: ['user_input']
124
124
  }
125
125
  },
126
- {
127
- name: 'functional_module_business_logic_prompt',
128
- description: 'Optimize prompt for functional module business logic analysis based on product requirements document',
129
- inputSchema: {
130
- type: 'object',
131
- properties: {
132
- functionalModule: {
133
- type: 'string',
134
- description: 'The functional module currently being designed'
135
- },
136
- user_input: {
137
- type: 'string',
138
- description: 'User input prompt that needs to be optimized for functional module business logic analysis'
139
- }
140
- },
141
- required: ['functionalModule', 'user_input']
142
- }
143
- },
126
+ // {
127
+ // name: 'functional_module_business_logic_prompt',
128
+ // description: 'Optimize prompt for functional module business logic analysis based on product requirements document',
129
+ // inputSchema: {
130
+ // type: 'object',
131
+ // properties: {
132
+ // functionalModule: {
133
+ // type: 'string',
134
+ // description: 'The functional module currently being designed'
135
+ // },
136
+ // user_input: {
137
+ // type: 'string',
138
+ // description: 'User input prompt that needs to be optimized for functional module business logic analysis'
139
+ // }
140
+ // },
141
+ // required: ['functionalModule', 'user_input']
142
+ // }
143
+ // },
144
144
  // {
145
145
  // name: 'talk_to_editor',
146
146
  // description: 'Establish long connection with editor backend using Socket.IO. Before calling this tool, you must first use read_file to read .bytefun/project.json and get projectID and uid values. This tool will wait for backend messages and return tasks to execute.',
@@ -196,20 +196,20 @@ server.setRequestHandler(ListToolsRequestSchema, async () => {
196
196
  required: ['user_input']
197
197
  }
198
198
  },
199
- {
200
- name: 'optimize_ui_design_replenish_prompt',
201
- description: 'Optimize prompt for UI design HTML replenishment and attribute completion',
202
- inputSchema: {
203
- type: 'object',
204
- properties: {
205
- user_input: {
206
- type: 'string',
207
- description: 'User input prompt that needs to be optimized for UI design HTML replenishment'
208
- }
209
- },
210
- required: ['user_input']
211
- }
212
- },
199
+ // {
200
+ // name: 'optimize_ui_design_replenish_prompt',
201
+ // description: 'Optimize prompt for UI design HTML replenishment and attribute completion',
202
+ // inputSchema: {
203
+ // type: 'object',
204
+ // properties: {
205
+ // user_input: {
206
+ // type: 'string',
207
+ // description: 'User input prompt that needs to be optimized for UI design HTML replenishment'
208
+ // }
209
+ // },
210
+ // required: ['user_input']
211
+ // }
212
+ // },
213
213
  {
214
214
  name: 'optimize_jump_page_code_prompt',
215
215
  description: 'Optimize prompt for page navigation code development based on UI design progress and jumping rules',
@@ -224,20 +224,20 @@ server.setRequestHandler(ListToolsRequestSchema, async () => {
224
224
  required: ['user_input']
225
225
  }
226
226
  },
227
- {
228
- name: 'optimize_declarative_ui_prompt',
229
- description: 'Optimize prompt for declarative UI design using JSON format to describe UI components and interfaces',
230
- inputSchema: {
231
- type: 'object',
232
- properties: {
233
- user_input: {
234
- type: 'string',
235
- description: 'User input prompt that needs to be optimized for declarative UI design'
236
- }
237
- },
238
- required: ['user_input']
239
- }
240
- },
227
+ // {
228
+ // name: 'optimize_declarative_ui_prompt',
229
+ // description: 'Optimize prompt for declarative UI design using JSON format to describe UI components and interfaces',
230
+ // inputSchema: {
231
+ // type: 'object',
232
+ // properties: {
233
+ // user_input: {
234
+ // type: 'string',
235
+ // description: 'User input prompt that needs to be optimized for declarative UI design'
236
+ // }
237
+ // },
238
+ // required: ['user_input']
239
+ // }
240
+ // },
241
241
  {
242
242
  name: 'optimize_ui_spec_design_prompt',
243
243
  description: 'Optimize prompt for UI specification design based on product requirements document to complete UI design standards',
@@ -251,21 +251,21 @@ server.setRequestHandler(ListToolsRequestSchema, async () => {
251
251
  },
252
252
  required: ['user_input']
253
253
  }
254
- },
255
- {
256
- name: 'implement_ui_code_prompt',
257
- description: 'Return prompt for implementing UI code with strict execution steps',
258
- inputSchema: {
259
- type: 'object',
260
- properties: {
261
- user_input: {
262
- type: 'string',
263
- description: 'User input describing UI code implementation requirements'
264
- }
265
- },
266
- required: ['user_input']
267
- }
268
254
  }
255
+ // {
256
+ // name: 'implement_ui_code_prompt',
257
+ // description: 'Return prompt for implementing UI code with strict execution steps',
258
+ // inputSchema: {
259
+ // type: 'object',
260
+ // properties: {
261
+ // user_input: {
262
+ // type: 'string',
263
+ // description: 'User input describing UI code implementation requirements'
264
+ // }
265
+ // },
266
+ // required: ['user_input']
267
+ // }
268
+ // }
269
269
  ]
270
270
  };
271
271
  });
@@ -484,4 +484,4 @@ async function main() {
484
484
  console.error('ByteFun AI Prompt MCP server running on stdio');
485
485
  }
486
486
  main().catch(console.error);
487
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\nimport { Server } from '@modelcontextprotocol/sdk/server/index.js';\nimport { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';\nimport {\n  CallToolRequestSchema,\n  ListToolsRequestSchema,\n  Tool,\n} from '@modelcontextprotocol/sdk/types.js';\nimport { PromptOptimizer } from './prompt-optimizer.js';\n\nconst server = new Server(\n  {\n    name: 'bytefun-ai-prompt',\n    version: '1.0.0',\n  }\n);\n\nconst promptOptimizer = new PromptOptimizer();\n\n\n\n// List available tools\nserver.setRequestHandler(ListToolsRequestSchema, async () => {\n  return {\n    tools: [\n      {\n        name: 'optimize_product_design_prompt',\n        description: 'Optimize prompt for product and business logic design',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            industry: {\n              type: 'string',\n              description: 'The industry that the APP or website belongs to'\n            },\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for product and business logic design'\n            }\n          },\n          required: ['industry', 'user_input']\n        }\n      },\n      {\n        name: 'optimize_ui_design_prompt',\n        description: 'Optimize prompt for UI design by reading page list and requirements from doc file',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI design'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'ui_design_guide_prompt',\n        description: 'Return comprehensive UI design guide prompt with strict execution rules',\n        inputSchema: {\n          type: 'object',\n          properties: {},\n          required: []\n        }\n      },\n      {\n        name: 'optimize_code_design_prompt',\n        description: 'Optimize prompt for code logic design thinking before development, generating detailed design documentation',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for code logic design thinking'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'implement_logic_code_prompt',\n        description: 'Optimize prompt for TypeScript code development by adding code development rules and marking user input',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for code development'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_hand_drawn_ui_design_prompt',\n        description: 'Analyze hand-drawn UI design sketches and extract detailed information for UI design',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input with hand-drawn UI design sketch that needs to be analyzed'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_ui_design_thinking_prompt',\n        description: 'Optimize prompt for UI design thinking process before actual design work, generating detailed UI design thinking documentation',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI design thinking process'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n\n      {\n        name: 'optimize_backend_design_prompt',\n        description: 'Optimize prompt for backend database and API interface design by reading module business logic documents',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for backend database and API interface design'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n\n      {\n        name: 'functional_module_business_logic_prompt',\n        description: 'Optimize prompt for functional module business logic analysis based on product requirements document',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            functionalModule: {\n              type: 'string',\n              description: 'The functional module currently being designed'\n            },\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for functional module business logic analysis'\n            }\n          },\n          required: ['functionalModule', 'user_input']\n        }\n      },\n\n      // {\n      //   name: 'talk_to_editor',\n      //   description: 'Establish long connection with editor backend using Socket.IO. Before calling this tool, you must first use read_file to read .bytefun/project.json and get projectID and uid values. This tool will wait for backend messages and return tasks to execute.',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       projectID: {\n      //         type: 'number',\n      //         description: 'Project ID from .bytefun/project.json configuration file'\n      //       },\n      //       uid: {\n      //         type: 'number',\n      //         description: 'User ID from .bytefun/project.json configuration file'\n      //       }\n      //     },\n      //     required: ['projectID', 'uid']\n      //   }\n      // },\n      // {\n      //   name: 'talk_to_editor_rules',\n      //   description: 'Get AI behavior rules for interacting with talk_to_editor tool. Returns detailed instructions on how AI should maintain continuous conversation and wait for backend control.',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {},\n      //     required: []\n      //   }\n      // },\n      {\n        name: 'implement_backend_code_prompt',\n        description: 'Optimize prompt for backend code development by reading backend design documents and applying coding standards',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for backend code development'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_ui_design_edit_prompt',\n        description: 'Optimize prompt for UI design modification and editing tasks, returning detailed UI design specifications',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI design modification'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_ui_design_replenish_prompt',\n        description: 'Optimize prompt for UI design HTML replenishment and attribute completion',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI design HTML replenishment'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_jump_page_code_prompt',\n        description: 'Optimize prompt for page navigation code development based on UI design progress and jumping rules',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for page navigation code development'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_declarative_ui_prompt',\n        description: 'Optimize prompt for declarative UI design using JSON format to describe UI components and interfaces',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for declarative UI design'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_ui_spec_design_prompt',\n        description: 'Optimize prompt for UI specification design based on product requirements document to complete UI design standards',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI specification design'\n            }\n          },\n          required: ['user_input']\n        }\n      }\n      ,\n      {\n        name: 'implement_ui_code_prompt',\n        description: 'Return prompt for implementing UI code with strict execution steps',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input describing UI code implementation requirements'\n            }\n          },\n          required: ['user_input']\n        }\n      }\n    ] as Tool[]\n  };\n});\n\n// Handle tool calls\nserver.setRequestHandler(CallToolRequestSchema, async (request) => {\n  const { name, arguments: args } = request.params;\n\n  if (!args) {\n    throw new Error('Missing arguments');\n  }\n\n  try {\n    switch (name) {\n      case 'optimize_product_design_prompt':\n        const optimizedProductDesignPrompt = await promptOptimizer.optimizeProductDesignPrompt(args.industry as string, args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedProductDesignPrompt\n            }\n          ]\n        };\n\n      case 'optimize_ui_design_prompt':\n        const optimizedUIPrompt = await promptOptimizer.optimizeUIDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedUIPrompt\n            }\n          ]\n        };\n\n      case 'ui_design_guide_prompt':\n        const uiDesignGuideText = await promptOptimizer.uiDesignGuidePrompt();\n        return {\n          content: [\n            {\n              type: 'text',\n              text: uiDesignGuideText\n            }\n          ]\n        };\n\n      case 'optimize_code_design_prompt':\n        const optimizedCodeDesignPrompt = await promptOptimizer.optimizeCodeDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedCodeDesignPrompt\n            }\n          ]\n        };\n\n      case 'implement_logic_code_prompt':\n        const optimizedCodePrompt = await promptOptimizer.optimizeCodePrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedCodePrompt\n            }\n          ]\n        };\n\n      // case 'optimize_hand_drawn_ui_design_prompt':\n      //   const optimizedHandDrawnPrompt = await promptOptimizer.optimizeHandDrawnUIDesignPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedHandDrawnPrompt\n      //       }\n      //     ]\n      //   };\n\n      // case 'optimize_ui_design_thinking_prompt':\n      //   const optimizedUIDesignThinkingPrompt = await promptOptimizer.optimizeUIDesignThinkingPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedUIDesignThinkingPrompt\n      //       }\n      //     ]\n      //   };\n\n      case 'optimize_backend_design_prompt':\n        const optimizedBackendDesignPrompt = await promptOptimizer.optimizeBackendDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedBackendDesignPrompt\n            }\n          ]\n        };\n\n      case 'functional_module_business_logic_prompt':\n        const optimizedFunctionalModulePrompt = await promptOptimizer.optimizeFunctionalModulePrompt(args.functionalModule as string, args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedFunctionalModulePrompt\n            }\n          ]\n        };\n\n\n      // case 'talk_to_editor':\n      //   const projectID = args.projectID as number || 0;\n      //   const uid = args.uid as number || 0;\n        \n      //   const talkResult = await promptOptimizer.talkToEditor({\n      //     projectID,\n      //     uid\n      //   });\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: talkResult\n      //       }\n      //     ]\n      //   };\n\n      // case 'talk_to_editor_rules':\n      //   const rulesResult = await promptOptimizer.talkToEditorRules();\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: rulesResult\n      //       }\n      //     ]\n      //   };\n\n      case 'implement_backend_code_prompt':\n        const optimizedBackendCodePrompt = await promptOptimizer.optimizeBackendCodePrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedBackendCodePrompt\n            }\n          ]\n        };\n\n      case 'optimize_ui_design_edit_prompt':\n        const optimizedUIDesignEditPrompt = await promptOptimizer.optimizeUIDesignEditPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedUIDesignEditPrompt\n            }\n          ]\n        };\n\n      case 'optimize_jump_page_code_prompt':\n        const optimizedJumpPageCodePrompt = await promptOptimizer.optimizeJumpPageCodePrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedJumpPageCodePrompt\n            }\n          ]\n        };\n\n      // case 'optimize_declarative_ui_prompt':\n      //   const optimizedDeclarativeUIPrompt = await promptOptimizer.optimizeDeclarativeUIPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedDeclarativeUIPrompt\n      //       }\n      //     ]\n      //   };\n\n      case 'optimize_ui_spec_design_prompt':\n        const optimizedUISpecDesignPrompt = await promptOptimizer.optimizeUISpecDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedUISpecDesignPrompt\n            }\n          ]\n        };\n\n      // case 'optimize_ui_design_replenish_prompt':\n      //   const optimizedUIDesignReplenishPrompt = await promptOptimizer.optimizeUIDesignReplenishPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedUIDesignReplenishPrompt\n      //       }\n      //     ]\n      //   };\n\n      // case 'implement_ui_code_prompt':\n      //   const implementUICodeText = await promptOptimizer.implementUICodePrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: implementUICodeText\n      //       }\n      //     ]\n      //   };\n\n      default:\n        throw new Error(`Unknown tool: ${name}`);\n    }\n  } catch (error) {\n    return {\n      content: [\n        {\n          type: 'text',\n          text: `Error: ${error instanceof Error ? error.message : String(error)}`\n        }\n      ],\n      isError: true\n    };\n  }\n});\n\nasync function main() {\n  const transport = new StdioServerTransport();\n  await server.connect(transport);\n  console.error('ByteFun AI Prompt MCP server running on stdio');\n}\n\nmain().catch(console.error);"]}
487
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\nimport { Server } from '@modelcontextprotocol/sdk/server/index.js';\nimport { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';\nimport {\n  CallToolRequestSchema,\n  ListToolsRequestSchema,\n  Tool,\n} from '@modelcontextprotocol/sdk/types.js';\nimport { PromptOptimizer } from './prompt-optimizer.js';\n\nconst server = new Server(\n  {\n    name: 'bytefun-ai-prompt',\n    version: '1.0.0',\n  }\n);\n\nconst promptOptimizer = new PromptOptimizer();\n\n\n\n// List available tools\nserver.setRequestHandler(ListToolsRequestSchema, async () => {\n  return {\n    tools: [\n      {\n        name: 'optimize_product_design_prompt',\n        description: 'Optimize prompt for product and business logic design',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            industry: {\n              type: 'string',\n              description: 'The industry that the APP or website belongs to'\n            },\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for product and business logic design'\n            }\n          },\n          required: ['industry', 'user_input']\n        }\n      },\n      {\n        name: 'optimize_ui_design_prompt',\n        description: 'Optimize prompt for UI design by reading page list and requirements from doc file',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI design'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'ui_design_guide_prompt',\n        description: 'Return comprehensive UI design guide prompt with strict execution rules',\n        inputSchema: {\n          type: 'object',\n          properties: {},\n          required: []\n        }\n      },\n      {\n        name: 'optimize_code_design_prompt',\n        description: 'Optimize prompt for code logic design thinking before development, generating detailed design documentation',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for code logic design thinking'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'implement_logic_code_prompt',\n        description: 'Optimize prompt for TypeScript code development by adding code development rules and marking user input',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for code development'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      // {\n      //   name: 'optimize_hand_drawn_ui_design_prompt',\n      //   description: 'Analyze hand-drawn UI design sketches and extract detailed information for UI design',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       user_input: {\n      //         type: 'string',\n      //         description: 'User input with hand-drawn UI design sketch that needs to be analyzed'\n      //       }\n      //     },\n      //     required: ['user_input']\n      //   }\n      // },\n      // {\n      //   name: 'optimize_ui_design_thinking_prompt',\n      //   description: 'Optimize prompt for UI design thinking process before actual design work, generating detailed UI design thinking documentation',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       user_input: {\n      //         type: 'string',\n      //         description: 'User input prompt that needs to be optimized for UI design thinking process'\n      //       }\n      //     },\n      //     required: ['user_input']\n      //   }\n      // },\n\n      {\n        name: 'optimize_backend_design_prompt',\n        description: 'Optimize prompt for backend database and API interface design by reading module business logic documents',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for backend database and API interface design'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      // {\n      //   name: 'functional_module_business_logic_prompt',\n      //   description: 'Optimize prompt for functional module business logic analysis based on product requirements document',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       functionalModule: {\n      //         type: 'string',\n      //         description: 'The functional module currently being designed'\n      //       },\n      //       user_input: {\n      //         type: 'string',\n      //         description: 'User input prompt that needs to be optimized for functional module business logic analysis'\n      //       }\n      //     },\n      //     required: ['functionalModule', 'user_input']\n      //   }\n      // },\n\n      // {\n      //   name: 'talk_to_editor',\n      //   description: 'Establish long connection with editor backend using Socket.IO. Before calling this tool, you must first use read_file to read .bytefun/project.json and get projectID and uid values. This tool will wait for backend messages and return tasks to execute.',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       projectID: {\n      //         type: 'number',\n      //         description: 'Project ID from .bytefun/project.json configuration file'\n      //       },\n      //       uid: {\n      //         type: 'number',\n      //         description: 'User ID from .bytefun/project.json configuration file'\n      //       }\n      //     },\n      //     required: ['projectID', 'uid']\n      //   }\n      // },\n      // {\n      //   name: 'talk_to_editor_rules',\n      //   description: 'Get AI behavior rules for interacting with talk_to_editor tool. Returns detailed instructions on how AI should maintain continuous conversation and wait for backend control.',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {},\n      //     required: []\n      //   }\n      // },\n      {\n        name: 'implement_backend_code_prompt',\n        description: 'Optimize prompt for backend code development by reading backend design documents and applying coding standards',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for backend code development'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      {\n        name: 'optimize_ui_design_edit_prompt',\n        description: 'Optimize prompt for UI design modification and editing tasks, returning detailed UI design specifications',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI design modification'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      // {\n      //   name: 'optimize_ui_design_replenish_prompt',\n      //   description: 'Optimize prompt for UI design HTML replenishment and attribute completion',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       user_input: {\n      //         type: 'string',\n      //         description: 'User input prompt that needs to be optimized for UI design HTML replenishment'\n      //       }\n      //     },\n      //     required: ['user_input']\n      //   }\n      // },\n      {\n        name: 'optimize_jump_page_code_prompt',\n        description: 'Optimize prompt for page navigation code development based on UI design progress and jumping rules',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for page navigation code development'\n            }\n          },\n          required: ['user_input']\n        }\n      },\n      // {\n      //   name: 'optimize_declarative_ui_prompt',\n      //   description: 'Optimize prompt for declarative UI design using JSON format to describe UI components and interfaces',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       user_input: {\n      //         type: 'string',\n      //         description: 'User input prompt that needs to be optimized for declarative UI design'\n      //       }\n      //     },\n      //     required: ['user_input']\n      //   }\n      // },\n      {\n        name: 'optimize_ui_spec_design_prompt',\n        description: 'Optimize prompt for UI specification design based on product requirements document to complete UI design standards',\n        inputSchema: {\n          type: 'object',\n          properties: {\n            user_input: {\n              type: 'string',\n              description: 'User input prompt that needs to be optimized for UI specification design'\n            }\n          },\n          required: ['user_input']\n        }\n      }\n      // {\n      //   name: 'implement_ui_code_prompt',\n      //   description: 'Return prompt for implementing UI code with strict execution steps',\n      //   inputSchema: {\n      //     type: 'object',\n      //     properties: {\n      //       user_input: {\n      //         type: 'string',\n      //         description: 'User input describing UI code implementation requirements'\n      //       }\n      //     },\n      //     required: ['user_input']\n      //   }\n      // }\n    ] as Tool[]\n  };\n});\n\n// Handle tool calls\nserver.setRequestHandler(CallToolRequestSchema, async (request) => {\n  const { name, arguments: args } = request.params;\n\n  if (!args) {\n    throw new Error('Missing arguments');\n  }\n\n  try {\n    switch (name) {\n      case 'optimize_product_design_prompt':\n        const optimizedProductDesignPrompt = await promptOptimizer.optimizeProductDesignPrompt(args.industry as string, args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedProductDesignPrompt\n            }\n          ]\n        };\n\n      case 'optimize_ui_design_prompt':\n        const optimizedUIPrompt = await promptOptimizer.optimizeUIDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedUIPrompt\n            }\n          ]\n        };\n\n      case 'ui_design_guide_prompt':\n        const uiDesignGuideText = await promptOptimizer.uiDesignGuidePrompt();\n        return {\n          content: [\n            {\n              type: 'text',\n              text: uiDesignGuideText\n            }\n          ]\n        };\n\n      case 'optimize_code_design_prompt':\n        const optimizedCodeDesignPrompt = await promptOptimizer.optimizeCodeDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedCodeDesignPrompt\n            }\n          ]\n        };\n\n      case 'implement_logic_code_prompt':\n        const optimizedCodePrompt = await promptOptimizer.optimizeCodePrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedCodePrompt\n            }\n          ]\n        };\n\n      // case 'optimize_hand_drawn_ui_design_prompt':\n      //   const optimizedHandDrawnPrompt = await promptOptimizer.optimizeHandDrawnUIDesignPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedHandDrawnPrompt\n      //       }\n      //     ]\n      //   };\n\n      // case 'optimize_ui_design_thinking_prompt':\n      //   const optimizedUIDesignThinkingPrompt = await promptOptimizer.optimizeUIDesignThinkingPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedUIDesignThinkingPrompt\n      //       }\n      //     ]\n      //   };\n\n      case 'optimize_backend_design_prompt':\n        const optimizedBackendDesignPrompt = await promptOptimizer.optimizeBackendDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedBackendDesignPrompt\n            }\n          ]\n        };\n\n      case 'functional_module_business_logic_prompt':\n        const optimizedFunctionalModulePrompt = await promptOptimizer.optimizeFunctionalModulePrompt(args.functionalModule as string, args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedFunctionalModulePrompt\n            }\n          ]\n        };\n\n\n      // case 'talk_to_editor':\n      //   const projectID = args.projectID as number || 0;\n      //   const uid = args.uid as number || 0;\n        \n      //   const talkResult = await promptOptimizer.talkToEditor({\n      //     projectID,\n      //     uid\n      //   });\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: talkResult\n      //       }\n      //     ]\n      //   };\n\n      // case 'talk_to_editor_rules':\n      //   const rulesResult = await promptOptimizer.talkToEditorRules();\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: rulesResult\n      //       }\n      //     ]\n      //   };\n\n      case 'implement_backend_code_prompt':\n        const optimizedBackendCodePrompt = await promptOptimizer.optimizeBackendCodePrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedBackendCodePrompt\n            }\n          ]\n        };\n\n      case 'optimize_ui_design_edit_prompt':\n        const optimizedUIDesignEditPrompt = await promptOptimizer.optimizeUIDesignEditPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedUIDesignEditPrompt\n            }\n          ]\n        };\n\n      case 'optimize_jump_page_code_prompt':\n        const optimizedJumpPageCodePrompt = await promptOptimizer.optimizeJumpPageCodePrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedJumpPageCodePrompt\n            }\n          ]\n        };\n\n      // case 'optimize_declarative_ui_prompt':\n      //   const optimizedDeclarativeUIPrompt = await promptOptimizer.optimizeDeclarativeUIPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedDeclarativeUIPrompt\n      //       }\n      //     ]\n      //   };\n\n      case 'optimize_ui_spec_design_prompt':\n        const optimizedUISpecDesignPrompt = await promptOptimizer.optimizeUISpecDesignPrompt(args.user_input as string);\n        return {\n          content: [\n            {\n              type: 'text',\n              text: optimizedUISpecDesignPrompt\n            }\n          ]\n        };\n\n      // case 'optimize_ui_design_replenish_prompt':\n      //   const optimizedUIDesignReplenishPrompt = await promptOptimizer.optimizeUIDesignReplenishPrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: optimizedUIDesignReplenishPrompt\n      //       }\n      //     ]\n      //   };\n\n      // case 'implement_ui_code_prompt':\n      //   const implementUICodeText = await promptOptimizer.implementUICodePrompt(args.user_input as string);\n      //   return {\n      //     content: [\n      //       {\n      //         type: 'text',\n      //         text: implementUICodeText\n      //       }\n      //     ]\n      //   };\n\n      default:\n        throw new Error(`Unknown tool: ${name}`);\n    }\n  } catch (error) {\n    return {\n      content: [\n        {\n          type: 'text',\n          text: `Error: ${error instanceof Error ? error.message : String(error)}`\n        }\n      ],\n      isError: true\n    };\n  }\n});\n\nasync function main() {\n  const transport = new StdioServerTransport();\n  await server.connect(transport);\n  console.error('ByteFun AI Prompt MCP server running on stdio');\n}\n\nmain().catch(console.error);"]}
@@ -1,2 +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\u7981\u6B62\u7684\u4E8B\u60C5\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- 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- hover\u4E0E\u70B9\u51FB\u53CD\u9988\uFF1A\u8BF7\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\n## \u4E8C\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\n## \u4E09\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- 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 - \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 - \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\u3002\n- \u9AD8\u7EA7\u7EC4\u4EF6\u8282\u70B9\u7684nodeType\u7ED3\u6784\u89C4\u5219\uFF1A\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\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`topNavigateBar`\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\n## \u56DB\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\u7684html\u4EE3\u7801\uFF0C\u5176\u4ED6Slide\u7684html\u4EE3\u7801\u4E5F\u5FC5\u987B\u8981\u5199\u3002\n- Tabs\u9009\u9879\u5361\u7EC4\u4EF6\u6BCF\u4E00\u4E2ATab Panel\u90FD\u5FC5\u987B\u6709html\u4EE3\u7801\u5B9E\u73B0\uFF0C\u4E0D\u5F97\u53EA\u5199\u7B2C1\u4E2ATab Panel\u7684html\u4EE3\u7801\uFF0C\u5176\u4ED6Tab Panel\u7684html\u4EE3\u7801\u4E5F\u5FC5\u987B\u8981\u5199\u3002\n\n## \u4E94\u3001\u56FE\u6807\u4E0E\u56FE\u7247\u7684\u89C4\u5219\n- icon\u56FE\u6807\u5FC5\u987B\u4F7F\u7528 FontAwesome \u56FE\u6807\uFF0C\u6BD4\u5982\uFF1A`<i name=\"\u5FAE\u4FE1Icon\" nodeType=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>`\n- img\u56FE\u7247\u7684src \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- \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\u7528 icon \u6216 img \u56FE\u7247\u8282\u70B9\u6765\u4EE3\u66FF\u3002\n\n## \u516D\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## \u4E03\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\u5C3D\u91CF\u4E0D\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\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\u3002\n";
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\u7981\u6B62\u7684\u4E8B\u60C5\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- 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- hover\u4E0E\u70B9\u51FB\u53CD\u9988\uFF1A\u8BF7\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\n## \u4E8C\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\n## \u4E09\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- 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 - \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 - \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\u3002\n- \u9AD8\u7EA7\u7EC4\u4EF6\u8282\u70B9\u7684nodeType\u7ED3\u6784\u89C4\u5219\uFF1A\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\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`topNavigateBar`\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\n## \u56DB\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\u7684html\u4EE3\u7801\uFF0C\u5176\u4ED6Slide\u7684html\u4EE3\u7801\u4E5F\u5FC5\u987B\u8981\u5199\u3002\n- Tabs\u9009\u9879\u5361\u7EC4\u4EF6\u6BCF\u4E00\u4E2ATab Panel\u90FD\u5FC5\u987B\u6709html\u4EE3\u7801\u5B9E\u73B0\uFF0C\u4E0D\u5F97\u53EA\u5199\u7B2C1\u4E2ATab Panel\u7684html\u4EE3\u7801\uFF0C\u5176\u4ED6Tab Panel\u7684html\u4EE3\u7801\u4E5F\u5FC5\u987B\u8981\u5199\u3002\n\n## \u4E94\u3001\u56FE\u6807\u4E0E\u56FE\u7247\u7684\u89C4\u5219\n- icon\u56FE\u6807\u5FC5\u987B\u4F7F\u7528 FontAwesome \u56FE\u6807\uFF0C\u6BD4\u5982\uFF1A`<i name=\"\u5FAE\u4FE1Icon\" nodeType=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>`\n- img\u56FE\u7247\u7684src \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- \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\u7528 icon \u6216 img \u56FE\u7247\u8282\u70B9\u6765\u4EE3\u66FF\u3002\n\n## \u516D\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## \u4E03\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\u5C3D\u91CF\u4E0D\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\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\u3002\n";
2
2
  //# sourceMappingURL=uiDesign.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"uiDesign.d.ts","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB,sjbA8FlC,CAAA"}
1
+ {"version":3,"file":"uiDesign.d.ts","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB,iwbA+FlC,CAAA"}
package/build/uiDesign.js CHANGED
@@ -4,6 +4,7 @@ export const uiDesignPromptTemplate = `# UI设计规则,特别注意必须使
4
4
  - 禁止使用任何前端框架,只使用 html+类选择器样式+js 来实现。
5
5
  - 禁止使用js代码来拼接html字符串,必须在body标签里面直接写html代码。
6
6
  - 禁止使用js代码来声明任何页面显示所需的数据,所有数据都必须在html代码中直接写死。
7
+ - 禁止使用文本渐变色,必须使用纯色文本,也就是禁止使用\`-webkit-text-fill-color\`属性。
7
8
  - loading节点的实现禁止使用div标签与边框属性实现,必须使用图标icon的i标签来实现loading的节点
8
9
  - 禁止为html标签节点添加动画或过渡效果,页面设计不需要任何动画和过渡效果,比如禁止:@keyframes、transition、animation 等。
9
10
  - hover与点击反馈:请使用浅色的背景色background来反馈就行,严禁使用transform效果
@@ -93,4 +94,4 @@ export const uiDesignPromptTemplate = `# UI设计规则,特别注意必须使
93
94
  - 闪屏页:尽量不使用全屏图片,一般使用主题相关的渐变色,然后带有一些额外的背景元素增强界面层次感
94
95
  - 引导页:尽量不使用全屏图片,一般每一页引导页背景色也可以渐变,然后每一页功能说明一般有非全屏图片、标题、副标题等等,你可以带入其他元素,让页面更加美观。
95
96
  `;
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesign.js","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,sBAAsB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA8FrC,CAAA","sourcesContent":["export const uiDesignPromptTemplate = `# UI设计规则，特别注意必须使用UI规范\\`.bytefun/UI设计规范.md\\`里面默认的主题皮肤来设计，不得使用其他主题皮肤。\n\n## 一、禁止的事情\n- 禁止使用任何前端框架，只使用 html+类选择器样式+js 来实现。\n- 禁止使用js代码来拼接html字符串，必须在body标签里面直接写html代码。\n- 禁止使用js代码来声明任何页面显示所需的数据，所有数据都必须在html代码中直接写死。\n- loading节点的实现禁止使用div标签与边框属性实现，必须使用图标icon的i标签来实现loading的节点\n- 禁止为html标签节点添加动画或过渡效果，页面设计不需要任何动画和过渡效果，比如禁止：@keyframes、transition、animation 等。\n- 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\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\n## 三、必须给每一个节点添加id、name、nodeType属性\n- 特别注意，\\`i\\`和\\`div\\`等标签也必须添加 id、name、nodeType 属性，每一个节点都需要添加这三个属性，千万别漏掉了，这是必要条件\n- id 属性必须只能使用英文或数字组成，且不能以数字开头，并且整个页面 id 属性的值必须唯一，使用驼峰的命名方式\n- name 属性必须是中文或数字，并且不能包含特殊字符\n- nodeType 属性的值必须是\\`组件类型枚举 (nodeType)枚举\\` 中的一个，一些布局容器需要遵守以下说明来选择正确的nodeType：\n  - 列表容器：\\`verticalListView\\`、\\`horizontalListView\\`、\\`listItemCard\\`，用于布局多个列表项，比如：商品列表、分类列表、标签列表等，可以支持多行多列的列表布局\n  - 列表页脚容器：\\`listFooterContainer\\`，用于布局列表的页脚，比如：加载更多、没有更多了等\n  - 网格容器：gridContainer用于布局多个网格项，里面包含N个gridItem，比如：分类网格入口\n  - 流式容器：用于布局多个子项，子项可以在一行显示，当位置不够时就换行显示，比如：一组标签tag的排版布局\n  - 多状态容器：\\`multiStateContainer\\`, \\`oneStateContentContainer\\`，用于不是通过交互，而是通过逻辑状态变量变化而显示不同状态的内容容器，比如：登录状态和未登录状态分别显示不同的内容。\n- 高级组件节点的nodeType结构规则：\n  - tab 选项卡：\\`tabMenuBar\\`是tab选项卡菜单栏，里面包含N个\\`tabMenuBarItem\\`，\\`tabPanelFather\\`是tab选项卡内容容器，里面包含N个\\`tabPanel\\`，\\`tabMenuBar\\`和\\`tabPanelFather\\`必须同时存在，\\`tabPanel\\`的数量必须和\\`tabMenuBarItem\\`的数量相同\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  - 顶部导航栏：\\`topNavigateBar\\`\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\n## 四、轮播与Tabs组件的规则\n- 轮播的每一个Slide和Tabs选项卡组件每一个Tab Panel都必须使用\\`display: none\\`和\\`display: block/flex\\`来实现隐藏和显示的互斥切换\n- 轮播的每一个Slide必须有html代码实现，不得只写第1个Slide的html代码，其他Slide的html代码也必须要写。\n- Tabs选项卡组件每一个Tab Panel都必须有html代码实现，不得只写第1个Tab Panel的html代码，其他Tab Panel的html代码也必须要写。\n\n## 五、图标与图片的规则\n- icon图标必须使用 FontAwesome 图标，比如：\\`<i name=\"微信Icon\" nodeType=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>\\`\n- img图片的src 必须使用图片地址：\\`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- 绝对不能使用 emoji 表情符号，不得使用任何 emoji 表情符号，请使用 icon 或 img 图片节点来代替。\n\n## 六、首页主体页与子页面的规则\n- 首页主体页嵌套了多个子页面，每一个子页面都不需要填充内容，空白就行，后面会有专门的任务来设计具体的子页面。\n- 任何子页面都必须禁止添加底部导航栏节点到页面，因为子页面是嵌套在首页主体页中的，父页面已经有底部导航栏了，子页面不需要再添加底部导航栏，也不得添加二级页面的标题栏到子页面中，因为子页面是嵌套在首页主体页中的，首页主体页和它的子页面都是一级页面，因此不得添加二级页面的标题栏到子页面中。\n\n## 七、如果用户没有明确说明该页面设计需求，那就按照以下页面默认规则设计\n- 闪屏页：尽量不使用全屏图片，一般使用主题相关的渐变色，然后带有一些额外的背景元素增强界面层次感\n- 引导页：尽量不使用全屏图片，一般每一页引导页背景色也可以渐变，然后每一页功能说明一般有非全屏图片、标题、副标题等等，你可以带入其他元素，让页面更加美观。\n`"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiDesign.js","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,sBAAsB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+FrC,CAAA","sourcesContent":["export const uiDesignPromptTemplate = `# UI设计规则，特别注意必须使用UI规范\\`.bytefun/UI设计规范.md\\`里面默认的主题皮肤来设计，不得使用其他主题皮肤。\n\n## 一、禁止的事情\n- 禁止使用任何前端框架，只使用 html+类选择器样式+js 来实现。\n- 禁止使用js代码来拼接html字符串，必须在body标签里面直接写html代码。\n- 禁止使用js代码来声明任何页面显示所需的数据，所有数据都必须在html代码中直接写死。\n- 禁止使用文本渐变色，必须使用纯色文本，也就是禁止使用\\`-webkit-text-fill-color\\`属性。\n- loading节点的实现禁止使用div标签与边框属性实现，必须使用图标icon的i标签来实现loading的节点\n- 禁止为html标签节点添加动画或过渡效果，页面设计不需要任何动画和过渡效果，比如禁止：@keyframes、transition、animation 等。\n- 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\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\n## 三、必须给每一个节点添加id、name、nodeType属性\n- 特别注意，\\`i\\`和\\`div\\`等标签也必须添加 id、name、nodeType 属性，每一个节点都需要添加这三个属性，千万别漏掉了，这是必要条件\n- id 属性必须只能使用英文或数字组成，且不能以数字开头，并且整个页面 id 属性的值必须唯一，使用驼峰的命名方式\n- name 属性必须是中文或数字，并且不能包含特殊字符\n- nodeType 属性的值必须是\\`组件类型枚举 (nodeType)枚举\\` 中的一个，一些布局容器需要遵守以下说明来选择正确的nodeType：\n  - 列表容器：\\`verticalListView\\`、\\`horizontalListView\\`、\\`listItemCard\\`，用于布局多个列表项，比如：商品列表、分类列表、标签列表等，可以支持多行多列的列表布局\n  - 列表页脚容器：\\`listFooterContainer\\`，用于布局列表的页脚，比如：加载更多、没有更多了等\n  - 网格容器：gridContainer用于布局多个网格项，里面包含N个gridItem，比如：分类网格入口\n  - 流式容器：用于布局多个子项，子项可以在一行显示，当位置不够时就换行显示，比如：一组标签tag的排版布局\n  - 多状态容器：\\`multiStateContainer\\`, \\`oneStateContentContainer\\`，用于不是通过交互，而是通过逻辑状态变量变化而显示不同状态的内容容器，比如：登录状态和未登录状态分别显示不同的内容。\n- 高级组件节点的nodeType结构规则：\n  - tab 选项卡：\\`tabMenuBar\\`是tab选项卡菜单栏，里面包含N个\\`tabMenuBarItem\\`，\\`tabPanelFather\\`是tab选项卡内容容器，里面包含N个\\`tabPanel\\`，\\`tabMenuBar\\`和\\`tabPanelFather\\`必须同时存在，\\`tabPanel\\`的数量必须和\\`tabMenuBarItem\\`的数量相同\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  - 顶部导航栏：\\`topNavigateBar\\`\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\n## 四、轮播与Tabs组件的规则\n- 轮播的每一个Slide和Tabs选项卡组件每一个Tab Panel都必须使用\\`display: none\\`和\\`display: block/flex\\`来实现隐藏和显示的互斥切换\n- 轮播的每一个Slide必须有html代码实现，不得只写第1个Slide的html代码，其他Slide的html代码也必须要写。\n- Tabs选项卡组件每一个Tab Panel都必须有html代码实现，不得只写第1个Tab Panel的html代码，其他Tab Panel的html代码也必须要写。\n\n## 五、图标与图片的规则\n- icon图标必须使用 FontAwesome 图标，比如：\\`<i name=\"微信Icon\" nodeType=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>\\`\n- img图片的src 必须使用图片地址：\\`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- 绝对不能使用 emoji 表情符号，不得使用任何 emoji 表情符号，请使用 icon 或 img 图片节点来代替。\n\n## 六、首页主体页与子页面的规则\n- 首页主体页嵌套了多个子页面，每一个子页面都不需要填充内容，空白就行，后面会有专门的任务来设计具体的子页面。\n- 任何子页面都必须禁止添加底部导航栏节点到页面，因为子页面是嵌套在首页主体页中的，父页面已经有底部导航栏了，子页面不需要再添加底部导航栏，也不得添加二级页面的标题栏到子页面中，因为子页面是嵌套在首页主体页中的，首页主体页和它的子页面都是一级页面，因此不得添加二级页面的标题栏到子页面中。\n\n## 七、如果用户没有明确说明该页面设计需求，那就按照以下页面默认规则设计\n- 闪屏页：尽量不使用全屏图片，一般使用主题相关的渐变色，然后带有一些额外的背景元素增强界面层次感\n- 引导页：尽量不使用全屏图片，一般每一页引导页背景色也可以渐变，然后每一页功能说明一般有非全屏图片、标题、副标题等等，你可以带入其他元素，让页面更加美观。\n`"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bytefun-ai-mcp",
3
- "version": "1.13.66",
3
+ "version": "1.13.68",
4
4
  "description": "ByteFun AI MCP服务 - 打通产品设计、UI设计、代码开发的服务平台,支持设计稿转代码和跨平台原生代码开发",
5
5
  "main": "build/index.js",
6
6
  "type": "module",