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,507 @@
1
+ ---
2
+ name: pptx
3
+ description: "Presentation creation, editing, and analysis. When Claude needs to work with presentations (.pptx files) for: (1) Creating new presentations, (2) Modifying or editing content, (3) Working with layouts, (4) Adding comments or speaker notes, or any other presentation tasks"
4
+ license: Proprietary. LICENSE.txt has complete terms
5
+ ---
6
+
7
+ # PPTX creation, editing, and analysis
8
+
9
+ ## Overview
10
+
11
+ A user may ask you to create, edit, or analyze the contents of a .pptx file. A .pptx file is essentially a ZIP archive containing XML files and other resources that you can read or edit. You have different tools and workflows available for different tasks.
12
+
13
+ ## Reading and analyzing content
14
+
15
+ ### Text extraction
16
+ If you just need to read the text contents of a presentation, you should convert the document to markdown:
17
+
18
+ ```bash
19
+ # Convert document to markdown
20
+ python -m markitdown path-to-file.pptx
21
+ ```
22
+
23
+ ### Raw XML access
24
+ You need raw XML access for: comments, speaker notes, slide layouts, animations, design elements, and complex formatting. For any of these features, you'll need to unpack a presentation and read its raw XML contents.
25
+
26
+ #### Unpacking a file
27
+ `python ooxml/scripts/unpack.py <office_file> <output_dir>`
28
+
29
+ **Note**: The unpack.py script is located at `skills/pptx/ooxml/scripts/unpack.py` relative to the project root. If the script doesn't exist at this path, use `find . -name "unpack.py"` to locate it.
30
+
31
+ #### Key file structures
32
+ * `ppt/presentation.xml` - Main presentation metadata and slide references
33
+ * `ppt/slides/slide{N}.xml` - Individual slide contents (slide1.xml, slide2.xml, etc.)
34
+ * `ppt/notesSlides/notesSlide{N}.xml` - Speaker notes for each slide
35
+ * `ppt/comments/modernComment_*.xml` - Comments for specific slides
36
+ * `ppt/slideLayouts/` - Layout templates for slides
37
+ * `ppt/slideMasters/` - Master slide templates
38
+ * `ppt/theme/` - Theme and styling information
39
+ * `ppt/media/` - Images and other media files
40
+
41
+ #### Typography and color extraction
42
+ **When given an example design to emulate**: Always analyze the presentation's typography and colors first using the methods below:
43
+ 1. **Read theme file**: Check `ppt/theme/theme1.xml` for colors (`<a:clrScheme>`) and fonts (`<a:fontScheme>`)
44
+ 2. **Sample slide content**: Examine `ppt/slides/slide1.xml` for actual font usage (`<a:rPr>`) and colors
45
+ 3. **Search for patterns**: Use grep to find color (`<a:solidFill>`, `<a:srgbClr>`) and font references across all XML files
46
+
47
+ ## Creating a new PowerPoint presentation **without a template**
48
+
49
+ When creating a new PowerPoint presentation from scratch, use the **html2pptx** workflow to convert HTML slides to PowerPoint with accurate positioning.
50
+
51
+ ### Design Principles
52
+
53
+ **CRITICAL**: Before creating any presentation, analyze the content and choose appropriate design elements:
54
+ 1. **Consider the subject matter**: What is this presentation about? What tone, industry, or mood does it suggest?
55
+ 2. **Check for branding**: If the user mentions a company/organization, consider their brand colors and identity
56
+ 3. **Match palette to content**: Select colors that reflect the subject
57
+ 4. **State your approach**: Explain your design choices before writing code
58
+
59
+ **Design Philosophy — "Swiss Style" over "Bootstrap"**:
60
+ - Treat each slide as a single, cohesive canvas with unity
61
+ - Use **negative space / whitespace** as the primary active element to separate content
62
+ - Establish hierarchy through font size/weight, not boxes/containers
63
+ - Prioritize **asymmetrical layouts, floating elements, and overlapping layers** over rigid, symmetrical grid systems
64
+ - Minimize the use of grid systems or nested frames; instead use parallel text directly listed in a clean format
65
+
66
+ **Requirements**:
67
+ - ✅ State your content-informed design approach BEFORE writing code
68
+ - ✅ Use web-safe fonts only: Arial, Helvetica, Times New Roman, Georgia, Courier New, Verdana, Tahoma, Trebuchet MS, Impact
69
+ - ✅ Create clear visual hierarchy through size, weight, and color — emphasize core points with larger fonts or numbers, creating contrast with smaller elements
70
+ - ✅ Ensure readability: strong contrast, appropriately sized text, clean alignment
71
+ - ✅ Be consistent: use the same color palette and font style throughout the entire presentation — do not change the main color or font family from slide to slide
72
+ - ✅ Use keywords, not long sentences — keep each slide concise (avoid more than 100 words per slide)
73
+ - ✅ Limit emphasis to only the most important elements (no more than 2-3 instances per slide)
74
+
75
+ #### Color Palette Selection
76
+
77
+ **Color System — Background / Primary / Accent**:
78
+
79
+ Each presentation uses exactly ONE color group with three roles:
80
+ - **Background**: Fixed, used only for the slide background
81
+ - **Primary**: Used for all main elements — titles, headers, frames, and content blocks (≥80% of non-background color)
82
+ - **Accent**: Used rarely (≤5%) for highlights only, never for decoration
83
+
84
+ **Color Rules**:
85
+ - Same type = same color. All titles share one color; all content blocks share one color
86
+ - Keep one dominant color (Primary). Accent appears only where emphasis is needed
87
+ - Use the same color (mostly Primary) for parallel elements on the same slide, such as icons and keywords
88
+ - Global consistency > ratio balance > color variety
89
+ - Visual ratio (strictly follow): **Primary ≥ 80% | Accent ≤ 5% | Background fixed**
90
+ - Minimize the use of color gradients
91
+ - **Background vs text contrast**: Background color and text/Primary color must have strong contrast. Never use similar or same-tone colors for background and text (e.g., dark background with dark text, or light background with light text). When using a background image, add a semi-transparent overlay to guarantee text readability
92
+ - **Shape fill vs slide background**: Decorative shapes or content card backgrounds must be clearly distinguishable from the slide background color — avoid using the same or nearly the same color for both
93
+
94
+ **Available Color Groups** (select ONE group and use ONLY that group for all slides):
95
+
96
+ | Style | Background | Primary | Accent |
97
+ |---|---|---|---|
98
+ | Warm Modern (Light) | #F4F1E9 | #15857A | #FF6A3B |
99
+ | Warm Modern (Dark) | #111111 | #15857A | #FF6A3B |
100
+ | Warm Modern (Mauve) | #111111 | #7C3D5E | #FF7E5E |
101
+ | Cool Modern (Green) | #FEFEFE | #44B54B | #1399FF |
102
+ | Cool Modern (Navy) | #09325E | #FFFFFF | #7DE545 |
103
+ | Cool Modern (Blue) | #FEFEFE | #1284BA | #FF862F |
104
+ | Cool Modern (Bold) | #FEFEFE | #133EFF | #00CD82 |
105
+ | Deep Mineral (Blue) | #162235 | #FFFFFF | #37DCF2 |
106
+ | Deep Mineral (Green) | #193328 | #FFFFFF | #E7E950 |
107
+ | Soft Neutral (Yellow) | #F7F3E6 | #E7F177 | #106188 |
108
+ | Soft Neutral (Lavender) | #EBDCEF | #73593C | #B13DC6 |
109
+ | Soft Neutral (Olive) | #8B9558 | #262626 | #E1DE2D |
110
+ | Minimalism (Warm) | #F3F1ED | #000000 | #D6C096 |
111
+ | Minimalism (Clean) | #FFFFFF | #000000 | #A6C40D |
112
+ | Minimalism (Gray) | #F3F1ED | #393939 | #FFFFFF |
113
+ | Warm Retro (Red) | #F4EEEA | #882F1C | #FEE79B |
114
+ | Warm Retro (Forest) | #F4F1E9 | #2A4A3A | #C89F62 |
115
+ | Warm Retro (Brown) | #554737 | #FFFFFF | #66D4FF |
116
+
117
+ You may create your own color group only when the user requests specific colors or the provided groups are not suitable — but still follow the Background/Primary/Accent structure and ratio rules strictly.
118
+
119
+ #### Visual & Layout Style
120
+
121
+ **Layout Approach**:
122
+ - **Vertical balance**: When a slide has limited content (e.g., only a title + a few bullet points or a single card), vertically center the content on the slide using flexbox (`justify-content: center` on body or a wrapper) so the slide doesn't look top-heavy with empty space at the bottom. Only top-align content when the slide is full or nearly full
123
+ - Create compact layouts: reduce overall vertical height, decrease internal padding/margins, tighten space between elements
124
+ - Use creative, asymmetric arrangements — prioritize visual interest over rigid grids
125
+ - Asymmetric column widths (30/70, 40/60, 25/75) are preferred over equal splits
126
+ - Floating text boxes and overlapping layers add depth
127
+ - Use negative space as a deliberate design element
128
+ - Avoid adding too much content per slide — if content exceeds allowed space, remove or summarize lowest-priority items while keeping key points
129
+
130
+ **Typography**:
131
+ - Establish hierarchy through size contrast (large titles vs smaller body text)
132
+ - All-caps headers with wide letter spacing for emphasis
133
+ - Numbered sections in oversized display type
134
+ - Monospace (Courier New) for data/stats/technical content
135
+ - Keep emphasized text size smaller than headings/titles
136
+ - Do not decrease font size below readable minimums just to fit more content
137
+ - Do not apply text-shadows or luminescence effects
138
+
139
+ **Cover Slide (First Slide)**:
140
+ - Title should be prominently sized and either centered (both horizontally and vertically) or left-aligned with vertical centering
141
+ - **CRITICAL**: To vertically center content, the body MUST use `display: flex; flex-direction: column; justify-content: center;`. Missing `flex-direction: column` will cause content to stack horizontally and pin to the top (y=0), completely breaking the cover layout
142
+ - If left-aligned, several keywords or data highlights can be placed on the right side, emphasized in bold
143
+ - Subtitle should be noticeably smaller than the title
144
+ - If speaker/time info is present, align uniformly
145
+ - Background image (if used): only one image with an opaque/semi-transparent mask
146
+
147
+ **Content Slides**:
148
+ - Maintain consistent design using the same color/font palette across all slides
149
+ - Content slide backgrounds should be consistent across all slides
150
+ - Headers should have consistent layout/style and similar color design across slides
151
+ - If chapter/section divider slides are planned, they should have a consistent layout and color scheme
152
+
153
+ **Charts & Data**:
154
+ - Monochrome charts with single accent color for key data
155
+ - Data labels directly on elements (no legends when possible)
156
+ - Oversized numbers for key metrics
157
+ - Minimal gridlines or none at all
158
+ - Horizontal bar charts instead of vertical when appropriate
159
+
160
+ **Background Treatments**:
161
+ - Solid color blocks occupying 40-60% of slide
162
+ - Split backgrounds (two colors, diagonal or vertical)
163
+ - Edge-to-edge color bands
164
+ - Minimize gradient fills
165
+
166
+ ### Layout Tips
167
+ **When creating slides with charts or tables:**
168
+ - **Two-column layout (PREFERRED)**: Use a header spanning the full width, then two columns below — text/bullets in one column and the featured content in the other. Use asymmetric column widths (e.g., 40%/60% split) to optimize space for each content type.
169
+ - **Full-slide layout**: Let the featured content (chart/table) take up the entire slide for maximum impact and readability
170
+ - **NEVER vertically stack**: Do not place charts/tables below text in a single column — this causes poor readability and layout issues
171
+ - Minimize vertical stacking and nested frames; instead, directly list parallel text points in a clean format
172
+
173
+ ### Workflow
174
+ 1. **MANDATORY - READ ENTIRE FILE**: Read [`html2pptx.md`](html2pptx.md) completely from start to finish. **NEVER set any range limits when reading this file.** Read the full file content for detailed syntax, critical formatting rules, and best practices before proceeding with presentation creation.
175
+ 2. Create an HTML file for each slide with proper dimensions (e.g., 720pt × 405pt for 16:9)
176
+ - Use `<p>`, `<h1>`-`<h6>`, `<ul>`, `<ol>` for all text content
177
+ - Use `class="placeholder"` for areas where charts/tables will be added (render with gray background for visibility)
178
+ - **CRITICAL**: Rasterize gradients and icons as PNG images FIRST using Sharp, then reference in HTML
179
+ - **LAYOUT**: For slides with charts/tables/images, use either full-slide layout or two-column layout for better readability
180
+ 3. Create and run a JavaScript file using the [`html2pptx.js`](scripts/html2pptx.js) library to convert HTML slides to PowerPoint and save the presentation
181
+ - Use the `html2pptx()` function to process each HTML file
182
+ - Add charts and tables to placeholder areas using PptxGenJS API
183
+ - Save the presentation using `pptx.writeFile()`
184
+ 4. **Visual validation**: Generate thumbnails and inspect for layout issues
185
+ - Create thumbnail grid: `python scripts/thumbnail.py output.pptx workspace/thumbnails --cols 4`
186
+ - Read and carefully examine the thumbnail image for:
187
+ - **Text cutoff**: Text being cut off by header bars, shapes, or slide edges
188
+ - **Text overlap**: Text overlapping with other text or shapes
189
+ - **Positioning issues**: Content too close to slide boundaries or other elements
190
+ - **Contrast issues**: Insufficient contrast between text and backgrounds
191
+ - If issues found, adjust HTML margins/spacing/colors and regenerate the presentation
192
+ - Repeat until all slides are visually correct
193
+
194
+ ## Editing an existing PowerPoint presentation
195
+
196
+ When edit slides in an existing PowerPoint presentation, you need to work with the raw Office Open XML (OOXML) format. This involves unpacking the .pptx file, editing the XML content, and repacking it.
197
+
198
+ ### Workflow
199
+ 1. **MANDATORY - READ ENTIRE FILE**: Read [`ooxml.md`](ooxml.md) (~500 lines) completely from start to finish. **NEVER set any range limits when reading this file.** Read the full file content for detailed guidance on OOXML structure and editing workflows before any presentation editing.
200
+ 2. Unpack the presentation: `python ooxml/scripts/unpack.py <office_file> <output_dir>`
201
+ 3. Edit the XML files (primarily `ppt/slides/slide{N}.xml` and related files)
202
+ 4. **CRITICAL**: Validate immediately after each edit and fix any validation errors before proceeding: `python ooxml/scripts/validate.py <dir> --original <file>`
203
+ 5. Pack the final presentation: `python ooxml/scripts/pack.py <input_directory> <office_file>`
204
+
205
+ ## Creating a new PowerPoint presentation **using a template**
206
+
207
+ When you need to create a presentation that follows an existing template's design, you'll need to duplicate and re-arrange template slides before then replacing placeholder context.
208
+
209
+ ### Workflow
210
+ 1. **Extract template text AND create visual thumbnail grid**:
211
+ * Extract text: `python -m markitdown template.pptx > template-content.md`
212
+ * Read `template-content.md`: Read the entire file to understand the contents of the template presentation. **NEVER set any range limits when reading this file.**
213
+ * Create thumbnail grids: `python scripts/thumbnail.py template.pptx`
214
+ * See [Creating Thumbnail Grids](#creating-thumbnail-grids) section for more details
215
+
216
+ 2. **Analyze template and save inventory to a file**:
217
+ * **Visual Analysis**: Review thumbnail grid(s) to understand slide layouts, design patterns, and visual structure
218
+ * Create and save a template inventory file at `template-inventory.md` containing:
219
+ ```markdown
220
+ # Template Inventory Analysis
221
+ **Total Slides: [count]**
222
+ **IMPORTANT: Slides are 0-indexed (first slide = 0, last slide = count-1)**
223
+
224
+ ## [Category Name]
225
+ - Slide 0: [Layout code if available] - Description/purpose
226
+ - Slide 1: [Layout code] - Description/purpose
227
+ - Slide 2: [Layout code] - Description/purpose
228
+ [... EVERY slide must be listed individually with its index ...]
229
+ ```
230
+ * **Using the thumbnail grid**: Reference the visual thumbnails to identify:
231
+ - Layout patterns (title slides, content layouts, section dividers)
232
+ - Image placeholder locations and counts
233
+ - Design consistency across slide groups
234
+ - Visual hierarchy and structure
235
+ * This inventory file is REQUIRED for selecting appropriate templates in the next step
236
+
237
+ 3. **Create presentation outline based on template inventory**:
238
+ * Review available templates from step 2.
239
+ * Choose an intro or title template for the first slide. This should be one of the first templates.
240
+ * Choose safe, text-based layouts for the other slides.
241
+ * **CRITICAL: Match layout structure to actual content**:
242
+ - Single-column layouts: Use for unified narrative or single topic
243
+ - Two-column layouts: Use ONLY when you have exactly 2 distinct items/concepts
244
+ - Three-column layouts: Use ONLY when you have exactly 3 distinct items/concepts
245
+ - Image + text layouts: Use ONLY when you have actual images to insert
246
+ - Quote layouts: Use ONLY for actual quotes from people (with attribution), never for emphasis
247
+ - Never use layouts with more placeholders than you have content
248
+ - If you have 2 items, don't force them into a 3-column layout
249
+ - If you have 4+ items, consider breaking into multiple slides or using a list format
250
+ * Count your actual content pieces BEFORE selecting the layout
251
+ * Verify each placeholder in the chosen layout will be filled with meaningful content
252
+ * Select one option representing the **best** layout for each content section.
253
+ * Save `outline.md` with content AND template mapping that leverages available designs
254
+ * Example template mapping:
255
+ ```
256
+ # Template slides to use (0-based indexing)
257
+ # WARNING: Verify indices are within range! Template with 73 slides has indices 0-72
258
+ # Mapping: slide numbers from outline -> template slide indices
259
+ template_mapping = [
260
+ 0, # Use slide 0 (Title/Cover)
261
+ 34, # Use slide 34 (B1: Title and body)
262
+ 34, # Use slide 34 again (duplicate for second B1)
263
+ 50, # Use slide 50 (E1: Quote)
264
+ 54, # Use slide 54 (F2: Closing + Text)
265
+ ]
266
+ ```
267
+
268
+ 4. **Duplicate, reorder, and delete slides using `rearrange.py`**:
269
+ * Use the `scripts/rearrange.py` script to create a new presentation with slides in the desired order:
270
+ ```bash
271
+ python scripts/rearrange.py template.pptx working.pptx 0,34,34,50,52
272
+ ```
273
+ * The script handles duplicating repeated slides, deleting unused slides, and reordering automatically
274
+ * Slide indices are 0-based (first slide is 0, second is 1, etc.)
275
+ * The same slide index can appear multiple times to duplicate that slide
276
+
277
+ 5. **Extract ALL text using the `inventory.py` script**:
278
+ * **Run inventory extraction**:
279
+ ```bash
280
+ python scripts/inventory.py working.pptx text-inventory.json
281
+ ```
282
+ * **Read text-inventory.json**: Read the entire text-inventory.json file to understand all shapes and their properties. **NEVER set any range limits when reading this file.**
283
+
284
+ * The inventory JSON structure:
285
+ ```json
286
+ {
287
+ "slide-0": {
288
+ "shape-0": {
289
+ "placeholder_type": "TITLE", // or null for non-placeholders
290
+ "left": 1.5, // position in inches
291
+ "top": 2.0,
292
+ "width": 7.5,
293
+ "height": 1.2,
294
+ "paragraphs": [
295
+ {
296
+ "text": "Paragraph text",
297
+ // Optional properties (only included when non-default):
298
+ "bullet": true, // explicit bullet detected
299
+ "level": 0, // only included when bullet is true
300
+ "alignment": "CENTER", // CENTER, RIGHT (not LEFT)
301
+ "space_before": 10.0, // space before paragraph in points
302
+ "space_after": 6.0, // space after paragraph in points
303
+ "line_spacing": 22.4, // line spacing in points
304
+ "font_name": "Arial", // from first run
305
+ "font_size": 14.0, // in points
306
+ "bold": true,
307
+ "italic": false,
308
+ "underline": false,
309
+ "color": "FF0000" // RGB color
310
+ }
311
+ ]
312
+ }
313
+ }
314
+ }
315
+ ```
316
+
317
+ * Key features:
318
+ - **Slides**: Named as "slide-0", "slide-1", etc.
319
+ - **Shapes**: Ordered by visual position (top-to-bottom, left-to-right) as "shape-0", "shape-1", etc.
320
+ - **Placeholder types**: TITLE, CENTER_TITLE, SUBTITLE, BODY, OBJECT, or null
321
+ - **Default font size**: `default_font_size` in points extracted from layout placeholders (when available)
322
+ - **Slide numbers are filtered**: Shapes with SLIDE_NUMBER placeholder type are automatically excluded from inventory
323
+ - **Bullets**: When `bullet: true`, `level` is always included (even if 0)
324
+ - **Spacing**: `space_before`, `space_after`, and `line_spacing` in points (only included when set)
325
+ - **Colors**: `color` for RGB (e.g., "FF0000"), `theme_color` for theme colors (e.g., "DARK_1")
326
+ - **Properties**: Only non-default values are included in the output
327
+
328
+ 6. **Generate replacement text and save the data to a JSON file**
329
+ Based on the text inventory from the previous step:
330
+ - **CRITICAL**: First verify which shapes exist in the inventory - only reference shapes that are actually present
331
+ - **VALIDATION**: The replace.py script will validate that all shapes in your replacement JSON exist in the inventory
332
+ - If you reference a non-existent shape, you'll get an error showing available shapes
333
+ - If you reference a non-existent slide, you'll get an error indicating the slide doesn't exist
334
+ - All validation errors are shown at once before the script exits
335
+ - **IMPORTANT**: The replace.py script uses inventory.py internally to identify ALL text shapes
336
+ - **AUTOMATIC CLEARING**: ALL text shapes from the inventory will be cleared unless you provide "paragraphs" for them
337
+ - Add a "paragraphs" field to shapes that need content (not "replacement_paragraphs")
338
+ - Shapes without "paragraphs" in the replacement JSON will have their text cleared automatically
339
+ - Paragraphs with bullets will be automatically left aligned. Don't set the `alignment` property on when `"bullet": true`
340
+ - Generate appropriate replacement content for placeholder text
341
+ - Use shape size to determine appropriate content length
342
+ - **CRITICAL**: Include paragraph properties from the original inventory - don't just provide text
343
+ - **IMPORTANT**: When bullet: true, do NOT include bullet symbols (•, -, *) in text - they're added automatically
344
+ - **ESSENTIAL FORMATTING RULES**:
345
+ - Headers/titles should typically have `"bold": true`
346
+ - List items should have `"bullet": true, "level": 0` (level is required when bullet is true)
347
+ - Preserve any alignment properties (e.g., `"alignment": "CENTER"` for centered text)
348
+ - Include font properties when different from default (e.g., `"font_size": 14.0`, `"font_name": "Lora"`)
349
+ - Colors: Use `"color": "FF0000"` for RGB or `"theme_color": "DARK_1"` for theme colors
350
+ - The replacement script expects **properly formatted paragraphs**, not just text strings
351
+ - **Overlapping shapes**: Prefer shapes with larger default_font_size or more appropriate placeholder_type
352
+ - Save the updated inventory with replacements to `replacement-text.json`
353
+ - **WARNING**: Different template layouts have different shape counts - always check the actual inventory before creating replacements
354
+
355
+ Example paragraphs field showing proper formatting:
356
+ ```json
357
+ "paragraphs": [
358
+ {
359
+ "text": "New presentation title text",
360
+ "alignment": "CENTER",
361
+ "bold": true
362
+ },
363
+ {
364
+ "text": "Section Header",
365
+ "bold": true
366
+ },
367
+ {
368
+ "text": "First bullet point without bullet symbol",
369
+ "bullet": true,
370
+ "level": 0
371
+ },
372
+ {
373
+ "text": "Red colored text",
374
+ "color": "FF0000"
375
+ },
376
+ {
377
+ "text": "Theme colored text",
378
+ "theme_color": "DARK_1"
379
+ },
380
+ {
381
+ "text": "Regular paragraph text without special formatting"
382
+ }
383
+ ]
384
+ ```
385
+
386
+ **Shapes not listed in the replacement JSON are automatically cleared**:
387
+ ```json
388
+ {
389
+ "slide-0": {
390
+ "shape-0": {
391
+ "paragraphs": [...] // This shape gets new text
392
+ }
393
+ // shape-1 and shape-2 from inventory will be cleared automatically
394
+ }
395
+ }
396
+ ```
397
+
398
+ **Common formatting patterns for presentations**:
399
+ - Title slides: Bold text, sometimes centered
400
+ - Section headers within slides: Bold text
401
+ - Bullet lists: Each item needs `"bullet": true, "level": 0`
402
+ - Body text: Usually no special properties needed
403
+ - Quotes: May have special alignment or font properties
404
+
405
+ 7. **Apply replacements using the `replace.py` script**
406
+ ```bash
407
+ python scripts/replace.py working.pptx replacement-text.json output.pptx
408
+ ```
409
+
410
+ The script will:
411
+ - First extract the inventory of ALL text shapes using functions from inventory.py
412
+ - Validate that all shapes in the replacement JSON exist in the inventory
413
+ - Clear text from ALL shapes identified in the inventory
414
+ - Apply new text only to shapes with "paragraphs" defined in the replacement JSON
415
+ - Preserve formatting by applying paragraph properties from the JSON
416
+ - Handle bullets, alignment, font properties, and colors automatically
417
+ - Save the updated presentation
418
+
419
+ Example validation errors:
420
+ ```
421
+ ERROR: Invalid shapes in replacement JSON:
422
+ - Shape 'shape-99' not found on 'slide-0'. Available shapes: shape-0, shape-1, shape-4
423
+ - Slide 'slide-999' not found in inventory
424
+ ```
425
+
426
+ ```
427
+ ERROR: Replacement text made overflow worse in these shapes:
428
+ - slide-0/shape-2: overflow worsened by 1.25" (was 0.00", now 1.25")
429
+ ```
430
+
431
+ ## Creating Thumbnail Grids
432
+
433
+ To create visual thumbnail grids of PowerPoint slides for quick analysis and reference:
434
+
435
+ ```bash
436
+ python scripts/thumbnail.py template.pptx [output_prefix]
437
+ ```
438
+
439
+ **Features**:
440
+ - Creates: `thumbnails.jpg` (or `thumbnails-1.jpg`, `thumbnails-2.jpg`, etc. for large decks)
441
+ - Default: 5 columns, max 30 slides per grid (5×6)
442
+ - Custom prefix: `python scripts/thumbnail.py template.pptx my-grid`
443
+ - Note: The output prefix should include the path if you want output in a specific directory (e.g., `workspace/my-grid`)
444
+ - Adjust columns: `--cols 4` (range: 3-6, affects slides per grid)
445
+ - Grid limits: 3 cols = 12 slides/grid, 4 cols = 20, 5 cols = 30, 6 cols = 42
446
+ - Slides are zero-indexed (Slide 0, Slide 1, etc.)
447
+
448
+ **Use cases**:
449
+ - Template analysis: Quickly understand slide layouts and design patterns
450
+ - Content review: Visual overview of entire presentation
451
+ - Navigation reference: Find specific slides by their visual appearance
452
+ - Quality check: Verify all slides are properly formatted
453
+
454
+ **Examples**:
455
+ ```bash
456
+ # Basic usage
457
+ python scripts/thumbnail.py presentation.pptx
458
+
459
+ # Combine options: custom name, columns
460
+ python scripts/thumbnail.py template.pptx analysis --cols 4
461
+ ```
462
+
463
+ ## Converting Slides to Images
464
+
465
+ To visually analyze PowerPoint slides, convert them to images using a two-step process:
466
+
467
+ 1. **Convert PPTX to PDF**:
468
+ ```bash
469
+ soffice --headless --convert-to pdf template.pptx
470
+ ```
471
+
472
+ 2. **Convert PDF pages to JPEG images**:
473
+ ```bash
474
+ pdftoppm -jpeg -r 150 template.pdf slide
475
+ ```
476
+ This creates files like `slide-1.jpg`, `slide-2.jpg`, etc.
477
+
478
+ Options:
479
+ - `-r 150`: Sets resolution to 150 DPI (adjust for quality/size balance)
480
+ - `-jpeg`: Output JPEG format (use `-png` for PNG if preferred)
481
+ - `-f N`: First page to convert (e.g., `-f 2` starts from page 2)
482
+ - `-l N`: Last page to convert (e.g., `-l 5` stops at page 5)
483
+ - `slide`: Prefix for output files
484
+
485
+ Example for specific range:
486
+ ```bash
487
+ pdftoppm -jpeg -r 150 -f 2 -l 5 template.pdf slide # Converts only pages 2-5
488
+ ```
489
+
490
+ ## Code Style Guidelines
491
+ **IMPORTANT**: When generating code for PPTX operations:
492
+ - Write concise code
493
+ - Avoid verbose variable names and redundant operations
494
+ - Avoid unnecessary print statements
495
+
496
+ ## Dependencies
497
+
498
+ Required dependencies (should already be installed):
499
+
500
+ - **markitdown**: `pip install "markitdown[pptx]"` (for text extraction from presentations)
501
+ - **pptxgenjs**: `npm install -g pptxgenjs` (for creating presentations via html2pptx)
502
+ - **playwright**: `npm install -g playwright` (for HTML rendering in html2pptx)
503
+ - **react-icons**: `npm install -g react-icons react react-dom` (for icons)
504
+ - **sharp**: `npm install -g sharp` (for SVG rasterization and image processing)
505
+ - **LibreOffice**: `sudo apt-get install libreoffice` (for PDF conversion)
506
+ - **Poppler**: `sudo apt-get install poppler-utils` (for pdftoppm to convert PDF to images)
507
+ - **defusedxml**: `pip install defusedxml` (for secure XML parsing)