@papert-code/papert-code 0.3.95 → 0.3.96

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 (331) hide show
  1. package/README.md +13 -0
  2. package/dist/chunks/{chunk-Q5TJEKUL.js → chunk-HSYOWGEB.js} +1 -1
  3. package/dist/chunks/{chunk-KDPC3L34.js → chunk-IK4ISYCE.js} +4 -4
  4. package/dist/chunks/{chunk-JATIVKZP.js → chunk-KBPFDUTA.js} +55 -10
  5. package/dist/chunks/{chunk-DQ32BMUI.js → chunk-TNDQXJLA.js} +924 -335
  6. package/dist/chunks/{gemini-SUVKHYG5.js → gemini-MVJNXCFF.js} +3910 -1535
  7. package/dist/chunks/{openaiContentGenerator-P6VRBRRB.js → openaiContentGenerator-GTG5MK5E.js} +2 -2
  8. package/dist/chunks/{papertContentGenerator-E64QQV3K.js → papertContentGenerator-Q5TTXUE6.js} +3 -3
  9. package/dist/chunks/{server-N2U4FF55.js → server-6D3KYATG.js} +7 -1
  10. package/dist/cli.js +5 -4
  11. package/dist/sandbox-macos-permissive-proxied.sb +1 -1
  12. package/dist/sandbox-macos-restrictive-proxied.sb +1 -1
  13. package/dist/skills/algorithmic-art/SKILL.md +405 -0
  14. package/dist/skills/algorithmic-art/templates/generator_template.js +223 -0
  15. package/dist/skills/algorithmic-art/templates/viewer.html +599 -0
  16. package/dist/skills/brand-guidelines/SKILL.md +73 -0
  17. package/dist/skills/canvas-design/SKILL.md +130 -0
  18. package/dist/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  19. package/dist/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  20. package/dist/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  21. package/dist/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
  22. package/dist/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  23. package/dist/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
  24. package/dist/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  25. package/dist/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  26. package/dist/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  27. package/dist/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  28. package/dist/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  29. package/dist/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  30. package/dist/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  31. package/dist/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  32. package/dist/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
  33. package/dist/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  34. package/dist/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
  35. package/dist/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  36. package/dist/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  37. package/dist/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
  38. package/dist/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  39. package/dist/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
  40. package/dist/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  41. package/dist/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  42. package/dist/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  43. package/dist/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  44. package/dist/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  45. package/dist/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  46. package/dist/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  47. package/dist/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  48. package/dist/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  49. package/dist/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  50. package/dist/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  51. package/dist/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  52. package/dist/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  53. package/dist/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  54. package/dist/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  55. package/dist/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
  56. package/dist/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  57. package/dist/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  58. package/dist/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  59. package/dist/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  60. package/dist/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  61. package/dist/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  62. package/dist/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
  63. package/dist/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  64. package/dist/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  65. package/dist/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  66. package/dist/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  67. package/dist/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  68. package/dist/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
  69. package/dist/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  70. package/dist/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  71. package/dist/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
  72. package/dist/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  73. package/dist/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  74. package/dist/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  75. package/dist/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  76. package/dist/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
  77. package/dist/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  78. package/dist/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  79. package/dist/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
  80. package/dist/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
  81. package/dist/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  82. package/dist/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  83. package/dist/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
  84. package/dist/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  85. package/dist/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
  86. package/dist/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  87. package/dist/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  88. package/dist/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
  89. package/dist/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  90. package/dist/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
  91. package/dist/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  92. package/dist/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  93. package/dist/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  94. package/dist/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  95. package/dist/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
  96. package/dist/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  97. package/dist/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
  98. package/dist/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  99. package/dist/skills/doc-coauthoring/SKILL.md +375 -0
  100. package/dist/skills/docx/SKILL.md +481 -0
  101. package/dist/skills/docx/scripts/__init__.py +1 -0
  102. package/dist/skills/docx/scripts/accept_changes.py +135 -0
  103. package/dist/skills/docx/scripts/comment.py +318 -0
  104. package/dist/skills/docx/scripts/office/helpers/__init__.py +0 -0
  105. package/dist/skills/docx/scripts/office/helpers/merge_runs.py +199 -0
  106. package/dist/skills/docx/scripts/office/helpers/simplify_redlines.py +197 -0
  107. package/dist/skills/docx/scripts/office/pack.py +159 -0
  108. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  109. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  110. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  111. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  112. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  113. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  114. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  115. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  116. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  117. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  118. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  119. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  120. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  121. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  122. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  123. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  124. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  125. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  126. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  127. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  128. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  129. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  130. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  131. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  132. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  133. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  134. package/dist/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  135. package/dist/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  136. package/dist/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  137. package/dist/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  138. package/dist/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  139. package/dist/skills/docx/scripts/office/schemas/mce/mc.xsd +75 -0
  140. package/dist/skills/docx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  141. package/dist/skills/docx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  142. package/dist/skills/docx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  143. package/dist/skills/docx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  144. package/dist/skills/docx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  145. package/dist/skills/docx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  146. package/dist/skills/docx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  147. package/dist/skills/docx/scripts/office/soffice.py +183 -0
  148. package/dist/skills/docx/scripts/office/unpack.py +132 -0
  149. package/dist/skills/docx/scripts/office/validate.py +111 -0
  150. package/dist/skills/docx/scripts/office/validators/__init__.py +15 -0
  151. package/dist/skills/docx/scripts/office/validators/base.py +847 -0
  152. package/dist/skills/docx/scripts/office/validators/docx.py +446 -0
  153. package/dist/skills/docx/scripts/office/validators/pptx.py +275 -0
  154. package/dist/skills/docx/scripts/office/validators/redlining.py +247 -0
  155. package/dist/skills/docx/scripts/templates/comments.xml +3 -0
  156. package/dist/skills/docx/scripts/templates/commentsExtended.xml +3 -0
  157. package/dist/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  158. package/dist/skills/docx/scripts/templates/commentsIds.xml +3 -0
  159. package/dist/skills/docx/scripts/templates/people.xml +3 -0
  160. package/dist/skills/frontend-design/SKILL.md +42 -0
  161. package/dist/skills/internal-comms/SKILL.md +32 -0
  162. package/dist/skills/internal-comms/examples/3p-updates.md +47 -0
  163. package/dist/skills/internal-comms/examples/company-newsletter.md +65 -0
  164. package/dist/skills/internal-comms/examples/faq-answers.md +30 -0
  165. package/dist/skills/internal-comms/examples/general-comms.md +16 -0
  166. package/dist/skills/mcp-builder/SKILL.md +236 -0
  167. package/dist/skills/mcp-builder/reference/evaluation.md +602 -0
  168. package/dist/skills/mcp-builder/reference/mcp_best_practices.md +249 -0
  169. package/dist/skills/mcp-builder/reference/node_mcp_server.md +970 -0
  170. package/dist/skills/mcp-builder/reference/python_mcp_server.md +719 -0
  171. package/dist/skills/mcp-builder/scripts/connections.py +151 -0
  172. package/dist/skills/mcp-builder/scripts/evaluation.py +373 -0
  173. package/dist/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  174. package/dist/skills/mcp-builder/scripts/requirements.txt +2 -0
  175. package/dist/skills/papert-code/SKILL.md +561 -0
  176. package/dist/skills/pdf/SKILL.md +314 -0
  177. package/dist/skills/pdf/forms.md +294 -0
  178. package/dist/skills/pdf/reference.md +612 -0
  179. package/dist/skills/pdf/scripts/check_bounding_boxes.py +65 -0
  180. package/dist/skills/pdf/scripts/check_fillable_fields.py +11 -0
  181. package/dist/skills/pdf/scripts/convert_pdf_to_images.py +33 -0
  182. package/dist/skills/pdf/scripts/create_validation_image.py +37 -0
  183. package/dist/skills/pdf/scripts/extract_form_field_info.py +122 -0
  184. package/dist/skills/pdf/scripts/extract_form_structure.py +115 -0
  185. package/dist/skills/pdf/scripts/fill_fillable_fields.py +98 -0
  186. package/dist/skills/pdf/scripts/fill_pdf_form_with_annotations.py +107 -0
  187. package/dist/skills/pptx/SKILL.md +232 -0
  188. package/dist/skills/pptx/editing.md +205 -0
  189. package/dist/skills/pptx/pptxgenjs.md +420 -0
  190. package/dist/skills/pptx/scripts/__init__.py +0 -0
  191. package/dist/skills/pptx/scripts/add_slide.py +195 -0
  192. package/dist/skills/pptx/scripts/clean.py +286 -0
  193. package/dist/skills/pptx/scripts/office/helpers/__init__.py +0 -0
  194. package/dist/skills/pptx/scripts/office/helpers/merge_runs.py +199 -0
  195. package/dist/skills/pptx/scripts/office/helpers/simplify_redlines.py +197 -0
  196. package/dist/skills/pptx/scripts/office/pack.py +159 -0
  197. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  198. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  199. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  200. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  201. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  202. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  203. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  204. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  205. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  206. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  207. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  208. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  209. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  210. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  211. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  212. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  213. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  214. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  215. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  216. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  217. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  218. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  219. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  220. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  221. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  222. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  223. package/dist/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  224. package/dist/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  225. package/dist/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  226. package/dist/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  227. package/dist/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  228. package/dist/skills/pptx/scripts/office/schemas/mce/mc.xsd +75 -0
  229. package/dist/skills/pptx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  230. package/dist/skills/pptx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  231. package/dist/skills/pptx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  232. package/dist/skills/pptx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  233. package/dist/skills/pptx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  234. package/dist/skills/pptx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  235. package/dist/skills/pptx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  236. package/dist/skills/pptx/scripts/office/soffice.py +183 -0
  237. package/dist/skills/pptx/scripts/office/unpack.py +132 -0
  238. package/dist/skills/pptx/scripts/office/validate.py +111 -0
  239. package/dist/skills/pptx/scripts/office/validators/__init__.py +15 -0
  240. package/dist/skills/pptx/scripts/office/validators/base.py +847 -0
  241. package/dist/skills/pptx/scripts/office/validators/docx.py +446 -0
  242. package/dist/skills/pptx/scripts/office/validators/pptx.py +275 -0
  243. package/dist/skills/pptx/scripts/office/validators/redlining.py +247 -0
  244. package/dist/skills/pptx/scripts/thumbnail.py +289 -0
  245. package/dist/skills/skill-creator/SKILL.md +357 -0
  246. package/dist/skills/skill-creator/references/output-patterns.md +82 -0
  247. package/dist/skills/skill-creator/references/workflows.md +28 -0
  248. package/dist/skills/skill-creator/scripts/init_skill.py +303 -0
  249. package/dist/skills/skill-creator/scripts/package_skill.py +110 -0
  250. package/dist/skills/skill-creator/scripts/quick_validate.py +103 -0
  251. package/dist/skills/slack-gif-creator/SKILL.md +254 -0
  252. package/dist/skills/slack-gif-creator/core/easing.py +234 -0
  253. package/dist/skills/slack-gif-creator/core/frame_composer.py +176 -0
  254. package/dist/skills/slack-gif-creator/core/gif_builder.py +269 -0
  255. package/dist/skills/slack-gif-creator/core/validators.py +136 -0
  256. package/dist/skills/slack-gif-creator/requirements.txt +4 -0
  257. package/dist/skills/theme-factory/SKILL.md +59 -0
  258. package/dist/skills/theme-factory/theme-showcase.pdf +0 -0
  259. package/dist/skills/theme-factory/themes/arctic-frost.md +19 -0
  260. package/dist/skills/theme-factory/themes/botanical-garden.md +19 -0
  261. package/dist/skills/theme-factory/themes/desert-rose.md +19 -0
  262. package/dist/skills/theme-factory/themes/forest-canopy.md +19 -0
  263. package/dist/skills/theme-factory/themes/golden-hour.md +19 -0
  264. package/dist/skills/theme-factory/themes/midnight-galaxy.md +19 -0
  265. package/dist/skills/theme-factory/themes/modern-minimalist.md +19 -0
  266. package/dist/skills/theme-factory/themes/ocean-depths.md +19 -0
  267. package/dist/skills/theme-factory/themes/sunset-boulevard.md +19 -0
  268. package/dist/skills/theme-factory/themes/tech-innovation.md +19 -0
  269. package/dist/skills/web-artifacts-builder/SKILL.md +74 -0
  270. package/dist/skills/web-artifacts-builder/scripts/bundle-artifact.sh +54 -0
  271. package/dist/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -0
  272. package/dist/skills/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  273. package/dist/skills/webapp-testing/SKILL.md +96 -0
  274. package/dist/skills/webapp-testing/examples/console_logging.py +35 -0
  275. package/dist/skills/webapp-testing/examples/element_discovery.py +40 -0
  276. package/dist/skills/webapp-testing/examples/static_html_automation.py +33 -0
  277. package/dist/skills/webapp-testing/scripts/with_server.py +106 -0
  278. package/dist/skills/xlsx/SKILL.md +292 -0
  279. package/dist/skills/xlsx/scripts/office/helpers/__init__.py +0 -0
  280. package/dist/skills/xlsx/scripts/office/helpers/merge_runs.py +199 -0
  281. package/dist/skills/xlsx/scripts/office/helpers/simplify_redlines.py +197 -0
  282. package/dist/skills/xlsx/scripts/office/pack.py +159 -0
  283. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  284. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  285. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  286. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  287. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  288. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  289. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  290. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  291. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  292. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  293. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  294. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  295. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  296. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  297. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  298. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  299. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  300. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  301. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  302. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  303. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  304. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  305. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  306. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  307. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  308. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  309. package/dist/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  310. package/dist/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  311. package/dist/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  312. package/dist/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  313. package/dist/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  314. package/dist/skills/xlsx/scripts/office/schemas/mce/mc.xsd +75 -0
  315. package/dist/skills/xlsx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  316. package/dist/skills/xlsx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  317. package/dist/skills/xlsx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  318. package/dist/skills/xlsx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  319. package/dist/skills/xlsx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  320. package/dist/skills/xlsx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  321. package/dist/skills/xlsx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  322. package/dist/skills/xlsx/scripts/office/soffice.py +183 -0
  323. package/dist/skills/xlsx/scripts/office/unpack.py +132 -0
  324. package/dist/skills/xlsx/scripts/office/validate.py +111 -0
  325. package/dist/skills/xlsx/scripts/office/validators/__init__.py +15 -0
  326. package/dist/skills/xlsx/scripts/office/validators/base.py +847 -0
  327. package/dist/skills/xlsx/scripts/office/validators/docx.py +446 -0
  328. package/dist/skills/xlsx/scripts/office/validators/pptx.py +275 -0
  329. package/dist/skills/xlsx/scripts/office/validators/redlining.py +247 -0
  330. package/dist/skills/xlsx/scripts/recalc.py +184 -0
  331. package/package.json +5 -4
@@ -0,0 +1,47 @@
1
+ ## Instructions
2
+ You are being asked to write a 3P update. 3P updates stand for "Progress, Plans, Problems." The main audience is for executives, leadership, other teammates, etc. They're meant to be very succinct and to-the-point: think something you can read in 30-60sec or less. They're also for people with some, but not a lot of context on what the team does.
3
+
4
+ 3Ps can cover a team of any size, ranging all the way up to the entire company. The bigger the team, the less granular the tasks should be. For example, "mobile team" might have "shipped feature" or "fixed bugs," whereas the company might have really meaty 3Ps, like "hired 20 new people" or "closed 10 new deals."
5
+
6
+ They represent the work of the team across a time period, almost always one week. They include three sections:
7
+ 1) Progress: what the team has accomplished over the next time period. Focus mainly on things shipped, milestones achieved, tasks created, etc.
8
+ 2) Plans: what the team plans to do over the next time period. Focus on what things are top-of-mind, really high priority, etc. for the team.
9
+ 3) Problems: anything that is slowing the team down. This could be things like too few people, bugs or blockers that are preventing the team from moving forward, some deal that fell through, etc.
10
+
11
+ Before writing them, make sure that you know the team name. If it's not specified, you can ask explicitly what the team name you're writing for is.
12
+
13
+
14
+ ## Tools Available
15
+ Whenever possible, try to pull from available sources to get the information you need:
16
+ - Slack: posts from team members with their updates - ideally look for posts in large channels with lots of reactions
17
+ - Google Drive: docs written from critical team members with lots of views
18
+ - Email: emails with lots of responses of lots of content that seems relevant
19
+ - Calendar: non-recurring meetings that have a lot of importance, like product reviews, etc.
20
+
21
+
22
+ Try to gather as much context as you can, focusing on the things that covered the time period you're writing for:
23
+ - Progress: anything between a week ago and today
24
+ - Plans: anything from today to the next week
25
+ - Problems: anything between a week ago and today
26
+
27
+
28
+ If you don't have access, you can ask the user for things they want to cover. They might also include these things to you directly, in which case you're mostly just formatting for this particular format.
29
+
30
+ ## Workflow
31
+
32
+ 1. **Clarify scope**: Confirm the team name and time period (usually past week for Progress/Problems, next
33
+ week for Plans)
34
+ 2. **Gather information**: Use available tools or ask the user directly
35
+ 3. **Draft the update**: Follow the strict formatting guidelines
36
+ 4. **Review**: Ensure it's concise (30-60 seconds to read) and data-driven
37
+
38
+ ## Formatting
39
+
40
+ The format is always the same, very strict formatting. Never use any formatting other than this. Pick an emoji that is fun and captures the vibe of the team and update.
41
+
42
+ [pick an emoji] [Team Name] (Dates Covered, usually a week)
43
+ Progress: [1-3 sentences of content]
44
+ Plans: [1-3 sentences of content]
45
+ Problems: [1-3 sentences of content]
46
+
47
+ Each section should be no more than 1-3 sentences: clear, to the point. It should be data-driven, and generally include metrics where possible. The tone should be very matter-of-fact, not super prose-heavy.
@@ -0,0 +1,65 @@
1
+ ## Instructions
2
+ You are being asked to write a company-wide newsletter update. You are meant to summarize the past week/month of a company in the form of a newsletter that the entire company will read. It should be maybe ~20-25 bullet points long. It will be sent via Slack and email, so make it consumable for that.
3
+
4
+ Ideally it includes the following attributes:
5
+ - Lots of links: pulling documents from Google Drive that are very relevant, linking to prominent Slack messages in announce channels and from executives, perhgaps referencing emails that went company-wide, highlighting significant things that have happened in the company.
6
+ - Short and to-the-point: each bullet should probably be no longer than ~1-2 sentences
7
+ - Use the "we" tense, as you are part of the company. Many of the bullets should say "we did this" or "we did that"
8
+
9
+ ## Tools to use
10
+ If you have access to the following tools, please try to use them. If not, you can also let the user know directly that their responses would be better if they gave them access.
11
+
12
+ - Slack: look for messages in channels with lots of people, with lots of reactions or lots of responses within the thread
13
+ - Email: look for things from executives that discuss company-wide announcements
14
+ - Calendar: if there were meetings with large attendee lists, particularly things like All-Hands meetings, big company announcements, etc. If there were documents attached to those meetings, those are great links to include.
15
+ - Documents: if there were new docs published in the last week or two that got a lot of attention, you can link them. These should be things like company-wide vision docs, plans for the upcoming quarter or half, things authored by critical executives, etc.
16
+ - External press: if you see references to articles or press we've received over the past week, that could be really cool too.
17
+
18
+ If you don't have access to any of these things, you can ask the user for things they want to cover. In this case, you'll mostly just be polishing up and fitting to this format more directly.
19
+
20
+ ## Sections
21
+ The company is pretty big: 1000+ people. There are a variety of different teams and initiatives going on across the company. To make sure the update works well, try breaking it into sections of similar things. You might break into clusters like {product development, go to market, finance} or {recruiting, execution, vision}, or {external news, internal news} etc. Try to make sure the different areas of the company are highlighted well.
22
+
23
+ ## Prioritization
24
+ Focus on:
25
+ - Company-wide impact (not team-specific details)
26
+ - Announcements from leadership
27
+ - Major milestones and achievements
28
+ - Information that affects most employees
29
+ - External recognition or press
30
+
31
+ Avoid:
32
+ - Overly granular team updates (save those for 3Ps)
33
+ - Information only relevant to small groups
34
+ - Duplicate information already communicated
35
+
36
+ ## Example Formats
37
+
38
+ :megaphone: Company Announcements
39
+ - Announcement 1
40
+ - Announcement 2
41
+ - Announcement 3
42
+
43
+ :dart: Progress on Priorities
44
+ - Area 1
45
+ - Sub-area 1
46
+ - Sub-area 2
47
+ - Sub-area 3
48
+ - Area 2
49
+ - Sub-area 1
50
+ - Sub-area 2
51
+ - Sub-area 3
52
+ - Area 3
53
+ - Sub-area 1
54
+ - Sub-area 2
55
+ - Sub-area 3
56
+
57
+ :pillar: Leadership Updates
58
+ - Post 1
59
+ - Post 2
60
+ - Post 3
61
+
62
+ :thread: Social Updates
63
+ - Update 1
64
+ - Update 2
65
+ - Update 3
@@ -0,0 +1,30 @@
1
+ ## Instructions
2
+ You are an assistant for answering questions that are being asked across the company. Every week, there are lots of questions that get asked across the company, and your goal is to try to summarize what those questions are. We want our company to be well-informed and on the same page, so your job is to produce a set of frequently asked questions that our employees are asking and attempt to answer them. Your singular job is to do two things:
3
+
4
+ - Find questions that are big sources of confusion for lots of employees at the company, generally about things that affect a large portion of the employee base
5
+ - Attempt to give a nice summarized answer to that question in order to minimize confusion.
6
+
7
+ Some examples of areas that may be interesting to folks: recent corporate events (fundraising, new executives, etc.), upcoming launches, hiring progress, changes to vision or focus, etc.
8
+
9
+
10
+ ## Tools Available
11
+ You should use the company's available tools, where communication and work happens. For most companies, it looks something like this:
12
+ - Slack: questions being asked across the company - it could be questions in response to posts with lots of responses, questions being asked with lots of reactions or thumbs up to show support, or anything else to show that a large number of employees want to ask the same things
13
+ - Email: emails with FAQs written directly in them can be a good source as well
14
+ - Documents: docs in places like Google Drive, linked on calendar events, etc. can also be a good source of FAQs, either directly added or inferred based on the contents of the doc
15
+
16
+ ## Formatting
17
+ The formatting should be pretty basic:
18
+
19
+ - *Question*: [insert question - 1 sentence]
20
+ - *Answer*: [insert answer - 1-2 sentence]
21
+
22
+ ## Guidance
23
+ Make sure you're being holistic in your questions. Don't focus too much on just the user in question or the team they are a part of, but try to capture the entire company. Try to be as holistic as you can in reading all the tools available, producing responses that are relevant to all at the company.
24
+
25
+ ## Answer Guidelines
26
+ - Base answers on official company communications when possible
27
+ - If information is uncertain, indicate that clearly
28
+ - Link to authoritative sources (docs, announcements, emails)
29
+ - Keep tone professional but approachable
30
+ - Flag if a question requires executive input or official response
@@ -0,0 +1,16 @@
1
+ ## Instructions
2
+ You are being asked to write internal company communication that doesn't fit into the standard formats (3P
3
+ updates, newsletters, or FAQs).
4
+
5
+ Before proceeding:
6
+ 1. Ask the user about their target audience
7
+ 2. Understand the communication's purpose
8
+ 3. Clarify the desired tone (formal, casual, urgent, informational)
9
+ 4. Confirm any specific formatting requirements
10
+
11
+ Use these general principles:
12
+ - Be clear and concise
13
+ - Use active voice
14
+ - Put the most important information first
15
+ - Include relevant links and references
16
+ - Match the company's communication style
@@ -0,0 +1,236 @@
1
+ ---
2
+ name: mcp-builder
3
+ description: Guide for creating high-quality MCP (Model Context Protocol) servers that enable LLMs to interact with external services through well-designed tools. Use when building MCP servers to integrate external APIs or services, whether in Python (FastMCP) or Node/TypeScript (MCP SDK).
4
+ license: Complete terms in LICENSE.txt
5
+ ---
6
+
7
+ # MCP Server Development Guide
8
+
9
+ ## Overview
10
+
11
+ Create MCP (Model Context Protocol) servers that enable LLMs to interact with external services through well-designed tools. The quality of an MCP server is measured by how well it enables LLMs to accomplish real-world tasks.
12
+
13
+ ---
14
+
15
+ # Process
16
+
17
+ ## 🚀 High-Level Workflow
18
+
19
+ Creating a high-quality MCP server involves four main phases:
20
+
21
+ ### Phase 1: Deep Research and Planning
22
+
23
+ #### 1.1 Understand Modern MCP Design
24
+
25
+ **API Coverage vs. Workflow Tools:**
26
+ Balance comprehensive API endpoint coverage with specialized workflow tools. Workflow tools can be more convenient for specific tasks, while comprehensive coverage gives agents flexibility to compose operations. Performance varies by client—some clients benefit from code execution that combines basic tools, while others work better with higher-level workflows. When uncertain, prioritize comprehensive API coverage.
27
+
28
+ **Tool Naming and Discoverability:**
29
+ Clear, descriptive tool names help agents find the right tools quickly. Use consistent prefixes (e.g., `github_create_issue`, `github_list_repos`) and action-oriented naming.
30
+
31
+ **Context Management:**
32
+ Agents benefit from concise tool descriptions and the ability to filter/paginate results. Design tools that return focused, relevant data. Some clients support code execution which can help agents filter and process data efficiently.
33
+
34
+ **Actionable Error Messages:**
35
+ Error messages should guide agents toward solutions with specific suggestions and next steps.
36
+
37
+ #### 1.2 Study MCP Protocol Documentation
38
+
39
+ **Navigate the MCP specification:**
40
+
41
+ Start with the sitemap to find relevant pages: `https://modelcontextprotocol.io/sitemap.xml`
42
+
43
+ Then fetch specific pages with `.md` suffix for markdown format (e.g., `https://modelcontextprotocol.io/specification/draft.md`).
44
+
45
+ Key pages to review:
46
+ - Specification overview and architecture
47
+ - Transport mechanisms (streamable HTTP, stdio)
48
+ - Tool, resource, and prompt definitions
49
+
50
+ #### 1.3 Study Framework Documentation
51
+
52
+ **Recommended stack:**
53
+ - **Language**: TypeScript (high-quality SDK support and good compatibility in many execution environments e.g. MCPB. Plus AI models are good at generating TypeScript code, benefiting from its broad usage, static typing and good linting tools)
54
+ - **Transport**: Streamable HTTP for remote servers, using stateless JSON (simpler to scale and maintain, as opposed to stateful sessions and streaming responses). stdio for local servers.
55
+
56
+ **Load framework documentation:**
57
+
58
+ - **MCP Best Practices**: [📋 View Best Practices](./reference/mcp_best_practices.md) - Core guidelines
59
+
60
+ **For TypeScript (recommended):**
61
+ - **TypeScript SDK**: Use WebFetch to load `https://raw.githubusercontent.com/modelcontextprotocol/typescript-sdk/main/README.md`
62
+ - [⚡ TypeScript Guide](./reference/node_mcp_server.md) - TypeScript patterns and examples
63
+
64
+ **For Python:**
65
+ - **Python SDK**: Use WebFetch to load `https://raw.githubusercontent.com/modelcontextprotocol/python-sdk/main/README.md`
66
+ - [🐍 Python Guide](./reference/python_mcp_server.md) - Python patterns and examples
67
+
68
+ #### 1.4 Plan Your Implementation
69
+
70
+ **Understand the API:**
71
+ Review the service's API documentation to identify key endpoints, authentication requirements, and data models. Use web search and WebFetch as needed.
72
+
73
+ **Tool Selection:**
74
+ Prioritize comprehensive API coverage. List endpoints to implement, starting with the most common operations.
75
+
76
+ ---
77
+
78
+ ### Phase 2: Implementation
79
+
80
+ #### 2.1 Set Up Project Structure
81
+
82
+ See language-specific guides for project setup:
83
+ - [⚡ TypeScript Guide](./reference/node_mcp_server.md) - Project structure, package.json, tsconfig.json
84
+ - [🐍 Python Guide](./reference/python_mcp_server.md) - Module organization, dependencies
85
+
86
+ #### 2.2 Implement Core Infrastructure
87
+
88
+ Create shared utilities:
89
+ - API client with authentication
90
+ - Error handling helpers
91
+ - Response formatting (JSON/Markdown)
92
+ - Pagination support
93
+
94
+ #### 2.3 Implement Tools
95
+
96
+ For each tool:
97
+
98
+ **Input Schema:**
99
+ - Use Zod (TypeScript) or Pydantic (Python)
100
+ - Include constraints and clear descriptions
101
+ - Add examples in field descriptions
102
+
103
+ **Output Schema:**
104
+ - Define `outputSchema` where possible for structured data
105
+ - Use `structuredContent` in tool responses (TypeScript SDK feature)
106
+ - Helps clients understand and process tool outputs
107
+
108
+ **Tool Description:**
109
+ - Concise summary of functionality
110
+ - Parameter descriptions
111
+ - Return type schema
112
+
113
+ **Implementation:**
114
+ - Async/await for I/O operations
115
+ - Proper error handling with actionable messages
116
+ - Support pagination where applicable
117
+ - Return both text content and structured data when using modern SDKs
118
+
119
+ **Annotations:**
120
+ - `readOnlyHint`: true/false
121
+ - `destructiveHint`: true/false
122
+ - `idempotentHint`: true/false
123
+ - `openWorldHint`: true/false
124
+
125
+ ---
126
+
127
+ ### Phase 3: Review and Test
128
+
129
+ #### 3.1 Code Quality
130
+
131
+ Review for:
132
+ - No duplicated code (DRY principle)
133
+ - Consistent error handling
134
+ - Full type coverage
135
+ - Clear tool descriptions
136
+
137
+ #### 3.2 Build and Test
138
+
139
+ **TypeScript:**
140
+ - Run `npm run build` to verify compilation
141
+ - Test with MCP Inspector: `npx @modelcontextprotocol/inspector`
142
+
143
+ **Python:**
144
+ - Verify syntax: `python -m py_compile your_server.py`
145
+ - Test with MCP Inspector
146
+
147
+ See language-specific guides for detailed testing approaches and quality checklists.
148
+
149
+ ---
150
+
151
+ ### Phase 4: Create Evaluations
152
+
153
+ After implementing your MCP server, create comprehensive evaluations to test its effectiveness.
154
+
155
+ **Load [✅ Evaluation Guide](./reference/evaluation.md) for complete evaluation guidelines.**
156
+
157
+ #### 4.1 Understand Evaluation Purpose
158
+
159
+ Use evaluations to test whether LLMs can effectively use your MCP server to answer realistic, complex questions.
160
+
161
+ #### 4.2 Create 10 Evaluation Questions
162
+
163
+ To create effective evaluations, follow the process outlined in the evaluation guide:
164
+
165
+ 1. **Tool Inspection**: List available tools and understand their capabilities
166
+ 2. **Content Exploration**: Use READ-ONLY operations to explore available data
167
+ 3. **Question Generation**: Create 10 complex, realistic questions
168
+ 4. **Answer Verification**: Solve each question yourself to verify answers
169
+
170
+ #### 4.3 Evaluation Requirements
171
+
172
+ Ensure each question is:
173
+ - **Independent**: Not dependent on other questions
174
+ - **Read-only**: Only non-destructive operations required
175
+ - **Complex**: Requiring multiple tool calls and deep exploration
176
+ - **Realistic**: Based on real use cases humans would care about
177
+ - **Verifiable**: Single, clear answer that can be verified by string comparison
178
+ - **Stable**: Answer won't change over time
179
+
180
+ #### 4.4 Output Format
181
+
182
+ Create an XML file with this structure:
183
+
184
+ ```xml
185
+ <evaluation>
186
+ <qa_pair>
187
+ <question>Find discussions about AI model launches with animal codenames. One model needed a specific safety designation that uses the format ASL-X. What number X was being determined for the model named after a spotted wild cat?</question>
188
+ <answer>3</answer>
189
+ </qa_pair>
190
+ <!-- More qa_pairs... -->
191
+ </evaluation>
192
+ ```
193
+
194
+ ---
195
+
196
+ # Reference Files
197
+
198
+ ## 📚 Documentation Library
199
+
200
+ Load these resources as needed during development:
201
+
202
+ ### Core MCP Documentation (Load First)
203
+ - **MCP Protocol**: Start with sitemap at `https://modelcontextprotocol.io/sitemap.xml`, then fetch specific pages with `.md` suffix
204
+ - [📋 MCP Best Practices](./reference/mcp_best_practices.md) - Universal MCP guidelines including:
205
+ - Server and tool naming conventions
206
+ - Response format guidelines (JSON vs Markdown)
207
+ - Pagination best practices
208
+ - Transport selection (streamable HTTP vs stdio)
209
+ - Security and error handling standards
210
+
211
+ ### SDK Documentation (Load During Phase 1/2)
212
+ - **Python SDK**: Fetch from `https://raw.githubusercontent.com/modelcontextprotocol/python-sdk/main/README.md`
213
+ - **TypeScript SDK**: Fetch from `https://raw.githubusercontent.com/modelcontextprotocol/typescript-sdk/main/README.md`
214
+
215
+ ### Language-Specific Implementation Guides (Load During Phase 2)
216
+ - [🐍 Python Implementation Guide](./reference/python_mcp_server.md) - Complete Python/FastMCP guide with:
217
+ - Server initialization patterns
218
+ - Pydantic model examples
219
+ - Tool registration with `@mcp.tool`
220
+ - Complete working examples
221
+ - Quality checklist
222
+
223
+ - [⚡ TypeScript Implementation Guide](./reference/node_mcp_server.md) - Complete TypeScript guide with:
224
+ - Project structure
225
+ - Zod schema patterns
226
+ - Tool registration with `server.registerTool`
227
+ - Complete working examples
228
+ - Quality checklist
229
+
230
+ ### Evaluation Guide (Load During Phase 4)
231
+ - [✅ Evaluation Guide](./reference/evaluation.md) - Complete evaluation creation guide with:
232
+ - Question creation guidelines
233
+ - Answer verification strategies
234
+ - XML format specifications
235
+ - Example questions and answers
236
+ - Running an evaluation with the provided scripts