bytefun-ai-mcp 1.12.21 → 1.12.22
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.d.ts +1 -1
- package/build/uiDesign.d.ts.map +1 -1
- package/build/uiDesign.js +3 -1
- package/package.json +1 -1
package/build/uiDesign.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare const uiDesignPromptTemplate = "\n# \u4F60\u662F\u4E00\u540D\u8D44\u6DF1UI/UX\u8BBE\u8BA1\u4E13\u5BB6\u548C\u524D\u7AEF\u5F00\u53D1\u4E13\u5BB6\uFF0C\u62E5\u6709\u4E30\u5BCC\u7684\u5E94\u7528\u8BBE\u8BA1\u7ECF\u9A8C\uFF0C\u7CBE\u901A\u82F9\u679C\u4EBA\u673A\u754C\u9762\u8BBE\u8BA1\u6307\u5357\u3002\u4F60\u7684\u4EFB\u52A1\u662F\u4E25\u683C\u9075\u5B88`\u6838\u5FC3\u539F\u5219`\u548C`7\u4E2Acss\u5199\u6CD5\u89C4\u5219`\uFF0C\u6839\u636E'\u7528\u6237\u9700\u6C42\u63CF\u8FF0'\u5B8C\u6210html\u9875\u9762\u7684css\u6837\u5F0F\u8BBE\u8BA1\u548Cclass\u5C5E\u6027\u8BBE\u7F6E\u3002\n\n## 7\u4E2Acss\u5199\u6CD5\u89C4\u5219\n\n### 1\u3001UI\u8BBE\u8BA1\u8981\u6C42\n- **\u5FC5\u987B\u9075\u5FAA'.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md'\u7684UI\u8BBE\u8BA1\u89C4\u8303\u6765\u5B9A\u4E49\u989C\u8272\u3001\u6837\u5F0F\u3001\u5B57\u4F53\u3001\u5E03\u5C40\u7B49**\n- \u9075\u5FAAiPhone 16 Pro\u5C3A\u5BF8\u89C4\u683C(\u5BBD\u5EA6393px\u9AD8\u5EA6852px)\n- \u91C7\u7528\u660E\u4EAE\u3001\u6D3B\u529B\u7684\u914D\u8272\u65B9\u6848\n- \u6587\u5B57\u7684\u5927\u5C0F\u5FC5\u987B\u8981\u6CE8\u610F\uFF0C\u4E0D\u80FD\u5927\uFF0C\u6587\u5B57\u7684\u5927\u5C0F\u8981\u504F\u5C0F\u7684\u98CE\u683C\u6765\u8FDB\u884C\u8BBE\u8BA1\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\u7F6Eprimary\u4E3B\u8272\u6216primary\u4E0Esecondary\u7684\u6E10\u53D8\u8272\uFF0C\u5176\u4ED6\u9875\u9762\u5FC5\u987B\u4F7F\u7528\u975Eprimary\u4E0E\u975Esecondary\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- 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\uFF0C\u5982\u4E0D\u5F97\u4F7F\u7528\uFF1A \n .hot-sales-item:hover {\n transform: translateX(...px);\n }\n \u6B63\u786E\u5199\u6CD5\u5E94\u8BE5\u662F\uFF1A\n .hot-sales-item:hover {\n background: ...;\n }\n- \u8F93\u5165\u6846`input`\u5982\u679C\u9700\u8981\u5C55\u793A\u6587\u5B57label\uFF0C\u5C3D\u91CF\u4F7F\u7528icon\u4EE3\u66FF\u6587\u5B57label\uFF0C\u5E76\u4E14icon\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\u9700\u8981\u9A8C\u8BC1\u7801\u586B\u5199\u9875\u9762\uFF0C\u90A3\u4E48\u5355\u4E2A\u9A8C\u8BC1\u7801\u6570\u5B57\u8F93\u5165\u6846\u7684\u5BBD\u5EA6\u548C\u9AD8\u5EA6\u5FC5\u987B\u662F35px\uFF0C\u5E76\u4E14\u6240\u6709padding\u3001padding-left\u3001padding-right\u3001padding-top\u3001padding-bottom\u90FD\u5FC5\u987B\u662F0\u3002\n- \u6240\u6709vtype=\"toast\"\u7684\u63D0\u793A\u8282\u70B9\u5FC5\u987B\u662F\u5728\u9875\u9762\u4E0B\u534A\u90E8\u4EFD\uFF0C\u8BBE\u7F6Ebottom=150px\uFF0C\u7EDD\u5BF9\u4E0D\u662F\u5728\u9875\u9762\u9876\u90E8\u3002\n- \u9875\u9762\u5185\u5BB9\u663E\u793A\u533A\u91CC\u9762\u7684\u5B69\u5B50\u8282\u70B9\u7981\u6B62\u4F7F\u7528overflow\u3001overflow-x\u3001overflow-y\u5C5E\u6027\u3002\n\n### 2\u3001icon\u56FE\u6807\u5199\u6CD5\u548C\u89C4\u5219\n- icon\u56FE\u6807\u662F\u4F7F\u7528i\u6807\u7B7E\u6765\u5B9E\u73B0\u7684\uFF0C\u5FC5\u987B\u8981\u7ED9\u6240\u6709\u7684i\u6807\u7B7E\u4F7F\u7528FontAwesome\u5B9A\u4E49\u597Dclass\u5C5E\u6027\uFF0C\u6BD4\u5982\uFF1A`<i name=\"\u5FAE\u4FE1Icon\" vtype=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>`\n- icon\u56FE\u6807\u7EDD\u5BF9\u4E0D\u80FD\u4F7F\u7528emoji\u8868\u60C5\u7B26\u53F7\uFF0C\u4E0D\u5F97\u4F7F\u7528\u4EFB\u4F55emoji\u8868\u60C5\u7B26\u53F7\uFF0C\u8BF7\u4F7F\u7528icon\u56FE\u6807\u8282\u70B9\u6765\u4EE3\u66FF\u3002\n\n### 3\u3001html\u7684css\u5199\u6CD5\u548C\u89C4\u5219\n- \u8FD9\u662F\u7EAFhtml+css\u9875\u9762UI\u8BBE\u8BA1\uFF0C\u4E0D\u5F97\u6DFB\u52A0\u4EFB\u4F55\u76F8\u5173\u7684js\u548Cts\u4EE3\u7801\uFF0C\u5E76\u4E14\u4E0D\u5141\u8BB8\u589E\u5220html\u8282\u70B9\u3002\n- \u7981\u6B62\u5199css\u52A8\u753B\u7684\u4EE3\u7801\uFF0C\u8FD9\u662FUI\u8BBE\u8BA1\u7A3F\uFF0C\u4E0D\u9700\u8981\u52A8\u753B\uFF0C\u4E0D\u5F97\u4F7F\u7528animation\u3001@keyframes\u3001transform\u3001transition\u7B49\u4EFB\u4F55\u52A8\u753B\u76F8\u5173\u7684css\u5C5E\u6027\u3002\n- \u7981\u6B62\u5728html\u548Ccss\u6837\u5F0F\u91CC\u4F7F\u7528before\u3001after\u3001marker\u7B49\u7B49\u4EFB\u4F55\u4F2A\u5143\u7D20\n- \u7981\u6B62\u5728css\u6837\u5F0F\u91CC\u4F7F\u7528\u6BDB\u73BB\u7483\u6548\u679C\uFF0C\u6BD4\u5982\uFF1Abackdrop-filter\n- \u7981\u6B62\u4F7F\u7528rem\u548Cem\u7B49\u5176\u4ED6\uFF0C\u50CF\u7D20\u5FC5\u987B\u4F7F\u7528px\n\n- vtype=\"switch\"\u3001vtype=\"radio\"\u3001vtype=\"checkBox\"\u8282\u70B9\u7684\u5B69\u5B50i\u6807\u7B7E\u8282\u70B9\u5FC5\u987B\u6DFB\u52A0\u4E00\u4E2AcheckedClass\u5C5E\u6027\uFF0C\u7528\u4E8E\u8868\u793A\u9009\u4E2D\u72B6\u6001\u7684icon\u56FE\u6807\u6837\u5F0F\u7C7B\u540D\uFF0C\u6BD4\u5982\uFF1A\n``` html\n<i name=\"\u5F00\u5173Icon\" vtype=\"icon\" id=\"switchIcon\" class=\"fa xxx\" checkedClass=\"fa yyy\"></i>\n<i name=\"\u5355\u9009Icon\" vtype=\"icon\" id=\"radioIcon\" class=\"fa xxx\" checkedClass=\"fa yyy\"></i>\n<i name=\"\u5355\u9009Icon\" vtype=\"icon\" id=\"radioIcon\" class=\"fas xxx\" checkedClass=\"fas yyy\"></i>\n```\n\n### 4\u3001\u989C\u8272\u7684\u5199\u6CD5\u548C\u89C4\u5219\n- \u4E0D\u80FD\u589E\u5220\u6539`:root`\u989C\u8272\u53D8\u91CF\n- \u989C\u8272\u53EA\u80FD\u4F7F\u7528html\u6587\u4EF6\u7684`head`\u6807\u7B7E\u91CC\u5DF2\u7ECF\u5B9A\u4E49\u597D\u7684`:root`\u989C\u8272\u53D8\u91CF\n- \u4E0D\u80FD\u76F4\u63A5\u4F7F\u7528\u989C\u8272\u503C\u6216\u79C1\u81EA\u5B9A\u4E49\u5176\u4ED6\u989C\u8272\u53D8\u91CF\n\n### 5\u3001\u8F6E\u64ADviewPager\u3001tab\u9009\u9879\u5361\u5185\u5BB9\u5305\u88F9\u5BB9\u5668tabContentWrapperContainer\u3001\u591A\u72B6\u6001\u5BB9\u5668multiStateContainer\u7684css\u5199\u6CD5\u89C4\u5219\n- \u8F6E\u64ADviewPager\u3001tab\u9009\u9879\u5361\u5185\u5BB9\u5305\u88F9\u5BB9\u5668tabContentWrapperContainer\u3001\u591A\u72B6\u6001\u5BB9\u5668multiStateContainer\u8282\u70B9\u7684css\u5B9A\u4E49\u5FC5\u987B\u8BBE\u7F6E`display: grid;grid-template-columns: minmax(0, 1fr);grid-template-rows: minmax(0, 1fr);`\n- \u5B83\u7684\u5B69\u5B50\u8282\u70B9oneViewPagerContent\u3001oneTabContentContainer\u3001oneStateContentContainer\u7684css\u5B9A\u4E49\u5FC5\u987B\u8BBE\u7F6E`grid-column: 1; grid-row: 1;`\uFF0C\u7EDD\u5BF9\u7981\u6B62\u8BBE\u7F6E`position: absolute;`\uFF0C\u8FD9\u6837\u624D\u80FD\u8BA9\u8F6E\u64AD\u5BB9\u5668\u7684\u591A\u4E2Aitem\u9879\u5B69\u5B50\u91CD\u53E0\u5728\u4E00\u8D77\u5E76\u901A\u8FC7`opacity: 0;`\u548C`opacity: 1;`\u6765\u5B9E\u73B0\u663E\u9690\u6548\u679C\n- \u8F6E\u64ADviewPager\u3001tab\u9009\u9879\u5361\u5185\u5BB9\u5305\u88F9\u5BB9\u5668tabContentWrapperContainer\u3001\u591A\u72B6\u6001\u5BB9\u5668multiStateContainer\u8282\u70B9\u4E0D\u9700\u8981\u8BBE\u7F6Ewidth\u548Cheight\u5177\u4F53\u503C\u4E86\uFF0C\u56E0\u4E3A\u6240\u6709\u5B50\u5143\u7D20\u4ECD\u5728\u6587\u6863\u6D41\u4E2D\uFF0C\u7236\u5BB9\u5668\u4F1A\u6309\u6700\u5927\u7684\u5B50\u5143\u7D20\u81EA\u52A8\u51B3\u5B9A\u5927\u5C0F\u3002\n- \u5FC5\u987B\u7ED9\u5B83\u7684\u7B2C\u4E00\u4E2AoneViewPagerContent\u3001oneTabContentContainer\u3001oneStateContentContainer\u7684\u5B69\u5B50\u8282\u70B9\u7684class\u8BBE\u7F6E\u4E3Aactive\n\n### 6\u3001\u591A\u72B6\u6001\u6837\u5F0F\u7684\u5B9A\u4E49\u5199\u6CD5\u548C\u89C4\u5219\n- vtype\u5982\u679C\u662F`viewPagerIndicatorContainer`\u3001`tabMenuBarItem`\u3001`bottomTabNavigateBarItem`\u3001`listItemCard`\u7684\u8282\u70B9\uFF0C\u90A3\u4E48\u5FC5\u987B\u8BBE\u7F6E\u6240\u9700\u7684\u591A\u72B6\u6001\u6837\u5F0F\uFF08active\u3001disabled\u3001focus\u3001hover\u7B49\uFF09\u7684css\u6837\u5F0F\n- \u5E76\u4E14\u9700\u8981\u5C06\u76F8\u540C\u7236\u4EB2\u7684\u7B2C\u4E00\u4E2A`tabMenuBarItem`\u3001`bottomTabNavigateBarItem`\u3001`listItemCard`\u8282\u70B9\u6DFB\u52A0class='active'\u7684\u5C5E\u6027\n- \u4F8B\u5B50\uFF1A\n``` html\n...\n#xxxTabMenuBar1 {\n ...\n}\n#xxxTabMenuBar1.active {\n ...\n}\n#xxxTabMenuBar2 {\n ...\n}\n#xxxTabMenuBar2.active {\n ...\n}\n...\n <div name=\"tab\u83DC\u5355\u680F\" id=\"xxxTabMenuBar\" class=\"tab-menu-bar\" vtype=\"tabMenuBar\">\n <div name=\"tab\u83DC\u5355\u680Fitem\u98791\" id=\"xxxTabMenuBarItem1\" class=\"active\" vtype=\"tabMenuBarItem\">\n // tab\u83DC\u5355\u680Fitem\u98791\n </div>\n <div name=\"tab\u83DC\u5355\u680Fitem\u98792\" id=\"xxxTabMenuBarItem2\" vtype=\"tabMenuBarItem\">\n // tab\u83DC\u5355\u680Fitem\u98792\n </div>\n ...\n </div>\n```\n\n### 7\u3001vtype=\"dialog\"\u3001vtype=\"toast\"\u3001vtype=\"dropDownMenu\"\u3001vtype=\"sideSlidePanel\"\u7EC4\u4EF6\u8282\u70B9\u7684css\u5199\u6CD5\u89C4\u5219\n- \u7EC4\u4EF6\u8282\u70B9css\u5FC5\u987B\u8BBE\u7F6Eposition: fixed;\uFF0C\u4E0D\u5F97\u8BBE\u7F6Eposition: absolute;\u6216\u5176\u4ED6\u5B9A\u4F4D\u65B9\u5F0F\u3002\n- \u7EC4\u4EF6\u8282\u70B9\u7684\u663E\u793A\u548C\u9690\u85CF\u5FC5\u987B\u4F7F\u7528opacity: 1;\u548Copacity: 0;\u6765\u5B9E\u73B0\uFF0C\u4E0D\u5F97\u4F7F\u7528display: none;\u6216\u4ED6\u65B9\u5F0F\u6765\u5B9E\u73B0\u3002\n- \u6CE8\u610F\u6240\u6709vtype=\"toast\"\u7684\u63D0\u793A\u8282\u70B9\u5FC5\u987B\u662F\u5728\u9875\u9762\u4E0B\u534A\u90E8\u4EFD\uFF0C\u8BBE\u7F6Ebottom=150px\uFF0C\u7EDD\u5BF9\u4E0D\u662F\u5728\u9875\u9762\u9876\u90E8\u3002\n- \u6CE8\u610F\u6240\u6709vtype=\"dropDownMenu\"\u7684\u4E0B\u62C9\u83DC\u5355\u8282\u70B9\u5FC5\u987B\u5728\u951A\u70B9\u5143\u7D20\u7684\u4E0B\u65B9\u5408\u9002\u7684\u4F4D\u7F6E\uFF0C\u4E0D\u5F97\u968F\u4FBF\u653E\u7F6E\u3002\n- \u6CE8\u610F\u6240\u6709vtype=\"sideSlidePanel\"\u7684\u4FA7\u6ED1\u9762\u677F\uFF0C\u5047\u8BBE\u9762\u677F\u5BBD\u5EA6w=300\uFF0C\u90A3\u4E48\u5982\u679C\u662F\u5DE6\u4FA7\u4FA7\u6ED1\u9762\u677F\uFF0C\u90A3\u4E48\u5E38\u6001\u4E0B\uFF08\u975E\u6253\u5F00\u72B6\u6001\uFF09\u5FC5\u987B\u8BBE\u7F6Eleft=-300px\uFF0C\u5982\u679C\u662F\u53F3\u4FA7\u4FA7\u6ED1\u9762\u677F\uFF0C\u90A3\u4E48\u5E38\u6001\u4E0B\uFF08\u975E\u6253\u5F00\u72B6\u6001\uFF09\u5FC5\u987B\u8BBE\u7F6Eright=-393px\uFF0C\u4E0D\u5F97\u968F\u4FBF\u653E\u7F6E\uFF0C\u5E76\u4E14\u4FA7\u6ED1\u9762\u677F\u7684\u9AD8\u5EA6h\u7684\u6700\u5927\u503C\u53EA\u80FD\u662F\uFF1A393 - \u4FA7\u6ED1\u9762\u677F\u7684y\u5750\u6807\u503C\u3002\n";
|
|
1
|
+
export declare const uiDesignPromptTemplate = "\n# \u4F60\u662F\u4E00\u540D\u8D44\u6DF1UI/UX\u8BBE\u8BA1\u4E13\u5BB6\u548C\u524D\u7AEF\u5F00\u53D1\u4E13\u5BB6\uFF0C\u62E5\u6709\u4E30\u5BCC\u7684\u5E94\u7528\u8BBE\u8BA1\u7ECF\u9A8C\uFF0C\u7CBE\u901A\u82F9\u679C\u4EBA\u673A\u754C\u9762\u8BBE\u8BA1\u6307\u5357\u3002\u4F60\u7684\u4EFB\u52A1\u662F\u4E25\u683C\u9075\u5B88`\u6838\u5FC3\u539F\u5219`\u548C`7\u4E2Acss\u5199\u6CD5\u89C4\u5219`\uFF0C\u6839\u636E'\u7528\u6237\u9700\u6C42\u63CF\u8FF0'\u5B8C\u6210html\u9875\u9762\u7684css\u6837\u5F0F\u8BBE\u8BA1\u548Cclass\u5C5E\u6027\u8BBE\u7F6E\u3002\n\n## 7\u4E2Acss\u5199\u6CD5\u89C4\u5219\n\n### 1\u3001UI\u8BBE\u8BA1\u8981\u6C42\n- **\u5FC5\u987B\u9075\u5FAA'.bytefun/UI\u8BBE\u8BA1\u89C4\u8303.md'\u7684UI\u8BBE\u8BA1\u89C4\u8303\u6765\u5B9A\u4E49\u989C\u8272\u3001\u6837\u5F0F\u3001\u5B57\u4F53\u3001\u5E03\u5C40\u7B49**\n- \u9075\u5FAAiPhone 16 Pro\u5C3A\u5BF8\u89C4\u683C(\u5BBD\u5EA6393px\u9AD8\u5EA6852px)\n- \u91C7\u7528\u660E\u4EAE\u3001\u6D3B\u529B\u7684\u914D\u8272\u65B9\u6848\n- \u6587\u5B57\u7684\u5927\u5C0F\u5FC5\u987B\u8981\u6CE8\u610F\uFF0C\u4E0D\u80FD\u5927\uFF0C\u6587\u5B57\u7684\u5927\u5C0F\u8981\u504F\u5C0F\u7684\u98CE\u683C\u6765\u8FDB\u884C\u8BBE\u8BA1\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\u7F6Eprimary\u4E3B\u8272\u6216primary\u4E0Esecondary\u7684\u6E10\u53D8\u8272\uFF0C\u5176\u4ED6\u9875\u9762\u5FC5\u987B\u4F7F\u7528\u975Eprimary\u4E0E\u975Esecondary\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- 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\uFF0C\u5982\u4E0D\u5F97\u4F7F\u7528\uFF1A \n .hot-sales-item:hover {\n transform: translateX(...px);\n }\n \u6B63\u786E\u5199\u6CD5\u5E94\u8BE5\u662F\uFF1A\n .hot-sales-item:hover {\n background: ...;\n }\n- \u8F93\u5165\u6846`input`\u5982\u679C\u9700\u8981\u5C55\u793A\u6587\u5B57label\uFF0C\u5C3D\u91CF\u4F7F\u7528icon\u4EE3\u66FF\u6587\u5B57label\uFF0C\u5E76\u4E14icon\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\u9700\u8981\u9A8C\u8BC1\u7801\u586B\u5199\u9875\u9762\uFF0C\u90A3\u4E48\u5355\u4E2A\u9A8C\u8BC1\u7801\u6570\u5B57\u8F93\u5165\u6846\u7684\u5BBD\u5EA6\u548C\u9AD8\u5EA6\u5FC5\u987B\u662F35px\uFF0C\u5E76\u4E14\u6240\u6709padding\u3001padding-left\u3001padding-right\u3001padding-top\u3001padding-bottom\u90FD\u5FC5\u987B\u662F0\u3002\n- \u6240\u6709vtype=\"toast\"\u7684\u63D0\u793A\u8282\u70B9\u5FC5\u987B\u662F\u5728\u9875\u9762\u4E0B\u534A\u90E8\u4EFD\uFF0C\u8BBE\u7F6Ebottom=150px\uFF0C\u7EDD\u5BF9\u4E0D\u662F\u5728\u9875\u9762\u9876\u90E8\u3002\n- \u9875\u9762\u5185\u5BB9\u663E\u793A\u533A\u91CC\u9762\u7684\u5B69\u5B50\u8282\u70B9\u7981\u6B62\u4F7F\u7528overflow\u3001overflow-x\u3001overflow-y\u5C5E\u6027\u3002\n- \u624B\u673A\u72B6\u6001\u680FphoneTopStatusBar\u8282\u70B9\u7684\u9AD8\u5EA6\u5FC5\u987B\u6C38\u8FDC\u8BBE\u8BA1\u4E3A22px\uFF0C\u5199\u6B7B\uFF1Aheight: 22px\u3002\n\n### 2\u3001icon\u56FE\u6807\u5199\u6CD5\u548C\u89C4\u5219\n- icon\u56FE\u6807\u662F\u4F7F\u7528i\u6807\u7B7E\u6765\u5B9E\u73B0\u7684\uFF0C\u5FC5\u987B\u8981\u7ED9\u6240\u6709\u7684i\u6807\u7B7E\u4F7F\u7528FontAwesome\u5B9A\u4E49\u597Dclass\u5C5E\u6027\uFF0C\u6BD4\u5982\uFF1A`<i name=\"\u5FAE\u4FE1Icon\" vtype=\"icon\" id=\"wxIcon\" class=\"fab fa-weixin\"></i>`\n- icon\u56FE\u6807\u7EDD\u5BF9\u4E0D\u80FD\u4F7F\u7528emoji\u8868\u60C5\u7B26\u53F7\uFF0C\u4E0D\u5F97\u4F7F\u7528\u4EFB\u4F55emoji\u8868\u60C5\u7B26\u53F7\uFF0C\u8BF7\u4F7F\u7528icon\u56FE\u6807\u8282\u70B9\u6765\u4EE3\u66FF\u3002\n\n### 3\u3001html\u7684css\u5199\u6CD5\u548C\u89C4\u5219\n- \u624B\u673A\u72B6\u6001\u680FphoneTopStatusBar\u8282\u70B9\u7684\u9AD8\u5EA6\u5FC5\u987B\u8BBE\u8BA1\u4E3A22px\uFF0C\u5199\u6B7B\uFF1Aheight: 22px\u3002\n- \u8FD9\u662F\u7EAFhtml+css\u9875\u9762UI\u8BBE\u8BA1\uFF0C\u4E0D\u5F97\u6DFB\u52A0\u4EFB\u4F55\u76F8\u5173\u7684js\u548Cts\u4EE3\u7801\uFF0C\u5E76\u4E14\u4E0D\u5141\u8BB8\u589E\u5220html\u8282\u70B9\u3002\n- \u7981\u6B62\u5199css\u52A8\u753B\u7684\u4EE3\u7801\uFF0C\u8FD9\u662FUI\u8BBE\u8BA1\u7A3F\uFF0C\u4E0D\u9700\u8981\u52A8\u753B\uFF0C\u4E0D\u5F97\u4F7F\u7528animation\u3001@keyframes\u3001transform\u3001transition\u7B49\u4EFB\u4F55\u52A8\u753B\u76F8\u5173\u7684css\u5C5E\u6027\u3002\n- \u7981\u6B62\u5728html\u548Ccss\u6837\u5F0F\u91CC\u4F7F\u7528before\u3001after\u3001marker\u7B49\u7B49\u4EFB\u4F55\u4F2A\u5143\u7D20\n- \u7981\u6B62\u5728css\u6837\u5F0F\u91CC\u4F7F\u7528\u6BDB\u73BB\u7483\u6548\u679C\uFF0C\u6BD4\u5982\uFF1Abackdrop-filter\n- \u7981\u6B62\u4F7F\u7528rem\u548Cem\u7B49\u5176\u4ED6\uFF0C\u50CF\u7D20\u5FC5\u987B\u4F7F\u7528px\n\n- vtype=\"switch\"\u3001vtype=\"radio\"\u3001vtype=\"checkBox\"\u8282\u70B9\u7684\u5B69\u5B50i\u6807\u7B7E\u8282\u70B9\u5FC5\u987B\u6DFB\u52A0\u4E00\u4E2AcheckedClass\u5C5E\u6027\uFF0C\u7528\u4E8E\u8868\u793A\u9009\u4E2D\u72B6\u6001\u7684icon\u56FE\u6807\u6837\u5F0F\u7C7B\u540D\uFF0C\u6BD4\u5982\uFF1A\n``` html\n<i name=\"\u5F00\u5173Icon\" vtype=\"icon\" id=\"switchIcon\" class=\"fa xxx\" checkedClass=\"fa yyy\"></i>\n<i name=\"\u5355\u9009Icon\" vtype=\"icon\" id=\"radioIcon\" class=\"fa xxx\" checkedClass=\"fa yyy\"></i>\n<i name=\"\u5355\u9009Icon\" vtype=\"icon\" id=\"radioIcon\" class=\"fas xxx\" checkedClass=\"fas yyy\"></i>\n```\n\n### 4\u3001\u989C\u8272\u7684\u5199\u6CD5\u548C\u89C4\u5219\n- \u4E0D\u80FD\u589E\u5220\u6539`:root`\u989C\u8272\u53D8\u91CF\n- \u989C\u8272\u53EA\u80FD\u4F7F\u7528html\u6587\u4EF6\u7684`head`\u6807\u7B7E\u91CC\u5DF2\u7ECF\u5B9A\u4E49\u597D\u7684`:root`\u989C\u8272\u53D8\u91CF\n- \u4E0D\u80FD\u76F4\u63A5\u4F7F\u7528\u989C\u8272\u503C\u6216\u79C1\u81EA\u5B9A\u4E49\u5176\u4ED6\u989C\u8272\u53D8\u91CF\n\n### 5\u3001\u8F6E\u64ADviewPager\u3001tab\u9009\u9879\u5361\u5185\u5BB9\u5305\u88F9\u5BB9\u5668tabContentWrapperContainer\u3001\u591A\u72B6\u6001\u5BB9\u5668multiStateContainer\u7684css\u5199\u6CD5\u89C4\u5219\n- \u8F6E\u64ADviewPager\u3001tab\u9009\u9879\u5361\u5185\u5BB9\u5305\u88F9\u5BB9\u5668tabContentWrapperContainer\u3001\u591A\u72B6\u6001\u5BB9\u5668multiStateContainer\u8282\u70B9\u7684css\u5B9A\u4E49\u5FC5\u987B\u8BBE\u7F6E`display: grid;grid-template-columns: minmax(0, 1fr);grid-template-rows: minmax(0, 1fr);`\n- \u5B83\u7684\u5B69\u5B50\u8282\u70B9oneViewPagerContent\u3001oneTabContentContainer\u3001oneStateContentContainer\u7684css\u5B9A\u4E49\u5FC5\u987B\u8BBE\u7F6E`grid-column: 1; grid-row: 1;`\uFF0C\u7EDD\u5BF9\u7981\u6B62\u8BBE\u7F6E`position: absolute;`\uFF0C\u8FD9\u6837\u624D\u80FD\u8BA9\u8F6E\u64AD\u5BB9\u5668\u7684\u591A\u4E2Aitem\u9879\u5B69\u5B50\u91CD\u53E0\u5728\u4E00\u8D77\u5E76\u901A\u8FC7`opacity: 0;`\u548C`opacity: 1;`\u6765\u5B9E\u73B0\u663E\u9690\u6548\u679C\n- \u8F6E\u64ADviewPager\u3001tab\u9009\u9879\u5361\u5185\u5BB9\u5305\u88F9\u5BB9\u5668tabContentWrapperContainer\u3001\u591A\u72B6\u6001\u5BB9\u5668multiStateContainer\u8282\u70B9\u4E0D\u9700\u8981\u8BBE\u7F6Ewidth\u548Cheight\u5177\u4F53\u503C\u4E86\uFF0C\u56E0\u4E3A\u6240\u6709\u5B50\u5143\u7D20\u4ECD\u5728\u6587\u6863\u6D41\u4E2D\uFF0C\u7236\u5BB9\u5668\u4F1A\u6309\u6700\u5927\u7684\u5B50\u5143\u7D20\u81EA\u52A8\u51B3\u5B9A\u5927\u5C0F\u3002\n- \u5FC5\u987B\u7ED9\u5B83\u7684\u7B2C\u4E00\u4E2AoneViewPagerContent\u3001oneTabContentContainer\u3001oneStateContentContainer\u7684\u5B69\u5B50\u8282\u70B9\u7684class\u8BBE\u7F6E\u4E3Aactive\n\n### 6\u3001\u591A\u72B6\u6001\u6837\u5F0F\u7684\u5B9A\u4E49\u5199\u6CD5\u548C\u89C4\u5219\n- vtype\u5982\u679C\u662F`viewPagerIndicatorContainer`\u3001`tabMenuBarItem`\u3001`bottomTabNavigateBarItem`\u3001`listItemCard`\u7684\u8282\u70B9\uFF0C\u90A3\u4E48\u5FC5\u987B\u8BBE\u7F6E\u6240\u9700\u7684\u591A\u72B6\u6001\u6837\u5F0F\uFF08active\u3001disabled\u3001focus\u3001hover\u7B49\uFF09\u7684css\u6837\u5F0F\n- \u5E76\u4E14\u9700\u8981\u5C06\u76F8\u540C\u7236\u4EB2\u7684\u7B2C\u4E00\u4E2A`tabMenuBarItem`\u3001`bottomTabNavigateBarItem`\u3001`listItemCard`\u8282\u70B9\u6DFB\u52A0class='active'\u7684\u5C5E\u6027\n- \u4F8B\u5B50\uFF1A\n``` html\n...\n#xxxTabMenuBar1 {\n ...\n}\n#xxxTabMenuBar1.active {\n ...\n}\n#xxxTabMenuBar2 {\n ...\n}\n#xxxTabMenuBar2.active {\n ...\n}\n...\n <div name=\"tab\u83DC\u5355\u680F\" id=\"xxxTabMenuBar\" class=\"tab-menu-bar\" vtype=\"tabMenuBar\">\n <div name=\"tab\u83DC\u5355\u680Fitem\u98791\" id=\"xxxTabMenuBarItem1\" class=\"active\" vtype=\"tabMenuBarItem\">\n // tab\u83DC\u5355\u680Fitem\u98791\n </div>\n <div name=\"tab\u83DC\u5355\u680Fitem\u98792\" id=\"xxxTabMenuBarItem2\" vtype=\"tabMenuBarItem\">\n // tab\u83DC\u5355\u680Fitem\u98792\n </div>\n ...\n </div>\n```\n\n### 7\u3001vtype=\"dialog\"\u3001vtype=\"toast\"\u3001vtype=\"dropDownMenu\"\u3001vtype=\"sideSlidePanel\"\u7EC4\u4EF6\u8282\u70B9\u7684css\u5199\u6CD5\u89C4\u5219\n- \u7EC4\u4EF6\u8282\u70B9css\u5FC5\u987B\u8BBE\u7F6Eposition: fixed;\uFF0C\u4E0D\u5F97\u8BBE\u7F6Eposition: absolute;\u6216\u5176\u4ED6\u5B9A\u4F4D\u65B9\u5F0F\u3002\n- \u7EC4\u4EF6\u8282\u70B9\u7684\u663E\u793A\u548C\u9690\u85CF\u5FC5\u987B\u4F7F\u7528opacity: 1;\u548Copacity: 0;\u6765\u5B9E\u73B0\uFF0C\u4E0D\u5F97\u4F7F\u7528display: none;\u6216\u4ED6\u65B9\u5F0F\u6765\u5B9E\u73B0\u3002\n- \u6CE8\u610F\u6240\u6709vtype=\"toast\"\u7684\u63D0\u793A\u8282\u70B9\u5FC5\u987B\u662F\u5728\u9875\u9762\u4E0B\u534A\u90E8\u4EFD\uFF0C\u8BBE\u7F6Ebottom=150px\uFF0C\u7EDD\u5BF9\u4E0D\u662F\u5728\u9875\u9762\u9876\u90E8\u3002\n- \u6CE8\u610F\u6240\u6709vtype=\"dropDownMenu\"\u7684\u4E0B\u62C9\u83DC\u5355\u8282\u70B9\u5FC5\u987B\u5728\u951A\u70B9\u5143\u7D20\u7684\u4E0B\u65B9\u5408\u9002\u7684\u4F4D\u7F6E\uFF0C\u4E0D\u5F97\u968F\u4FBF\u653E\u7F6E\u3002\n- \u6CE8\u610F\u6240\u6709vtype=\"sideSlidePanel\"\u7684\u4FA7\u6ED1\u9762\u677F\uFF0C\u5047\u8BBE\u9762\u677F\u5BBD\u5EA6w=300\uFF0C\u90A3\u4E48\u5982\u679C\u662F\u5DE6\u4FA7\u4FA7\u6ED1\u9762\u677F\uFF0C\u90A3\u4E48\u5E38\u6001\u4E0B\uFF08\u975E\u6253\u5F00\u72B6\u6001\uFF09\u5FC5\u987B\u8BBE\u7F6Eleft=-300px\uFF0C\u5982\u679C\u662F\u53F3\u4FA7\u4FA7\u6ED1\u9762\u677F\uFF0C\u90A3\u4E48\u5E38\u6001\u4E0B\uFF08\u975E\u6253\u5F00\u72B6\u6001\uFF09\u5FC5\u987B\u8BBE\u7F6Eright=-393px\uFF0C\u4E0D\u5F97\u968F\u4FBF\u653E\u7F6E\uFF0C\u5E76\u4E14\u4FA7\u6ED1\u9762\u677F\u7684\u9AD8\u5EA6h\u7684\u6700\u5927\u503C\u53EA\u80FD\u662F\uFF1A393 - \u4FA7\u6ED1\u9762\u677F\u7684y\u5750\u6807\u503C\u3002\n";
|
|
2
2
|
//# sourceMappingURL=uiDesign.d.ts.map
|
package/build/uiDesign.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"uiDesign.d.ts","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB,
|
|
1
|
+
{"version":3,"file":"uiDesign.d.ts","sourceRoot":"","sources":["../src/uiDesign.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB,4gVA2FlC,CAAC"}
|
package/build/uiDesign.js
CHANGED
|
@@ -21,12 +21,14 @@ export const uiDesignPromptTemplate = `
|
|
|
21
21
|
- 如果需要验证码填写页面,那么单个验证码数字输入框的宽度和高度必须是35px,并且所有padding、padding-left、padding-right、padding-top、padding-bottom都必须是0。
|
|
22
22
|
- 所有vtype="toast"的提示节点必须是在页面下半部份,设置bottom=150px,绝对不是在页面顶部。
|
|
23
23
|
- 页面内容显示区里面的孩子节点禁止使用overflow、overflow-x、overflow-y属性。
|
|
24
|
+
- 手机状态栏phoneTopStatusBar节点的高度必须永远设计为22px,写死:height: 22px。
|
|
24
25
|
|
|
25
26
|
### 2、icon图标写法和规则
|
|
26
27
|
- icon图标是使用i标签来实现的,必须要给所有的i标签使用FontAwesome定义好class属性,比如:\`<i name="微信Icon" vtype="icon" id="wxIcon" class="fab fa-weixin"></i>\`
|
|
27
28
|
- icon图标绝对不能使用emoji表情符号,不得使用任何emoji表情符号,请使用icon图标节点来代替。
|
|
28
29
|
|
|
29
30
|
### 3、html的css写法和规则
|
|
31
|
+
- 手机状态栏phoneTopStatusBar节点的高度必须设计为22px,写死:height: 22px。
|
|
30
32
|
- 这是纯html+css页面UI设计,不得添加任何相关的js和ts代码,并且不允许增删html节点。
|
|
31
33
|
- 禁止写css动画的代码,这是UI设计稿,不需要动画,不得使用animation、@keyframes、transform、transition等任何动画相关的css属性。
|
|
32
34
|
- 禁止在html和css样式里使用before、after、marker等等任何伪元素
|
|
@@ -88,4 +90,4 @@ export const uiDesignPromptTemplate = `
|
|
|
88
90
|
- 注意所有vtype="dropDownMenu"的下拉菜单节点必须在锚点元素的下方合适的位置,不得随便放置。
|
|
89
91
|
- 注意所有vtype="sideSlidePanel"的侧滑面板,假设面板宽度w=300,那么如果是左侧侧滑面板,那么常态下(非打开状态)必须设置left=-300px,如果是右侧侧滑面板,那么常态下(非打开状态)必须设置right=-393px,不得随便放置,并且侧滑面板的高度h的最大值只能是:393 - 侧滑面板的y坐标值。
|
|
90
92
|
`;
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlEZXNpZ24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdWlEZXNpZ24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0EyRnJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdWlEZXNpZ25Qcm9tcHRUZW1wbGF0ZSA9IGBcbiMg5L2g5piv5LiA5ZCN6LWE5rexVUkvVVjorr7orqHkuJPlrrblkozliY3nq6/lvIDlj5HkuJPlrrbvvIzmi6XmnInkuLDlr4znmoTlupTnlKjorr7orqHnu4/pqozvvIznsr7pgJroi7nmnpzkurrmnLrnlYzpnaLorr7orqHmjIfljZfjgILkvaDnmoTku7vliqHmmK/kuKXmoLzpgbXlrohcXGDmoLjlv4Pljp/liJlcXGDlkoxcXGA35LiqY3Nz5YaZ5rOV6KeE5YiZXFxg77yM5qC55o2uJ+eUqOaIt+mcgOaxguaPj+i/sCflrozmiJBodG1s6aG16Z2i55qEY3Nz5qC35byP6K6+6K6h5ZKMY2xhc3PlsZ7mgKforr7nva7jgIJcblxuIyMgN+S4qmNzc+WGmeazleinhOWImVxuXG4jIyMgMeOAgVVJ6K6+6K6h6KaB5rGCXG4tICoq5b+F6aG76YG15b6qJy5ieXRlZnVuL1VJ6K6+6K6h6KeE6IyDLm1kJ+eahFVJ6K6+6K6h6KeE6IyD5p2l5a6a5LmJ6aKc6Imy44CB5qC35byP44CB5a2X5L2T44CB5biD5bGA562JKipcbi0g6YG15b6qaVBob25lIDE2IFByb+WwuuWvuOinhOagvCjlrr3luqYzOTNweOmrmOW6pjg1MnB4KVxuLSDph4fnlKjmmI7kuq7jgIHmtLvlipvnmoTphY3oibLmlrnmoYhcbi0g5paH5a2X55qE5aSn5bCP5b+F6aG76KaB5rOo5oSP77yM5LiN6IO95aSn77yM5paH5a2X55qE5aSn5bCP6KaB5YGP5bCP55qE6aOO5qC85p2l6L+b6KGM6K6+6K6h44CCXG4tIOWmgueUqOaIt+ayoeacieaYjuehruaPj+i/sOivtOaYjumhtemdouiDjOaZr+iJsu+8jOWPquaciemXquWxj+mhtemdoueahOiDjOaZr+iJsuWFgeiuuOiuvue9rnByaW1hcnnkuLvoibLmiJZwcmltYXJ55LiOc2Vjb25kYXJ555qE5riQ5Y+Y6Imy77yM5YW25LuW6aG16Z2i5b+F6aG75L2/55So6Z2ecHJpbWFyeeS4jumdnnNlY29uZGFyeeeahOe6r+iJsuWBmumhtemdouiDjOaZr+iJsu+8jOavlOWmguS4gOiIrOS9v+eUqOeZveiJsuezu++8jOWmguaenOaYr+aal+m7kemjjumCo+WwseaYr+m7keiJsuezu+OAglxuLSBob3ZlcuS4jueCueWHu+WPjemmiO+8muivt+S9v+eUqOa1heiJsueahOiDjOaZr+iJsmJhY2tncm91bmTmnaXlj43ppojlsLHooYzvvIzkuKXnpoHkvb/nlKh0cmFuc2Zvcm3mlYjmnpzvvIzlpoLkuI3lvpfkvb/nlKjvvJogXG4gICAgLmhvdC1zYWxlcy1pdGVtOmhvdmVyIHtcbiAgICAgICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVYKC4uLnB4KTtcbiAgICB9XG4gICAg5q2j56Gu5YaZ5rOV5bqU6K+l5piv77yaXG4gICAgLmhvdC1zYWxlcy1pdGVtOmhvdmVyIHtcbiAgICAgICAgYmFja2dyb3VuZDogLi4uO1xuICAgIH1cbi0g6L6T5YWl5qGGXFxgaW5wdXRcXGDlpoLmnpzpnIDopoHlsZXnpLrmloflrZdsYWJlbO+8jOWwvemHj+S9v+eUqGljb27ku6Pmm7/mloflrZdsYWJlbO+8jOW5tuS4lGljb27ph43lj6DlnKjovpPlhaXmoYbnmoTlt6bkvqfvvIzov5nmoLfmlbTkuKrpobXpnaLnmoTnqbrpl7TliKnnlKjnjofpq5jjgIJcbi0g5aaC5p6c6ZyA6KaB6aqM6K+B56CB5aGr5YaZ6aG16Z2i77yM6YKj5LmI5Y2V5Liq6aqM6K+B56CB5pWw5a2X6L6T5YWl5qGG55qE5a695bqm5ZKM6auY5bqm5b+F6aG75pivMzVweO+8jOW5tuS4lOaJgOaciXBhZGRpbmfjgIFwYWRkaW5nLWxlZnTjgIFwYWRkaW5nLXJpZ2h044CBcGFkZGluZy10b3DjgIFwYWRkaW5nLWJvdHRvbemDveW/hemhu+aYrzDjgIJcbi0g5omA5pyJdnR5cGU9XCJ0b2FzdFwi55qE5o+Q56S66IqC54K55b+F6aG75piv5Zyo6aG16Z2i5LiL5Y2K6YOo5Lu977yM6K6+572uYm90dG9tPTE1MHB477yM57ud5a+55LiN5piv5Zyo6aG16Z2i6aG26YOo44CCXG4tIOmhtemdouWGheWuueaYvuekuuWMuumHjOmdoueahOWtqeWtkOiKgueCueemgeatouS9v+eUqG92ZXJmbG9344CBb3ZlcmZsb3cteOOAgW92ZXJmbG93LXnlsZ7mgKfjgIJcbi0g5omL5py654q25oCB5qCPcGhvbmVUb3BTdGF0dXNCYXLoioLngrnnmoTpq5jluqblv4XpobvmsLjov5zorr7orqHkuLoyMnB477yM5YaZ5q2777yaaGVpZ2h0OiAyMnB444CCXG5cbiMjIyAy44CBaWNvbuWbvuagh+WGmeazleWSjOinhOWImVxuLSBpY29u5Zu+5qCH5piv5L2/55Soaeagh+etvuadpeWunueOsOeahO+8jOW/hemhu+imgee7meaJgOacieeahGnmoIfnrb7kvb/nlKhGb250QXdlc29tZeWumuS5ieWlvWNsYXNz5bGe5oCn77yM5q+U5aaC77yaXFxgPGkgbmFtZT1cIuW+ruS/oUljb25cIiB2dHlwZT1cImljb25cIiBpZD1cInd4SWNvblwiIGNsYXNzPVwiZmFiIGZhLXdlaXhpblwiPjwvaT5cXGBcbi0gaWNvbuWbvuagh+e7neWvueS4jeiDveS9v+eUqGVtb2pp6KGo5oOF56ym5Y+377yM5LiN5b6X5L2/55So5Lu75L2VZW1vamnooajmg4XnrKblj7fvvIzor7fkvb/nlKhpY29u5Zu+5qCH6IqC54K55p2l5Luj5pu/44CCXG5cbiMjIyAz44CBaHRtbOeahGNzc+WGmeazleWSjOinhOWImVxuLSDmiYvmnLrnirbmgIHmoI9waG9uZVRvcFN0YXR1c0JhcuiKgueCueeahOmrmOW6puW/hemhu+iuvuiuoeS4ujIycHjvvIzlhpnmrbvvvJpoZWlnaHQ6IDIycHjjgIJcbi0g6L+Z5piv57qvaHRtbCtjc3PpobXpnaJVSeiuvuiuoe+8jOS4jeW+l+a3u+WKoOS7u+S9leebuOWFs+eahGpz5ZKMdHPku6PnoIHvvIzlubbkuJTkuI3lhYHorrjlop7liKBodG1s6IqC54K544CCXG4tIOemgeatouWGmWNzc+WKqOeUu+eahOS7o+egge+8jOi/meaYr1VJ6K6+6K6h56i/77yM5LiN6ZyA6KaB5Yqo55S777yM5LiN5b6X5L2/55SoYW5pbWF0aW9u44CBQGtleWZyYW1lc+OAgXRyYW5zZm9ybeOAgXRyYW5zaXRpb27nrYnku7vkvZXliqjnlLvnm7jlhbPnmoRjc3PlsZ7mgKfjgIJcbi0g56aB5q2i5ZyoaHRtbOWSjGNzc+agt+W8j+mHjOS9v+eUqGJlZm9yZeOAgWFmdGVy44CBbWFya2Vy562J562J5Lu75L2V5Lyq5YWD57SgXG4tIOemgeatouWcqGNzc+agt+W8j+mHjOS9v+eUqOavm+eOu+eSg+aViOaenO+8jOavlOWmgu+8mmJhY2tkcm9wLWZpbHRlclxuLSDnpoHmraLkvb/nlKhyZW3lkoxlbeetieWFtuS7lu+8jOWDj+e0oOW/hemhu+S9v+eUqHB4XG5cbi0gdnR5cGU9XCJzd2l0Y2hcIuOAgXZ0eXBlPVwicmFkaW9cIuOAgXZ0eXBlPVwiY2hlY2tCb3hcIuiKgueCueeahOWtqeWtkGnmoIfnrb7oioLngrnlv4Xpobvmt7vliqDkuIDkuKpjaGVja2VkQ2xhc3PlsZ7mgKfvvIznlKjkuo7ooajnpLrpgInkuK3nirbmgIHnmoRpY29u5Zu+5qCH5qC35byP57G75ZCN77yM5q+U5aaC77yaXG5cXGBcXGBcXGAgaHRtbFxuPGkgbmFtZT1cIuW8gOWFs0ljb25cIiB2dHlwZT1cImljb25cIiBpZD1cInN3aXRjaEljb25cIiBjbGFzcz1cImZhIHh4eFwiIGNoZWNrZWRDbGFzcz1cImZhIHl5eVwiPjwvaT5cbjxpIG5hbWU9XCLljZXpgIlJY29uXCIgdnR5cGU9XCJpY29uXCIgaWQ9XCJyYWRpb0ljb25cIiBjbGFzcz1cImZhIHh4eFwiIGNoZWNrZWRDbGFzcz1cImZhIHl5eVwiPjwvaT5cbjxpIG5hbWU9XCLljZXpgIlJY29uXCIgdnR5cGU9XCJpY29uXCIgaWQ9XCJyYWRpb0ljb25cIiBjbGFzcz1cImZhcyB4eHhcIiBjaGVja2VkQ2xhc3M9XCJmYXMgeXl5XCI+PC9pPlxuXFxgXFxgXFxgXG5cbiMjIyA044CB6aKc6Imy55qE5YaZ5rOV5ZKM6KeE5YiZXG4tIOS4jeiDveWinuWIoOaUuVxcYDpyb290XFxg6aKc6Imy5Y+Y6YePXG4tIOminOiJsuWPquiDveS9v+eUqGh0bWzmlofku7bnmoRcXGBoZWFkXFxg5qCH562+6YeM5bey57uP5a6a5LmJ5aW955qEXFxgOnJvb3RcXGDpopzoibLlj5jph49cbi0g5LiN6IO955u05o6l5L2/55So6aKc6Imy5YC85oiW56eB6Ieq5a6a5LmJ5YW25LuW6aKc6Imy5Y+Y6YePXG5cbiMjIyA144CB6L2u5pKtdmlld1BhZ2Vy44CBdGFi6YCJ6aG55Y2h5YaF5a655YyF6KO55a655ZmodGFiQ29udGVudFdyYXBwZXJDb250YWluZXLjgIHlpJrnirbmgIHlrrnlmahtdWx0aVN0YXRlQ29udGFpbmVy55qEY3Nz5YaZ5rOV6KeE5YiZXG4tIOi9ruaSrXZpZXdQYWdlcuOAgXRhYumAiemhueWNoeWGheWuueWMheijueWuueWZqHRhYkNvbnRlbnRXcmFwcGVyQ29udGFpbmVy44CB5aSa54q25oCB5a655ZmobXVsdGlTdGF0ZUNvbnRhaW5lcuiKgueCueeahGNzc+WumuS5ieW/hemhu+iuvue9rlxcYGRpc3BsYXk6IGdyaWQ7Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiBtaW5tYXgoMCwgMWZyKTtncmlkLXRlbXBsYXRlLXJvd3M6IG1pbm1heCgwLCAxZnIpO1xcYFxuLSDlroPnmoTlranlrZDoioLngrlvbmVWaWV3UGFnZXJDb250ZW5044CBb25lVGFiQ29udGVudENvbnRhaW5lcuOAgW9uZVN0YXRlQ29udGVudENvbnRhaW5lcueahGNzc+WumuS5ieW/hemhu+iuvue9rlxcYGdyaWQtY29sdW1uOiAxOyBncmlkLXJvdzogMTtcXGDvvIznu53lr7nnpoHmraLorr7nva5cXGBwb3NpdGlvbjogYWJzb2x1dGU7XFxg77yM6L+Z5qC35omN6IO96K6p6L2u5pKt5a655Zmo55qE5aSa5LiqaXRlbemhueWtqeWtkOmHjeWPoOWcqOS4gOi1t+W5tumAmui/h1xcYG9wYWNpdHk6IDA7XFxg5ZKMXFxgb3BhY2l0eTogMTtcXGDmnaXlrp7njrDmmL7pmpDmlYjmnpxcbi0g6L2u5pKtdmlld1BhZ2Vy44CBdGFi6YCJ6aG55Y2h5YaF5a655YyF6KO55a655ZmodGFiQ29udGVudFdyYXBwZXJDb250YWluZXLjgIHlpJrnirbmgIHlrrnlmahtdWx0aVN0YXRlQ29udGFpbmVy6IqC54K55LiN6ZyA6KaB6K6+572ud2lkdGjlkoxoZWlnaHTlhbfkvZPlgLzkuobvvIzlm6DkuLrmiYDmnInlrZDlhYPntKDku43lnKjmlofmoaPmtYHkuK3vvIzniLblrrnlmajkvJrmjInmnIDlpKfnmoTlrZDlhYPntKDoh6rliqjlhrPlrprlpKflsI/jgIJcbi0g5b+F6aG757uZ5a6D55qE56ys5LiA5Liqb25lVmlld1BhZ2VyQ29udGVudOOAgW9uZVRhYkNvbnRlbnRDb250YWluZXLjgIFvbmVTdGF0ZUNvbnRlbnRDb250YWluZXLnmoTlranlrZDoioLngrnnmoRjbGFzc+iuvue9ruS4umFjdGl2ZVxuXG4jIyMgNuOAgeWkmueKtuaAgeagt+W8j+eahOWumuS5ieWGmeazleWSjOinhOWImVxuLSB2dHlwZeWmguaenOaYr1xcYHZpZXdQYWdlckluZGljYXRvckNvbnRhaW5lclxcYOOAgVxcYHRhYk1lbnVCYXJJdGVtXFxg44CBXFxgYm90dG9tVGFiTmF2aWdhdGVCYXJJdGVtXFxg44CBXFxgbGlzdEl0ZW1DYXJkXFxg55qE6IqC54K577yM6YKj5LmI5b+F6aG76K6+572u5omA6ZyA55qE5aSa54q25oCB5qC35byP77yIYWN0aXZl44CBZGlzYWJsZWTjgIFmb2N1c+OAgWhvdmVy562J77yJ55qEY3Nz5qC35byPXG4tIOW5tuS4lOmcgOimgeWwhuebuOWQjOeItuS6sueahOesrOS4gOS4qlxcYHRhYk1lbnVCYXJJdGVtXFxg44CBXFxgYm90dG9tVGFiTmF2aWdhdGVCYXJJdGVtXFxg44CBXFxgbGlzdEl0ZW1DYXJkXFxg6IqC54K55re75YqgY2xhc3M9J2FjdGl2ZSfnmoTlsZ7mgKdcbi0g5L6L5a2Q77yaXG5cXGBcXGBcXGAgaHRtbFxuLi4uXG4jeHh4VGFiTWVudUJhcjEge1xuICAgIC4uLlxufVxuI3h4eFRhYk1lbnVCYXIxLmFjdGl2ZSB7XG4gICAgLi4uXG59XG4jeHh4VGFiTWVudUJhcjIge1xuICAgIC4uLlxufVxuI3h4eFRhYk1lbnVCYXIyLmFjdGl2ZSB7XG4gICAgLi4uXG59XG4uLi5cbiAgICA8ZGl2IG5hbWU9XCJ0YWLoj5zljZXmoI9cIiBpZD1cInh4eFRhYk1lbnVCYXJcIiBjbGFzcz1cInRhYi1tZW51LWJhclwiIHZ0eXBlPVwidGFiTWVudUJhclwiPlxuICAgICAgICA8ZGl2IG5hbWU9XCJ0YWLoj5zljZXmoI9pdGVt6aG5MVwiIGlkPVwieHh4VGFiTWVudUJhckl0ZW0xXCIgY2xhc3M9XCJhY3RpdmVcIiB2dHlwZT1cInRhYk1lbnVCYXJJdGVtXCI+XG4gICAgICAgICAgICAvLyB0YWLoj5zljZXmoI9pdGVt6aG5MVxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdiBuYW1lPVwidGFi6I+c5Y2V5qCPaXRlbemhuTJcIiBpZD1cInh4eFRhYk1lbnVCYXJJdGVtMlwiIHZ0eXBlPVwidGFiTWVudUJhckl0ZW1cIj5cbiAgICAgICAgICAgIC8vIHRhYuiPnOWNleagj2l0ZW3pobkyXG4gICAgICAgIDwvZGl2PlxuICAgICAgICAuLi5cbiAgICA8L2Rpdj5cblxcYFxcYFxcYFxuXG4jIyMgN+OAgXZ0eXBlPVwiZGlhbG9nXCLjgIF2dHlwZT1cInRvYXN0XCLjgIF2dHlwZT1cImRyb3BEb3duTWVudVwi44CBdnR5cGU9XCJzaWRlU2xpZGVQYW5lbFwi57uE5Lu26IqC54K555qEY3Nz5YaZ5rOV6KeE5YiZXG4tIOe7hOS7tuiKgueCuWNzc+W/hemhu+iuvue9rnBvc2l0aW9uOiBmaXhlZDvvvIzkuI3lvpforr7nva5wb3NpdGlvbjogYWJzb2x1dGU75oiW5YW25LuW5a6a5L2N5pa55byP44CCXG4tIOe7hOS7tuiKgueCueeahOaYvuekuuWSjOmakOiXj+W/hemhu+S9v+eUqG9wYWNpdHk6IDE75ZKMb3BhY2l0eTogMDvmnaXlrp7njrDvvIzkuI3lvpfkvb/nlKhkaXNwbGF5OiBub25lO+aIluS7luaWueW8j+adpeWunueOsOOAglxuLSDms6jmhI/miYDmnIl2dHlwZT1cInRvYXN0XCLnmoTmj5DnpLroioLngrnlv4XpobvmmK/lnKjpobXpnaLkuIvljYrpg6jku73vvIzorr7nva5ib3R0b209MTUwcHjvvIznu53lr7nkuI3mmK/lnKjpobXpnaLpobbpg6jjgIJcbi0g5rOo5oSP5omA5pyJdnR5cGU9XCJkcm9wRG93bk1lbnVcIueahOS4i+aLieiPnOWNleiKgueCueW/hemhu+WcqOmUmueCueWFg+e0oOeahOS4i+aWueWQiOmAgueahOS9jee9ru+8jOS4jeW+l+maj+S+v+aUvue9ruOAglxuLSDms6jmhI/miYDmnIl2dHlwZT1cInNpZGVTbGlkZVBhbmVsXCLnmoTkvqfmu5HpnaLmnb/vvIzlgYforr7pnaLmnb/lrr3luqZ3PTMwMO+8jOmCo+S5iOWmguaenOaYr+W3puS+p+S+p+a7kemdouadv++8jOmCo+S5iOW4uOaAgeS4i++8iOmdnuaJk+W8gOeKtuaAge+8ieW/hemhu+iuvue9rmxlZnQ9LTMwMHB477yM5aaC5p6c5piv5Y+z5L6n5L6n5ruR6Z2i5p2/77yM6YKj5LmI5bi45oCB5LiL77yI6Z2e5omT5byA54q25oCB77yJ5b+F6aG76K6+572ucmlnaHQ9LTM5M3B477yM5LiN5b6X6ZqP5L6/5pS+572u77yM5bm25LiU5L6n5ruR6Z2i5p2/55qE6auY5bqmaOeahOacgOWkp+WAvOWPquiDveaYr++8mjM5MyAtIOS+p+a7kemdouadv+eahHnlnZDmoIflgLzjgIJcbmA7Il19
|