myagent-ai 1.0.0

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.
Files changed (486) hide show
  1. package/Dockerfile +30 -0
  2. package/README.md +333 -0
  3. package/agents/__init__.py +6 -0
  4. package/agents/__pycache__/main_agent.cpython-312.pyc +0 -0
  5. package/agents/base.py +115 -0
  6. package/agents/main_agent.py +695 -0
  7. package/agents/memory_agent.py +313 -0
  8. package/agents/tool_agent.py +248 -0
  9. package/chatbot/__init__.py +5 -0
  10. package/chatbot/base.py +124 -0
  11. package/chatbot/discord_bot.py +146 -0
  12. package/chatbot/feishu_bot.py +548 -0
  13. package/chatbot/manager.py +164 -0
  14. package/chatbot/qq_bot.py +189 -0
  15. package/chatbot/telegram_bot.py +167 -0
  16. package/chatbot/wechat_bot.py +558 -0
  17. package/communication/__init__.py +66 -0
  18. package/communication/channel.py +576 -0
  19. package/communication/crypto.py +347 -0
  20. package/communication/manager.py +397 -0
  21. package/communication/peer.py +156 -0
  22. package/config.py +464 -0
  23. package/core/__init__.py +10 -0
  24. package/core/config_broadcast.py +276 -0
  25. package/core/llm.py +878 -0
  26. package/core/logger.py +241 -0
  27. package/core/task_queue.py +362 -0
  28. package/core/utils.py +184 -0
  29. package/executor/__init__.py +4 -0
  30. package/executor/__pycache__/engine.cpython-312.pyc +0 -0
  31. package/executor/engine.py +1215 -0
  32. package/groups/__init__.py +15 -0
  33. package/groups/manager.py +724 -0
  34. package/knowledge/__init__.py +4 -0
  35. package/knowledge/rag.py +444 -0
  36. package/main.py +801 -0
  37. package/memory/__init__.py +4 -0
  38. package/memory/manager.py +840 -0
  39. package/organization/__init__.py +4 -0
  40. package/organization/manager.py +350 -0
  41. package/package.json +58 -0
  42. package/requirements.txt +59 -0
  43. package/setup.py +40 -0
  44. package/skills/ASR/LICENSE.txt +21 -0
  45. package/skills/ASR/SKILL.md +580 -0
  46. package/skills/ASR/scripts/asr.ts +27 -0
  47. package/skills/LLM/LICENSE.txt +21 -0
  48. package/skills/LLM/SKILL.md +856 -0
  49. package/skills/LLM/scripts/chat.ts +32 -0
  50. package/skills/TTS/LICENSE.txt +21 -0
  51. package/skills/TTS/SKILL.md +735 -0
  52. package/skills/TTS/tts.ts +25 -0
  53. package/skills/VLM/LICENSE.txt +21 -0
  54. package/skills/VLM/SKILL.md +588 -0
  55. package/skills/VLM/scripts/vlm.ts +57 -0
  56. package/skills/__init__.py +5 -0
  57. package/skills/agent-browser/SKILL.md +328 -0
  58. package/skills/ai-news-collectors/SKILL.md +157 -0
  59. package/skills/ai-news-collectors/_meta.json +6 -0
  60. package/skills/ai-news-collectors/references/sources.md +128 -0
  61. package/skills/aminer-open-academic/SKILL.md +312 -0
  62. package/skills/aminer-open-academic/_meta.json +6 -0
  63. package/skills/aminer-open-academic/evals/evals.json +46 -0
  64. package/skills/aminer-open-academic/references/api-catalog.md +1032 -0
  65. package/skills/aminer-open-academic/scripts/__pycache__/aminer_client.cpython-312.pyc +0 -0
  66. package/skills/aminer-open-academic/scripts/aminer_client.py +875 -0
  67. package/skills/auto-target-tracker/SKILL.md +317 -0
  68. package/skills/base.py +147 -0
  69. package/skills/blog-writer/2024-02-17-radical-transparency-sales.md +35 -0
  70. package/skills/blog-writer/2024-02-17-raycast-spotlight-superpowers.md +33 -0
  71. package/skills/blog-writer/2024-02-17-short-form-content-marketing.md +47 -0
  72. package/skills/blog-writer/2024-02-17-typing-speed-benefits.md +33 -0
  73. package/skills/blog-writer/2024-03-14-effective-ai-prompts.md +55 -0
  74. package/skills/blog-writer/2024-11-08-ai-revolutionizing-entry-level-sales.md +43 -0
  75. package/skills/blog-writer/2025-11-12-why-ai-art-is-useless.md +49 -0
  76. package/skills/blog-writer/README.md +2 -0
  77. package/skills/blog-writer/SKILL.md +158 -0
  78. package/skills/blog-writer/__pycache__/manage_examples.cpython-312.pyc +0 -0
  79. package/skills/blog-writer/_meta.json +6 -0
  80. package/skills/blog-writer/manage_examples.py +90 -0
  81. package/skills/blog-writer/style-guide.md +160 -0
  82. package/skills/browser_skill.py +146 -0
  83. package/skills/coding-agent/SKILL.md +120 -0
  84. package/skills/coding-agent/_meta.json +6 -0
  85. package/skills/coding-agent/criteria.md +48 -0
  86. package/skills/coding-agent/execution.md +42 -0
  87. package/skills/coding-agent/memory-template.md +38 -0
  88. package/skills/coding-agent/planning.md +31 -0
  89. package/skills/coding-agent/state.md +60 -0
  90. package/skills/coding-agent/verification.md +39 -0
  91. package/skills/content-strategy/SKILL.md +181 -0
  92. package/skills/content-strategy/_meta.json +6 -0
  93. package/skills/contentanalysis/ExtractWisdom/SKILL.md +229 -0
  94. package/skills/contentanalysis/ExtractWisdom/Workflows/Extract.md +60 -0
  95. package/skills/contentanalysis/SKILL.md +14 -0
  96. package/skills/docx/CHANGELOG.md +85 -0
  97. package/skills/docx/LICENSE.txt +30 -0
  98. package/skills/docx/SKILL.md +455 -0
  99. package/skills/docx/docx-js.md +681 -0
  100. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  101. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  102. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  103. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  104. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  105. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  106. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  107. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  108. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  109. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  110. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  111. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  112. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  113. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  114. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  115. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  116. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  117. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  118. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  119. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  120. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  121. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  122. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  123. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  124. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  125. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  126. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  127. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  128. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  129. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  130. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  131. package/skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
  132. package/skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  133. package/skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  134. package/skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  135. package/skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  136. package/skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  137. package/skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  138. package/skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  139. package/skills/docx/ooxml/scripts/__pycache__/pack.cpython-312.pyc +0 -0
  140. package/skills/docx/ooxml/scripts/__pycache__/unpack.cpython-312.pyc +0 -0
  141. package/skills/docx/ooxml/scripts/__pycache__/validate.cpython-312.pyc +0 -0
  142. package/skills/docx/ooxml/scripts/pack.py +159 -0
  143. package/skills/docx/ooxml/scripts/unpack.py +29 -0
  144. package/skills/docx/ooxml/scripts/validate.py +69 -0
  145. package/skills/docx/ooxml/scripts/validation/__init__.py +15 -0
  146. package/skills/docx/ooxml/scripts/validation/__pycache__/__init__.cpython-312.pyc +0 -0
  147. package/skills/docx/ooxml/scripts/validation/__pycache__/base.cpython-312.pyc +0 -0
  148. package/skills/docx/ooxml/scripts/validation/__pycache__/docx.cpython-312.pyc +0 -0
  149. package/skills/docx/ooxml/scripts/validation/__pycache__/pptx.cpython-312.pyc +0 -0
  150. package/skills/docx/ooxml/scripts/validation/__pycache__/redlining.cpython-312.pyc +0 -0
  151. package/skills/docx/ooxml/scripts/validation/base.py +951 -0
  152. package/skills/docx/ooxml/scripts/validation/docx.py +274 -0
  153. package/skills/docx/ooxml/scripts/validation/pptx.py +315 -0
  154. package/skills/docx/ooxml/scripts/validation/redlining.py +279 -0
  155. package/skills/docx/ooxml.md +615 -0
  156. package/skills/docx/scripts/__init__.py +1 -0
  157. package/skills/docx/scripts/__pycache__/__init__.cpython-312.pyc +0 -0
  158. package/skills/docx/scripts/__pycache__/add_toc_placeholders.cpython-312.pyc +0 -0
  159. package/skills/docx/scripts/__pycache__/document.cpython-312.pyc +0 -0
  160. package/skills/docx/scripts/__pycache__/utilities.cpython-312.pyc +0 -0
  161. package/skills/docx/scripts/add_toc_placeholders.py +220 -0
  162. package/skills/docx/scripts/document.py +1302 -0
  163. package/skills/docx/scripts/templates/comments.xml +3 -0
  164. package/skills/docx/scripts/templates/commentsExtended.xml +3 -0
  165. package/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  166. package/skills/docx/scripts/templates/commentsIds.xml +3 -0
  167. package/skills/docx/scripts/templates/people.xml +3 -0
  168. package/skills/docx/scripts/utilities.py +374 -0
  169. package/skills/dream-interpreter/SKILL.md +88 -0
  170. package/skills/dream-interpreter/assets/example_asset.txt +24 -0
  171. package/skills/dream-interpreter/references/api_reference.md +34 -0
  172. package/skills/dream-interpreter/references/interpretation-guide.md +83 -0
  173. package/skills/dream-interpreter/references/output-schema.md +65 -0
  174. package/skills/dream-interpreter/references/questioning-strategy.md +62 -0
  175. package/skills/dream-interpreter/references/visual-mapping.md +81 -0
  176. package/skills/dream-interpreter/scripts/__pycache__/example.cpython-312.pyc +0 -0
  177. package/skills/dream-interpreter/scripts/example.py +19 -0
  178. package/skills/dream-interpreter/skill.json +7 -0
  179. package/skills/file_skill.py +246 -0
  180. package/skills/finance/Finance_API_Doc.md +445 -0
  181. package/skills/finance/SKILL.md +53 -0
  182. package/skills/fullstack-dev/SKILL.md +205 -0
  183. package/skills/get-fortune-analysis/SKILL.md +370 -0
  184. package/skills/get-fortune-analysis/lunar_python.py +91 -0
  185. package/skills/gift-evaluator/SKILL.md +83 -0
  186. package/skills/gift-evaluator/__pycache__/html_tools.cpython-312.pyc +0 -0
  187. package/skills/gift-evaluator/html_tools.py +268 -0
  188. package/skills/image-edit/LICENSE.txt +21 -0
  189. package/skills/image-edit/SKILL.md +896 -0
  190. package/skills/image-edit/scripts/image-edit.ts +36 -0
  191. package/skills/image-generation/LICENSE.txt +21 -0
  192. package/skills/image-generation/SKILL.md +583 -0
  193. package/skills/image-generation/scripts/image-generation.ts +28 -0
  194. package/skills/image-understand/LICENSE.txt +21 -0
  195. package/skills/image-understand/SKILL.md +855 -0
  196. package/skills/image-understand/scripts/image-understand.ts +41 -0
  197. package/skills/interview-designer/README.md +70 -0
  198. package/skills/interview-designer/SKILL.md +53 -0
  199. package/skills/interview-designer/_meta.json +6 -0
  200. package/skills/interview-designer/references/design_rationale.md +43 -0
  201. package/skills/interview-designer/templates/interview_guide_template.md +62 -0
  202. package/skills/market-research-reports/SKILL.md +901 -0
  203. package/skills/market-research-reports/assets/FORMATTING_GUIDE.md +428 -0
  204. package/skills/market-research-reports/assets/market_report_template.tex +1380 -0
  205. package/skills/market-research-reports/assets/market_research.sty +564 -0
  206. package/skills/market-research-reports/references/data_analysis_patterns.md +548 -0
  207. package/skills/market-research-reports/references/report_structure_guide.md +999 -0
  208. package/skills/market-research-reports/references/visual_generation_guide.md +1077 -0
  209. package/skills/market-research-reports/scripts/__pycache__/generate_market_visuals.cpython-312.pyc +0 -0
  210. package/skills/market-research-reports/scripts/generate_market_visuals.py +529 -0
  211. package/skills/marketing-mode/README.md +49 -0
  212. package/skills/marketing-mode/SKILL.md +693 -0
  213. package/skills/marketing-mode/_meta.json +6 -0
  214. package/skills/marketing-mode/mode-prompt.md +39 -0
  215. package/skills/marketing-mode/skill.json +51 -0
  216. package/skills/mindfulness-meditation/SKILL.md +65 -0
  217. package/skills/mindfulness-meditation/_meta.json +6 -0
  218. package/skills/multi-search-engine/CHANGELOG.md +15 -0
  219. package/skills/multi-search-engine/CHANNELLOG.md +48 -0
  220. package/skills/multi-search-engine/SKILL.md +78 -0
  221. package/skills/multi-search-engine/_meta.json +6 -0
  222. package/skills/multi-search-engine/config.json +14 -0
  223. package/skills/multi-search-engine/metadata.json +7 -0
  224. package/skills/multi-search-engine/references/international-search.md +651 -0
  225. package/skills/pdf/LICENSE.txt +30 -0
  226. package/skills/pdf/SKILL.md +1534 -0
  227. package/skills/pdf/forms.md +205 -0
  228. package/skills/pdf/reference.md +765 -0
  229. package/skills/pdf/scripts/__pycache__/add_zai_metadata.cpython-312.pyc +0 -0
  230. package/skills/pdf/scripts/__pycache__/check_bounding_boxes.cpython-312.pyc +0 -0
  231. package/skills/pdf/scripts/__pycache__/check_bounding_boxes_test.cpython-312.pyc +0 -0
  232. package/skills/pdf/scripts/__pycache__/check_fillable_fields.cpython-312.pyc +0 -0
  233. package/skills/pdf/scripts/__pycache__/convert_pdf_to_images.cpython-312.pyc +0 -0
  234. package/skills/pdf/scripts/__pycache__/create_validation_image.cpython-312.pyc +0 -0
  235. package/skills/pdf/scripts/__pycache__/extract_form_field_info.cpython-312.pyc +0 -0
  236. package/skills/pdf/scripts/__pycache__/fill_fillable_fields.cpython-312.pyc +0 -0
  237. package/skills/pdf/scripts/__pycache__/fill_pdf_form_with_annotations.cpython-312.pyc +0 -0
  238. package/skills/pdf/scripts/__pycache__/sanitize_code.cpython-312.pyc +0 -0
  239. package/skills/pdf/scripts/add_zai_metadata.py +172 -0
  240. package/skills/pdf/scripts/check_bounding_boxes.py +70 -0
  241. package/skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
  242. package/skills/pdf/scripts/check_fillable_fields.py +12 -0
  243. package/skills/pdf/scripts/convert_pdf_to_images.py +35 -0
  244. package/skills/pdf/scripts/create_validation_image.py +41 -0
  245. package/skills/pdf/scripts/extract_form_field_info.py +152 -0
  246. package/skills/pdf/scripts/fill_fillable_fields.py +114 -0
  247. package/skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
  248. package/skills/pdf/scripts/sanitize_code.py +110 -0
  249. package/skills/podcast-generate/LICENSE.txt +21 -0
  250. package/skills/podcast-generate/SKILL.md +198 -0
  251. package/skills/podcast-generate/generate.ts +661 -0
  252. package/skills/podcast-generate/package.json +30 -0
  253. package/skills/podcast-generate/readme.md +177 -0
  254. package/skills/podcast-generate/test_data/segments.jsonl +3 -0
  255. package/skills/podcast-generate/tsconfig.json +26 -0
  256. package/skills/pptx/LICENSE.txt +30 -0
  257. package/skills/pptx/SKILL.md +507 -0
  258. package/skills/pptx/html2pptx.md +625 -0
  259. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  260. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  261. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  262. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  263. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  264. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  265. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  266. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  267. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  268. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  269. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  270. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  271. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  272. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  273. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  274. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  275. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  276. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  277. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  278. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  279. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  280. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  281. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  282. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  283. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  284. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  285. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  286. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  287. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  288. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  289. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  290. package/skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
  291. package/skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  292. package/skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  293. package/skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  294. package/skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  295. package/skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  296. package/skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  297. package/skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  298. package/skills/pptx/ooxml/scripts/__pycache__/pack.cpython-312.pyc +0 -0
  299. package/skills/pptx/ooxml/scripts/__pycache__/unpack.cpython-312.pyc +0 -0
  300. package/skills/pptx/ooxml/scripts/__pycache__/validate.cpython-312.pyc +0 -0
  301. package/skills/pptx/ooxml/scripts/pack.py +159 -0
  302. package/skills/pptx/ooxml/scripts/unpack.py +29 -0
  303. package/skills/pptx/ooxml/scripts/validate.py +69 -0
  304. package/skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
  305. package/skills/pptx/ooxml/scripts/validation/__pycache__/__init__.cpython-312.pyc +0 -0
  306. package/skills/pptx/ooxml/scripts/validation/__pycache__/base.cpython-312.pyc +0 -0
  307. package/skills/pptx/ooxml/scripts/validation/__pycache__/docx.cpython-312.pyc +0 -0
  308. package/skills/pptx/ooxml/scripts/validation/__pycache__/pptx.cpython-312.pyc +0 -0
  309. package/skills/pptx/ooxml/scripts/validation/__pycache__/redlining.cpython-312.pyc +0 -0
  310. package/skills/pptx/ooxml/scripts/validation/base.py +951 -0
  311. package/skills/pptx/ooxml/scripts/validation/docx.py +274 -0
  312. package/skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
  313. package/skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
  314. package/skills/pptx/ooxml.md +427 -0
  315. package/skills/pptx/scripts/__pycache__/inventory.cpython-312.pyc +0 -0
  316. package/skills/pptx/scripts/__pycache__/inventory.cpython-313.pyc +0 -0
  317. package/skills/pptx/scripts/__pycache__/rearrange.cpython-312.pyc +0 -0
  318. package/skills/pptx/scripts/__pycache__/replace.cpython-312.pyc +0 -0
  319. package/skills/pptx/scripts/__pycache__/thumbnail.cpython-312.pyc +0 -0
  320. package/skills/pptx/scripts/html2pptx.js +1044 -0
  321. package/skills/pptx/scripts/inventory.py +1020 -0
  322. package/skills/pptx/scripts/rearrange.py +231 -0
  323. package/skills/pptx/scripts/replace.py +385 -0
  324. package/skills/pptx/scripts/thumbnail.py +450 -0
  325. package/skills/qingyan-research/SKILL.md +294 -0
  326. package/skills/qingyan-research/__pycache__/generate_html.cpython-312.pyc +0 -0
  327. package/skills/qingyan-research/generate_html.py +33 -0
  328. package/skills/registry.py +344 -0
  329. package/skills/search_skill.py +228 -0
  330. package/skills/seo-content-writer/SKILL.md +661 -0
  331. package/skills/seo-content-writer/_meta.json +6 -0
  332. package/skills/seo-content-writer/references/content-structure-templates.md +875 -0
  333. package/skills/seo-content-writer/references/title-formulas.md +339 -0
  334. package/skills/skill-creator/LICENSE.txt +202 -0
  335. package/skills/skill-creator/SKILL.md +485 -0
  336. package/skills/skill-creator/agents/analyzer.md +274 -0
  337. package/skills/skill-creator/agents/comparator.md +202 -0
  338. package/skills/skill-creator/agents/grader.md +223 -0
  339. package/skills/skill-creator/assets/eval_review.html +146 -0
  340. package/skills/skill-creator/eval-viewer/__pycache__/generate_review.cpython-312.pyc +0 -0
  341. package/skills/skill-creator/eval-viewer/generate_review.py +471 -0
  342. package/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  343. package/skills/skill-creator/references/schemas.md +430 -0
  344. package/skills/skill-creator/scripts/__init__.py +0 -0
  345. package/skills/skill-creator/scripts/__pycache__/__init__.cpython-312.pyc +0 -0
  346. package/skills/skill-creator/scripts/__pycache__/aggregate_benchmark.cpython-312.pyc +0 -0
  347. package/skills/skill-creator/scripts/__pycache__/generate_report.cpython-312.pyc +0 -0
  348. package/skills/skill-creator/scripts/__pycache__/improve_description.cpython-312.pyc +0 -0
  349. package/skills/skill-creator/scripts/__pycache__/package_skill.cpython-312.pyc +0 -0
  350. package/skills/skill-creator/scripts/__pycache__/quick_validate.cpython-312.pyc +0 -0
  351. package/skills/skill-creator/scripts/__pycache__/run_eval.cpython-312.pyc +0 -0
  352. package/skills/skill-creator/scripts/__pycache__/run_loop.cpython-312.pyc +0 -0
  353. package/skills/skill-creator/scripts/__pycache__/utils.cpython-312.pyc +0 -0
  354. package/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
  355. package/skills/skill-creator/scripts/generate_report.py +326 -0
  356. package/skills/skill-creator/scripts/improve_description.py +236 -0
  357. package/skills/skill-creator/scripts/package_skill.py +136 -0
  358. package/skills/skill-creator/scripts/quick_validate.py +103 -0
  359. package/skills/skill-creator/scripts/run_eval.py +310 -0
  360. package/skills/skill-creator/scripts/run_loop.py +328 -0
  361. package/skills/skill-creator/scripts/utils.py +47 -0
  362. package/skills/skill-finder-cn/SKILL.md +66 -0
  363. package/skills/skill-finder-cn/_meta.json +6 -0
  364. package/skills/skill-finder-cn/package.json +5 -0
  365. package/skills/skill-finder-cn/scripts/search.sh +15 -0
  366. package/skills/skill-vetter/SKILL.md +137 -0
  367. package/skills/stock-analysis-skill/SKILL.md +156 -0
  368. package/skills/stock-analysis-skill/package.json +21 -0
  369. package/skills/stock-analysis-skill/src/analyzer.ts +264 -0
  370. package/skills/stock-analysis-skill/src/dataFetcher.ts +130 -0
  371. package/skills/stock-analysis-skill/src/dividend.ts +226 -0
  372. package/skills/stock-analysis-skill/src/index.ts +327 -0
  373. package/skills/stock-analysis-skill/src/rumorScanner.ts +200 -0
  374. package/skills/stock-analysis-skill/src/types.ts +167 -0
  375. package/skills/stock-analysis-skill/src/watchlist.ts +292 -0
  376. package/skills/stock-analysis-skill/tsconfig.json +15 -0
  377. package/skills/storyboard-manager/SKILL.md +532 -0
  378. package/skills/storyboard-manager/index.js +9 -0
  379. package/skills/storyboard-manager/package.json +11 -0
  380. package/skills/storyboard-manager/references/character_development.md +232 -0
  381. package/skills/storyboard-manager/references/story_structures.md +148 -0
  382. package/skills/storyboard-manager/scripts/__pycache__/consistency_checker.cpython-312.pyc +0 -0
  383. package/skills/storyboard-manager/scripts/__pycache__/timeline_tracker.cpython-312.pyc +0 -0
  384. package/skills/storyboard-manager/scripts/consistency_checker.py +391 -0
  385. package/skills/storyboard-manager/scripts/timeline_tracker.py +352 -0
  386. package/skills/system_skill.py +249 -0
  387. package/skills/ui-ux-pro-max/SKILL.md +43 -0
  388. package/skills/ui-ux-pro-max/_meta.json +6 -0
  389. package/skills/ui-ux-pro-max/assets/data/charts.csv +26 -0
  390. package/skills/ui-ux-pro-max/assets/data/colors.csv +97 -0
  391. package/skills/ui-ux-pro-max/assets/data/icons.csv +101 -0
  392. package/skills/ui-ux-pro-max/assets/data/landing.csv +31 -0
  393. package/skills/ui-ux-pro-max/assets/data/products.csv +97 -0
  394. package/skills/ui-ux-pro-max/assets/data/react-performance.csv +45 -0
  395. package/skills/ui-ux-pro-max/assets/data/stacks/astro.csv +54 -0
  396. package/skills/ui-ux-pro-max/assets/data/stacks/flutter.csv +53 -0
  397. package/skills/ui-ux-pro-max/assets/data/stacks/html-tailwind.csv +56 -0
  398. package/skills/ui-ux-pro-max/assets/data/stacks/jetpack-compose.csv +53 -0
  399. package/skills/ui-ux-pro-max/assets/data/stacks/nextjs.csv +53 -0
  400. package/skills/ui-ux-pro-max/assets/data/stacks/nuxt-ui.csv +51 -0
  401. package/skills/ui-ux-pro-max/assets/data/stacks/nuxtjs.csv +59 -0
  402. package/skills/ui-ux-pro-max/assets/data/stacks/react-native.csv +52 -0
  403. package/skills/ui-ux-pro-max/assets/data/stacks/react.csv +54 -0
  404. package/skills/ui-ux-pro-max/assets/data/stacks/shadcn.csv +61 -0
  405. package/skills/ui-ux-pro-max/assets/data/stacks/svelte.csv +54 -0
  406. package/skills/ui-ux-pro-max/assets/data/stacks/swiftui.csv +51 -0
  407. package/skills/ui-ux-pro-max/assets/data/stacks/vue.csv +50 -0
  408. package/skills/ui-ux-pro-max/assets/data/styles.csv +68 -0
  409. package/skills/ui-ux-pro-max/assets/data/typography.csv +58 -0
  410. package/skills/ui-ux-pro-max/assets/data/ui-reasoning.csv +101 -0
  411. package/skills/ui-ux-pro-max/assets/data/ux-guidelines.csv +100 -0
  412. package/skills/ui-ux-pro-max/assets/data/web-interface.csv +31 -0
  413. package/skills/ui-ux-pro-max/data/charts.csv +26 -0
  414. package/skills/ui-ux-pro-max/data/colors.csv +97 -0
  415. package/skills/ui-ux-pro-max/data/icons.csv +101 -0
  416. package/skills/ui-ux-pro-max/data/landing.csv +31 -0
  417. package/skills/ui-ux-pro-max/data/products.csv +97 -0
  418. package/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  419. package/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -0
  420. package/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  421. package/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  422. package/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
  423. package/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  424. package/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  425. package/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  426. package/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  427. package/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
  428. package/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  429. package/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  430. package/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  431. package/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  432. package/skills/ui-ux-pro-max/data/styles.csv +68 -0
  433. package/skills/ui-ux-pro-max/data/typography.csv +58 -0
  434. package/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  435. package/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  436. package/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
  437. package/skills/ui-ux-pro-max/references/upstream-README.md +488 -0
  438. package/skills/ui-ux-pro-max/references/upstream-skill-content.md +288 -0
  439. package/skills/ui-ux-pro-max/scripts/__init__.py +0 -0
  440. package/skills/ui-ux-pro-max/scripts/__pycache__/__init__.cpython-312.pyc +0 -0
  441. package/skills/ui-ux-pro-max/scripts/__pycache__/core.cpython-312.pyc +0 -0
  442. package/skills/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-312.pyc +0 -0
  443. package/skills/ui-ux-pro-max/scripts/__pycache__/search.cpython-312.pyc +0 -0
  444. package/skills/ui-ux-pro-max/scripts/core.py +253 -0
  445. package/skills/ui-ux-pro-max/scripts/design_system.py +1071 -0
  446. package/skills/ui-ux-pro-max/scripts/search.py +111 -0
  447. package/skills/video-generation/LICENSE.txt +21 -0
  448. package/skills/video-generation/SKILL.md +1082 -0
  449. package/skills/video-generation/scripts/video.ts +168 -0
  450. package/skills/video-understand/LICENSE.txt +21 -0
  451. package/skills/video-understand/SKILL.md +916 -0
  452. package/skills/video-understand/scripts/video-understand.ts +41 -0
  453. package/skills/visual-design-foundations/SKILL.md +318 -0
  454. package/skills/visual-design-foundations/references/color-systems.md +417 -0
  455. package/skills/visual-design-foundations/references/spacing-iconography.md +425 -0
  456. package/skills/visual-design-foundations/references/typography-systems.md +432 -0
  457. package/skills/web-reader/LICENSE.txt +21 -0
  458. package/skills/web-reader/SKILL.md +1140 -0
  459. package/skills/web-reader/scripts/web-reader.ts +37 -0
  460. package/skills/web-search/LICENSE.txt +21 -0
  461. package/skills/web-search/SKILL.md +912 -0
  462. package/skills/web-search/scripts/web_search.ts +44 -0
  463. package/skills/web-shader-extractor/SKILL.md +145 -0
  464. package/skills/web-shader-extractor/references/config-extraction.md +50 -0
  465. package/skills/web-shader-extractor/references/encoded-definitions.md +53 -0
  466. package/skills/web-shader-extractor/references/extraction-workflow.md +61 -0
  467. package/skills/web-shader-extractor/references/porting-strategy.md +164 -0
  468. package/skills/web-shader-extractor/references/shader-injection.md +126 -0
  469. package/skills/web-shader-extractor/references/shaders-com.md +190 -0
  470. package/skills/web-shader-extractor/references/tech-signatures.md +54 -0
  471. package/skills/web-shader-extractor/references/tsl-extraction.md +41 -0
  472. package/skills/web-shader-extractor/references/unicorn-studio.md +353 -0
  473. package/skills/web-shader-extractor/scripts/fetch-rendered-dom.mjs +153 -0
  474. package/skills/web-shader-extractor/scripts/scan-bundle.sh +76 -0
  475. package/skills/writing-plans/SKILL.md +116 -0
  476. package/skills/writing-plans/_meta.json +6 -0
  477. package/skills/xlsx/LICENSE.txt +30 -0
  478. package/skills/xlsx/SKILL.md +496 -0
  479. package/skills/xlsx/__pycache__/recalc.cpython-312.pyc +0 -0
  480. package/skills/xlsx/recalc.py +178 -0
  481. package/start.sh +36 -0
  482. package/web/__init__.py +1 -0
  483. package/web/__pycache__/api_server.cpython-312.pyc +0 -0
  484. package/web/api_server.py +2043 -0
  485. package/web/ui/chat.html +3235 -0
  486. package/web/ui/index.html +458 -0
@@ -0,0 +1,458 @@
1
+ <!DOCTYPE html>
2
+ <html lang="zh-CN">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
+ <title>MyAgent 管理后台</title>
7
+ <style>
8
+ *{margin:0;padding:0;box-sizing:border-box}
9
+ :root{--bg:#0f1117;--surface:#1a1d27;--surface2:#232733;--border:#2e3347;--text:#e1e4ed;--text2:#8b92a5;--primary:#6366f1;--primary-h:#818cf8;--success:#22c55e;--warn:#f59e0b;--danger:#ef4444;--info:#3b82f6;--radius:8px}
10
+ body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);height:100vh;display:flex}
11
+ .sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
12
+ .sidebar .logo{padding:20px;font-size:18px;font-weight:700;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
13
+ .sidebar .logo span{color:var(--primary)}
14
+ .nav{flex:1;padding:8px;overflow-y:auto}
15
+ .nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);cursor:pointer;color:var(--text2);font-size:14px;transition:all .15s;margin-bottom:2px}
16
+ .nav-item:hover{background:var(--surface2);color:var(--text)}
17
+ .nav-item.active{background:var(--primary);color:#fff}
18
+ .nav-item .icon{width:20px;text-align:center;font-size:16px}
19
+ .main{flex:1;display:flex;flex-direction:column;overflow:hidden}
20
+ .header{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--surface)}
21
+ .header h2{font-size:18px}
22
+ .status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);display:inline-block;margin-right:8px;animation:pulse 2s infinite}
23
+ @keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
24
+ .content{flex:1;padding:24px;overflow-y:auto}
25
+ .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}
26
+ .card h3{font-size:15px;margin-bottom:12px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
27
+ .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
28
+ .stat{background:var(--surface2);padding:16px;border-radius:var(--radius)}
29
+ .stat .label{font-size:12px;color:var(--text2);margin-bottom:4px}
30
+ .stat .value{font-size:28px;font-weight:700}
31
+ input,select,textarea{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:6px;font-size:14px;width:100%;outline:none}
32
+ input:focus,select:focus,textarea:focus{border-color:var(--primary)}
33
+ textarea{font-family:'Cascadia Code',Consolas,monospace;resize:vertical;min-height:100px}
34
+ .btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
35
+ .btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-h)}
36
+ .btn-success{background:var(--success);color:#fff}
37
+ .btn-danger{background:var(--danger);color:#fff}
38
+ .btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface2)}
39
+ .btn-sm{padding:4px 10px;font-size:12px}
40
+ table{width:100%;border-collapse:collapse}
41
+ th,td{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);font-size:13px}
42
+ th{color:var(--text2);font-weight:600;font-size:12px}
43
+ tr:hover{background:var(--surface2)}
44
+ .badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}
45
+ .badge-green{background:#22c55e22;color:var(--success)}
46
+ .badge-red{background:#ef444422;color:var(--danger)}
47
+ .badge-yellow{background:#f59e0b22;color:var(--warn)}
48
+ .form-group{margin-bottom:14px}
49
+ .form-group label{display:block;font-size:13px;color:var(--text2);margin-bottom:4px}
50
+ .tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0}
51
+ .tab{padding:8px 16px;cursor:pointer;font-size:13px;color:var(--text2);border-bottom:2px solid transparent}
52
+ .tab.active{color:var(--primary);border-color:var(--primary)}
53
+ .modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:100}
54
+ .modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto}
55
+ .modal h3{margin-bottom:16px}
56
+ .log-viewer{background:#0a0c10;border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-family:monospace;font-size:12px;line-height:1.6;max-height:500px;overflow-y:auto;white-space:pre-wrap;color:#a0a8c0}
57
+ .log-viewer .INFO{color:#22c55e}.log-viewer .WARNING{color:#f59e0b}.log-viewer .ERROR{color:#ef4444}.log-viewer .DEBUG{color:#6366f1}
58
+ .hidden{display:none!important}
59
+ .flex{display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}
60
+ .mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}
61
+ .tag{display:inline-block;padding:2px 6px;background:var(--surface2);border-radius:4px;font-size:11px;color:var(--text2);margin:2px}
62
+ .empty{text-align:center;color:var(--text2);padding:40px;font-size:14px}
63
+ </style>
64
+ </head>
65
+ <body>
66
+ <div class="sidebar">
67
+ <div class="logo"><span>🤖</span> MyAgent</div>
68
+ <div class="nav">
69
+ <div class="nav-item active" onclick="showPage('dashboard')"><span class="icon">📊</span>仪表盘</div>
70
+ <div class="nav-item" onclick="showPage('agents')"><span class="icon">🧠</span>Agent 管理</div>
71
+ <div class="nav-item" onclick="showPage('platforms')"><span class="icon">💬</span>聊天平台</div>
72
+ <div class="nav-item" onclick="showPage('sessions')"><span class="icon">📂</span>会话管理</div>
73
+ <div class="nav-item" onclick="showPage('memory')"><span class="icon">🧠</span>记忆管理</div>
74
+ <div class="nav-item" onclick="showPage('llm')"><span class="icon">⚙️</span>大模型设置</div>
75
+ <div class="nav-item" onclick="showPage('executor')"><span class="icon">🔧</span>执行引擎</div>
76
+ <div class="nav-item" onclick="showPage('skills')"><span class="icon">🛠</span>插件管理</div>
77
+ <div class="nav-item" onclick="showPage('files')"><span class="icon">📁</span>工作目录</div>
78
+ <div class="nav-item" onclick="showPage('logs')"><span class="icon">📋</span>查看日志</div>
79
+ </div>
80
+ <div style="padding:12px;border-top:1px solid var(--border);font-size:12px;color:var(--text2)">
81
+ v1.0.0 · <a href="#" onclick="api('/api/status').then(r=>alert('Running: '+r.running))">状态</a>
82
+ </div>
83
+ </div>
84
+ <div class="main">
85
+ <div class="header"><h2 id="pageTitle">📊 仪表盘</h2><div><span class="status-dot"></span>运行中</div></div>
86
+ <div class="content" id="content"></div>
87
+ </div>
88
+ <div id="modalContainer"></div>
89
+
90
+ <script>
91
+ const API='';const pages={dashboard:'📊 仪表盘',agents:'🧠 Agent 管理',platforms:'💬 聊天平台',sessions:'📂 会话管理',memory:'🧠 记忆管理',llm:'⚙️ 大模型设置',executor:'🔧 执行引擎',skills:'🛠 插件管理',files:'📁 工作目录',logs:'📋 查看日志'};
92
+ let currentPage='dashboard';
93
+
94
+ async function api(url,opts={}){const r=await fetch(API+url,{headers:{'Content-Type':'application/json'},...opts});return r.json()}
95
+ function $(id){return document.getElementById(id)}
96
+ function showPage(page){
97
+ currentPage=page;
98
+ document.querySelectorAll('.nav-item').forEach((n,i)=>n.classList.toggle('active',Object.keys(pages)[i]===page));
99
+ $('pageTitle').textContent=pages[page]||page;
100
+ const renderers={dashboard:renderDashboard,agents:renderAgents,platforms:renderPlatforms,sessions:renderSessions,memory:renderMemory,llm:renderLLM,executor:renderExecutor,skills:renderSkills,files:renderFiles,logs:renderLogs};
101
+ if(renderers[page])renderers[page]();
102
+ }
103
+
104
+ // ========== Dashboard ==========
105
+ async function renderDashboard(){
106
+ const s=await api('/api/status');const m=await api('/api/memory/stats');const sk=await api('/api/skills');
107
+ $('content').innerHTML=`<div class="grid">
108
+ <div class="stat"><div class="label">LLM</div><div class="value">${s.provider}/${s.model}</div></div>
109
+ <div class="stat"><div class="label">记忆条目</div><div class="value">${m.total_count||0}</div></div>
110
+ <div class="stat"><div class="label">已注册技能</div><div class="value">${s.skills||sk.length||0}</div></div>
111
+ <div class="stat"><div class="label">会话数</div><div class="value">${m.session_count||0}</div></div>
112
+ <div class="stat"><div class="label">任务队列</div><div class="value">${s.queue?.total_submitted||0} 提交</div></div>
113
+ <div class="stat"><div class="label">短期记忆</div><div class="value">${m.short_term_count||0}</div></div>
114
+ <div class="stat"><div class="label">工作记忆</div><div class="value">${m.working_count||0}</div></div>
115
+ <div class="stat"><div class="label">长期记忆</div><div class="value">${m.long_term_count||0}</div></div>
116
+ </div>`;
117
+ }
118
+
119
+ // ========== Agents ==========
120
+ async function renderAgents(){
121
+ const agents=await api('/api/agents');
122
+ let html='<div class="flex justify-between mb-16"><div></div><button class="btn btn-primary" onclick="createAgent()">+ 新建 Agent</button></div>';
123
+ html+='<div class="grid">';
124
+ for(const a of agents){
125
+ const desc=a.description||a.system_prompt||'默认助手';
126
+ html+=`<div class="card" style="cursor:pointer" onclick="editAgent('${a.name}')">
127
+ <h3 style="color:var(--text)">${a.name}</h3>
128
+ <p style="font-size:13px;color:var(--text2);margin:8px 0">${desc.slice(0,80)}${desc.length>80?'...':''}</p>
129
+ <div class="flex gap-8 mt-8">
130
+ <span class="tag">${a.model||'default'}</span>
131
+ <span class="tag">${a.provider||'openai'}</span>
132
+ </div>
133
+ </div>`;
134
+ }
135
+ html+='</div>';
136
+ $('content').innerHTML=html;
137
+ }
138
+
139
+ function createAgent(){
140
+ const name=prompt('Agent 名称:');if(!name)return;
141
+ api('/api/agents',{method:'POST',body:JSON.stringify({name,description:'新 Agent'})}).then(()=>renderAgents());
142
+ }
143
+
144
+ async function editAgent(name){
145
+ const a=await api(`/api/agents/${name}`);
146
+ $('modalContainer').innerHTML=`<div class="modal-overlay" onclick="closeModal()"><div class="modal" onclick="event.stopPropagation()">
147
+ <h3>🧠 ${a.name}</h3>
148
+ <div class="tabs">
149
+ <div class="tab active" onclick="agentTab(this,'agentTabConfig')">配置</div>
150
+ <div class="tab" onclick="agentTab(this,'agentTabSoul')">Soul.md</div>
151
+ <div class="tab" onclick="agentTab(this,'agentTabIdentity')">Identity.md</div>
152
+ <div class="tab" onclick="agentTab(this,'agentTabUser')">User.md</div>
153
+ </div>
154
+ <div id="agentTabConfig">
155
+ <div class="form-group"><label>模型</label><input id="agModel" value="${a.model||''}"></div>
156
+ <div class="form-group"><label>Provider</label><select id="agProvider"><option ${a.provider==='openai'?'selected':''}>openai</option><option ${a.provider==='anthropic'?'selected':''}>anthropic</option><option ${a.provider==='ollama'?'selected':''}>ollama</option><option ${a.provider==='zhipu'?'selected':''}>zhipu</option></select></div>
157
+ <div class="form-group"><label>描述</label><textarea id="agDesc" rows="2">${a.description||''}</textarea></div>
158
+ <div class="form-group"><label>系统提示</label><textarea id="agSystem" rows="4">${a.system_prompt||''}</textarea></div>
159
+ <div class="flex gap-8 mt-16">
160
+ <button class="btn btn-primary" onclick="saveAgent('${name}')">保存</button>
161
+ <button class="btn btn-danger" onclick="deleteAgent('${name}')">删除</button>
162
+ <button class="btn btn-ghost" onclick="closeModal()">关闭</button>
163
+ </div>
164
+ </div>
165
+ <div id="agentTabSoul" class="hidden">
166
+ <textarea id="agSoul" rows="15" style="min-height:300px">${a.soul||''}</textarea>
167
+ <div class="flex gap-8 mt-8"><button class="btn btn-primary" onclick="saveSoul('${name}')">保存 Soul.md</button></div>
168
+ </div>
169
+ <div id="agentTabIdentity" class="hidden">
170
+ <textarea id="agIdentity" rows="15" style="min-height:300px">${a.identity||''}</textarea>
171
+ <div class="flex gap-8 mt-8"><button class="btn btn-primary" onclick="saveIdentity('${name}')">保存 Identity.md</button></div>
172
+ </div>
173
+ <div id="agentTabUser" class="hidden">
174
+ <p style="font-size:13px;color:var(--text2);margin-bottom:8px">描述用户画像、偏好、习惯等信息,帮助 Agent 更好地理解你的需求。</p>
175
+ <textarea id="agUser" rows="15" style="min-height:300px">${a.user||''}</textarea>
176
+ <div class="flex gap-8 mt-8"><button class="btn btn-primary" onclick="saveUser('${name}')">保存 User.md</button></div>
177
+ </div>
178
+ </div></div>`;
179
+ }
180
+
181
+ function agentTab(el,tabId){
182
+ el.parentElement.querySelectorAll('.tab').forEach(t=>t.classList.remove('active'));
183
+ el.classList.add('active');
184
+ ['agentTabConfig','agentTabSoul','agentTabIdentity','agentTabUser'].forEach(id=>{
185
+ $(id).classList.toggle('hidden',id!==tabId);
186
+ });
187
+ }
188
+
189
+ async function saveAgent(name){
190
+ await api(`/api/agents/${name}`,{method:'PUT',body:JSON.stringify({
191
+ model:$('agModel').value,provider:$('agProvider').value,
192
+ description:$('agDesc').value,system_prompt:$('agSystem').value
193
+ })});alert('已保存');renderAgents();
194
+ }
195
+ async function saveSoul(name){await api(`/api/agents/${name}/soul`,{method:'PUT',body:JSON.stringify({soul:$('agSoul').value})});alert('Soul.md 已保存')}
196
+ async function saveIdentity(name){await api(`/api/agents/${name}/identity`,{method:'PUT',body:JSON.stringify({identity:$('agIdentity').value})});alert('Identity.md 已保存')}
197
+ async function saveUser(name){await api(`/api/agents/${name}/user`,{method:'PUT',body:JSON.stringify({user:$('agUser').value})});alert('User.md 已保存')}
198
+ async function deleteAgent(name){if(!confirm('删除 Agent '+name+'?'))return;await api(`/api/agents/${name}`,{method:'DELETE'});closeModal();renderAgents()}
199
+ function closeModal(){$('modalContainer').innerHTML=''}
200
+
201
+ // ========== Platforms ==========
202
+ async function renderPlatforms(){
203
+ const ps=await api('/api/platforms');
204
+ const icons={telegram:'📱',discord:'🎮',feishu:'🐦',qq:'🐧',wechat:'💚'};
205
+ let html='<div class="grid">';
206
+ for(const p of ps){
207
+ html+=`<div class="card"><div class="flex justify-between items-center">
208
+ <h3 style="color:var(--text)">${icons[p.name]||''} ${p.name}</h3>
209
+ <span class="badge ${p.enabled?'badge-green':'badge-red'}">${p.enabled?'已启用':'未启用'}</span>
210
+ </div>
211
+ <p style="font-size:13px;color:var(--text2);margin-top:8px">Token: ${p.token_set?'已配置':'未配置'}</p>
212
+ <div class="mt-8">
213
+ <button class="btn btn-sm ${p.enabled?'btn-danger':'btn-success'}" onclick="togglePlatform('${p.name}',${!p.enabled})">
214
+ ${p.enabled?'停用':'启用'}
215
+ </button>
216
+ </div></div>`;
217
+ }
218
+ html+='</div>';
219
+ $('content').innerHTML=html;
220
+ }
221
+ async function togglePlatform(name,enable){await api(`/api/platforms/${name}`,{method:'PUT',body:JSON.stringify({enabled})});renderPlatforms()}
222
+
223
+ // ========== Sessions ==========
224
+ async function renderSessions(){
225
+ const ss=await api('/api/sessions');
226
+ let html='<table><tr><th>会话 ID</th><th>消息数</th><th>最后活动</th><th>操作</th></tr>';
227
+ for(const s of ss){
228
+ html+=`<tr><td>${s.id}</td><td>${s.messages}</td><td>${s.last?.slice(0,19)||''}</td>
229
+ <td><button class="btn btn-sm btn-ghost" onclick="viewSession('${s.id}')">查看</button>
230
+ <button class="btn btn-sm btn-danger" onclick="clearSession('${s.id}')">清除</button></td></tr>`;
231
+ }
232
+ html+='</table>';
233
+ if(!ss.length)html='<div class="empty">暂无会话</div>';
234
+ $('content').innerHTML=html;
235
+ }
236
+ async function viewSession(sid){
237
+ const msgs=await api(`/api/sessions/${sid}/messages`);
238
+ let html='<h3 style="margin-bottom:12px">会话: '+sid+'</h3><div class="log-viewer" style="max-height:400px">';
239
+ for(const m of msgs){html+=`<div><span class="${m.role==='user'?'INFO':'WARNING'}">[${m.role}]</span> ${m.content.slice(0,300)}</div>`;}
240
+ html+='</div><button class="btn btn-ghost mt-8" onclick="renderSessions()">返回</button>';
241
+ $('content').innerHTML=html;
242
+ }
243
+ async function clearSession(sid){await api(`/api/sessions/${sid}`,{method:'DELETE'});renderSessions()}
244
+
245
+ // ========== Memory ==========
246
+ async function renderMemory(){
247
+ const stats=await api('/api/memory/stats');
248
+ const lt=await api('/api/memory/long-term');
249
+ let html=`<div class="grid" style="grid-template-columns:repeat(4,1fr);margin-bottom:16px">
250
+ <div class="stat"><div class="label">总计</div><div class="value">${stats.total_count||0}</div></div>
251
+ <div class="stat"><div class="label">短期</div><div class="value">${stats.short_term_count||0}</div></div>
252
+ <div class="stat"><div class="label">工作</div><div class="value">${stats.working_count||0}</div></div>
253
+ <div class="stat"><div class="label">长期</div><div class="value">${stats.long_term_count||0}</div></div>
254
+ </div>`;
255
+ html+='<div class="flex gap-8 mb-16"><input id="memSearch" placeholder="搜索记忆..." onkeydown="if(event.key===\'Enter\')searchMemory()" style="max-width:400px"><button class="btn btn-primary" onclick="searchMemory()">搜索</button><button class="btn btn-ghost" onclick="cleanupMemory()">清理过期</button></div>';
256
+ html+='<h3 style="margin-bottom:8px">长期记忆</h3><table><tr><th>Key</th><th>内容</th><th>重要性</th><th></th></tr>';
257
+ for(const e of lt){
258
+ html+=`<tr><td>${e.key||''}</td><td>${(e.content||e.summary||'').slice(0,150)}</td><td>${e.importance||''}</td>
259
+ <td><button class="btn btn-sm btn-danger" onclick="deleteMemory('${e.id}')">删除</button></td></tr>`;
260
+ }
261
+ html+='</table>';
262
+ if(!lt.length)html+='<div class="empty">暂无长期记忆</div>';
263
+ $('content').innerHTML=html;
264
+ }
265
+ async function searchMemory(){
266
+ const q=$('memSearch').value;if(!q)return;
267
+ const r=await api('/api/memory/search?q='+encodeURIComponent(q));
268
+ let html='<h3>搜索结果: '+r.length+' 条</h3><table><tr><th>Key</th><th>内容</th><th>分类</th></tr>';
269
+ for(const e of r){html+=`<tr><td>${e.key||''}</td><td>${(e.content||'').slice(0,200)}</td><td>${e.category||''}</td></tr>`;}
270
+ html+='</table><button class="btn btn-ghost mt-8" onclick="renderMemory()">返回</button>';
271
+ $('content').innerHTML=html;
272
+ }
273
+ async function deleteMemory(id){await api(`/api/memory/long-term/${id}`,{method:'DELETE'});renderMemory()}
274
+ async function cleanupMemory(){const r=await api('/api/memory/cleanup',{method:'POST'});alert('清理了 '+r.cleaned+' 条');renderMemory()}
275
+
276
+ // ========== LLM ==========
277
+ async function renderLLM(){
278
+ const c=await api('/api/llm');const u=await api('/api/llm/usage');
279
+ let html=`<div class="card"><h3>模型配置</h3>
280
+ <div class="grid" style="grid-template-columns:1fr 1fr">
281
+ <div class="form-group"><label>Provider</label><select id="llmProvider">
282
+ <option ${c.provider==='openai'?'selected':''}>openai</option>
283
+ <option ${c.provider==='anthropic'?'selected':''}>anthropic</option>
284
+ <option ${c.provider==='ollama'?'selected':''}>ollama</option>
285
+ <option ${c.provider==='zhipu'?'selected':''}>zhipu</option></select></div>
286
+ <div class="form-group"><label>模型</label><input id="llmModel" value="${c.model||''}"></div>
287
+ <div class="form-group"><label>Base URL</label><input id="llmUrl" value="${c.base_url||''}"></div>
288
+ <div class="form-group"><label>API Key</label><input id="llmKey" type="password" value="" placeholder="${c.api_key_set?'已配置(留空不修改)':'未配置'}"></div>
289
+ <div class="form-group"><label>Temperature</label><input id="llmTemp" type="number" step="0.1" value="${c.temperature||0.7}"></div>
290
+ <div class="form-group"><label>Max Tokens</label><input id="llmMaxTokens" type="number" value="${c.max_tokens||4096}"></div>
291
+ </div>
292
+ <div class="flex gap-8 mt-16">
293
+ <button class="btn btn-primary" onclick="saveLLM()">保存配置</button>
294
+ <button class="btn btn-success" onclick="testLLM()">测试连接</button>
295
+ </div>
296
+ </div>`;
297
+ html+=`<div class="card"><h3>用量统计</h3>
298
+ <div class="grid" style="grid-template-columns:repeat(4,1fr)">
299
+ <div class="stat"><div class="label">调用次数</div><div class="value">${u.call_count||0}</div></div>
300
+ <div class="stat"><div class="label">Prompt Tokens</div><div class="value">${u.total_prompt_tokens||0}</div></div>
301
+ <div class="stat"><div class="label">Completion Tokens</div><div class="value">${u.total_completion_tokens||0}</div></div>
302
+ <div class="stat"><div class="label">估算费用</div><div class="value">$${(u.total_cost_usd||0).toFixed(4)}</div></div>
303
+ </div></div>`;
304
+ $('content').innerHTML=html;
305
+ }
306
+ async function saveLLM(){
307
+ await api('/api/llm',{method:'PUT',body:JSON.stringify({
308
+ provider:$('llmProvider').value,model:$('llmModel').value,base_url:$('llmUrl').value,
309
+ temperature:parseFloat($('llmTemp').value),max_tokens:parseInt($('llmMaxTokens').value),
310
+ api_key:$('llmKey').value||undefined
311
+ })});alert('已保存');
312
+ }
313
+ async function testLLM(){
314
+ const btn=event.target;btn.textContent='测试中...';btn.disabled=true;
315
+ const r=await api('/api/llm/test',{method:'POST'});
316
+ btn.textContent='测试连接';btn.disabled=false;
317
+ alert(r.ok?'连接成功: '+r.response:'连接失败: '+r.error);
318
+ }
319
+
320
+ // ========== Executor ==========
321
+ async function renderExecutor(){
322
+ const e=await api('/api/executor');
323
+ const isSandbox=e.mode==='sandbox';
324
+ const dockerOk=e.docker_available;
325
+ let html=`<div class="card"><h3>执行模式</h3>
326
+ <div style="display:flex;gap:12px;margin-bottom:16px">
327
+ <label style="display:flex;align-items:center;gap:6px;cursor:pointer;padding:16px 24px;border-radius:var(--radius);border:2px solid ${!isSandbox?'var(--primary)':'var(--border)'};background:${!isSandbox?'#6366f122':'transparent'};flex:1">
328
+ <input type="radio" name="execMode" value="local" ${!isSandbox?'checked':''} onchange="switchMode('local')">
329
+ <div><strong>🖥️ 本机执行</strong><br><span style="font-size:12px;color:var(--text2)">直接在本机运行代码,功能完整,速度最快</span></div>
330
+ </label>
331
+ <label style="display:flex;align-items:center;gap:6px;cursor:pointer;padding:16px 24px;border-radius:var(--radius);border:2px solid ${isSandbox?'var(--primary)':'var(--border)'};background:${isSandbox?'#6366f122':'transparent'};flex:1">
332
+ <input type="radio" name="execMode" value="sandbox" ${isSandbox?'checked':''} onchange="switchMode('sandbox')" ${!dockerOk?'disabled':''}>
333
+ <div><strong>📦 沙盒执行 (Docker)</strong><br><span style="font-size:12px;color:var(--text2)">在隔离容器中运行,更安全${!dockerOk?' (Docker 不可用)':''}</span></div>
334
+ </label>
335
+ </div>
336
+ <div style="font-size:13px;color:var(--text2)">
337
+ 当前模式: <span class="badge ${isSandbox?'badge-yellow':'badge-green'}">${isSandbox?'沙盒 (Docker)':'本机'}</span>
338
+ Docker 状态: <span class="badge ${dockerOk?'badge-green':'badge-red'}">${dockerOk?'可用':'不可用'}</span>
339
+ 累计执行: <span class="tag">${e.execution_count||0} 次</span>
340
+ </div>
341
+ </div>`;
342
+ html+=`<div class="card"><h3>沙盒设置</h3>
343
+ <div class="grid" style="grid-template-columns:1fr 1fr">
344
+ <div class="form-group"><label>Docker 镜像</label><input id="sbImage" value="${e.sandbox_image||'python:3.12-slim'}"></div>
345
+ <div class="form-group"><label>内存限制</label><input id="sbMemory" value="${e.sandbox_memory||'512m'}" placeholder="512m"></div>
346
+ <div class="form-group"><label>网络访问</label><select id="sbNetwork"><option ${!e.sandbox_network?'selected':''} value="false">禁止 (更安全)</option><option ${e.sandbox_network?'selected':''} value="true">允许</option></select></div>
347
+ </div>
348
+ <div class="flex gap-8 mt-16">
349
+ <button class="btn btn-primary" onclick="saveExecutor()">保存设置</button>
350
+ </div>
351
+ </div>`;
352
+ html+=`<div class="card"><h3>执行参数</h3>
353
+ <div class="grid" style="grid-template-columns:1fr 1fr 1fr">
354
+ <div class="form-group"><label>超时时间 (秒)</label><input id="exTimeout" type="number" value="${e.timeout||300}"></div>
355
+ <div class="form-group"><label>自动重试</label><input id="exRetries" type="number" value="2"></div>
356
+ <div class="form-group"><label>自动修复</label><select id="exAutoFix"><option ${e.auto_fix?'selected':''} value="true">开启</option><option ${!e.auto_fix?'selected':''} value="false">关闭</option></select></div>
357
+ </div></div>`;
358
+ $('content').innerHTML=html;
359
+ }
360
+ async function switchMode(mode){
361
+ const r=await api('/api/executor',{method:'PUT',body:JSON.stringify({execution_mode:mode})});
362
+ if(!r.ok){alert('切换失败: '+(r.error||'Docker 不可用'));renderExecutor();}
363
+ else renderExecutor();
364
+ }
365
+ async function saveExecutor(){
366
+ await api('/api/executor',{method:'PUT',body:JSON.stringify({
367
+ sandbox_image:$('sbImage').value,sandbox_memory:$('sbMemory').value,
368
+ sandbox_network:$('sbNetwork').value==='true',
369
+ timeout:parseInt($('exTimeout').value),auto_fix:$('exAutoFix').value==='true'
370
+ })});alert('已保存');renderExecutor();
371
+ }
372
+
373
+ // ========== Skills ==========
374
+ async function renderSkills(){
375
+ const sk=await api('/api/skills');
376
+ let html=`<p style="color:var(--text2);margin-bottom:16px">共 ${sk.length} 个技能已注册</p>`;
377
+ html+='<div class="grid">';
378
+ for(const s of sk){
379
+ const src=s.source||'builtin';
380
+ html+=`<div class="card">
381
+ <div class="flex justify-between items-center">
382
+ <h3 style="color:var(--text)">${s.name}</h3>
383
+ <span class="badge ${src==='openclaw_external'?'badge-yellow':'badge-green'}">${src==='openclaw_external'?'OpenClaw':'内置'}</span>
384
+ </div>
385
+ <p style="font-size:13px;color:var(--text2);margin-top:6px">${(s.description||'').slice(0,100)}</p>
386
+ ${s.dangerous?'<span class="badge badge-red mt-8">⚠️ 危险操作</span>':''}
387
+ </div>`;
388
+ }
389
+ html+='</div>';
390
+ $('content').innerHTML=html;
391
+ }
392
+
393
+ // ========== Files ==========
394
+ async function renderFiles(){
395
+ const wd=await api('/api/workdir');const files=await api('/api/workdir/files');
396
+ let html=`<div class="flex items-center gap-8 mb-16">
397
+ <span style="font-size:14px;color:var(--text2)">工作目录: ${wd.path}</span>
398
+ <button class="btn btn-sm btn-ghost" onclick="changeWorkdir()">更改</button>
399
+ <button class="btn btn-sm btn-ghost" onclick="renderFiles()">刷新</button>
400
+ </div>`;
401
+ html+='<table><tr><th>名称</th><th>类型</th><th>大小</th></tr>';
402
+ for(const f of files){
403
+ const icon=f.type==='dir'?'📁':'📄';
404
+ const size=f.type==='file'?(f.size>1024?(f.size/1024).toFixed(1)+'KB':f.size+'B'):'-';
405
+ html+=`<tr><td>${icon} ${f.name}</td><td>${f.type}</td><td>${size}</td></tr>`;
406
+ }
407
+ if(!files.length)html+='<tr><td colspan="3" class="empty">目录为空</td></tr>';
408
+ html+='</table>';
409
+ $('content').innerHTML=html;
410
+ }
411
+ async function changeWorkdir(){
412
+ const p=prompt('新路径:');if(!p)return;
413
+ await api('/api/workdir',{method:'PUT',body:JSON.stringify({path:p})});renderFiles();
414
+ }
415
+
416
+ // ========== Logs ==========
417
+ async function renderLogs(){
418
+ let html=`<div class="flex gap-8 mb-16">
419
+ <select id="logLines" style="width:auto"><option value="100">100 行</option><option value="500" selected>500 行</option><option value="1000">1000 行</option></select>
420
+ <button class="btn btn-primary" onclick="loadLogs()">刷新</button>
421
+ <button class="btn btn-ghost" onclick="toggleLogStream()" id="streamBtn">实时日志</button>
422
+ </div>
423
+ <div class="log-viewer" id="logViewer" style="height:calc(100vh - 220px)">加载中...</div>`;
424
+ $('content').innerHTML=html;
425
+ loadLogs();
426
+ }
427
+
428
+ async function loadLogs(){
429
+ const lines=$('logLines').value;
430
+ const logs=await api(`/api/logs?lines=${lines}`);
431
+ $('logViewer').innerHTML=logs.map(l=>`<div>${escHtml(l)}</div>`).join('');
432
+ $('logViewer').scrollTop=$('logViewer').scrollHeight;
433
+ }
434
+
435
+ let logStreamActive=false;
436
+ async function toggleLogStream(){
437
+ if(logStreamActive){logStreamActive=false;$('streamBtn').textContent='实时日志';return;}
438
+ logStreamActive=true;$('streamBtn').textContent='停止实时';
439
+ const es=new EventSource(API+'/api/logs/stream');
440
+ es.onmessage=function(e){
441
+ try{
442
+ const lines=JSON.parse(e.data).split('\n');
443
+ for(const l of lines){$('logViewer').innerHTML+=`<div>${escHtml(l)}</div>`;}
444
+ $('logViewer').scrollTop=$('logViewer').scrollHeight;
445
+ while($('logViewer').children.length>2000)$('logViewer').removeChild($('logViewer').firstChild);
446
+ }catch(ex){}
447
+ };
448
+ es.onerror=function(){if(logStreamActive)setTimeout(()=>{},3000)};
449
+ }
450
+
451
+ function escHtml(s){return s.replace(/&/g,'&amp;').replace(/</g,'&lt;').replace(/>/g,'&gt;')}
452
+
453
+ // Init
454
+ showPage('dashboard');
455
+ setInterval(()=>{api('/api/status').catch(()=>{})},30000);
456
+ </script>
457
+ </body>
458
+ </html>