devskill 2.0.5 → 2.0.7

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 (438) hide show
  1. package/landing/app/[locale]/page.tsx +68 -2
  2. package/landing/messages/en.json +12 -2
  3. package/landing/messages/vi.json +13 -3
  4. package/meta.ts +18 -1
  5. package/package.json +5 -1
  6. package/scripts/cli.ts +175 -46
  7. package/skills/algorithmic-art/LICENSE.txt +202 -0
  8. package/skills/algorithmic-art/SKILL.md +405 -0
  9. package/skills/algorithmic-art/SYNC.md +5 -0
  10. package/skills/algorithmic-art/templates/generator_template.js +223 -0
  11. package/skills/algorithmic-art/templates/viewer.html +599 -0
  12. package/skills/brand-guidelines/LICENSE.txt +202 -0
  13. package/skills/brand-guidelines/SKILL.md +73 -0
  14. package/skills/brand-guidelines/SYNC.md +5 -0
  15. package/skills/canvas-design/LICENSE.txt +202 -0
  16. package/skills/canvas-design/SKILL.md +130 -0
  17. package/skills/canvas-design/SYNC.md +5 -0
  18. package/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  19. package/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  20. package/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  21. package/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
  22. package/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  23. package/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
  24. package/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  25. package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  26. package/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  27. package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  28. package/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  29. package/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  30. package/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  31. package/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  32. package/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
  33. package/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  34. package/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
  35. package/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  36. package/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  37. package/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
  38. package/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  39. package/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
  40. package/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  41. package/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  42. package/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  43. package/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  44. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  45. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  46. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  47. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  48. package/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  49. package/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  50. package/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  51. package/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  52. package/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  53. package/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  54. package/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  55. package/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
  56. package/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  57. package/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  58. package/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  59. package/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  60. package/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  61. package/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  62. package/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
  63. package/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  64. package/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  65. package/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  66. package/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  67. package/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  68. package/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
  69. package/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  70. package/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  71. package/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
  72. package/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  73. package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  74. package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  75. package/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  76. package/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
  77. package/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  78. package/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  79. package/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
  80. package/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
  81. package/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  82. package/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  83. package/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
  84. package/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  85. package/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
  86. package/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  87. package/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  88. package/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
  89. package/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  90. package/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
  91. package/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  92. package/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  93. package/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  94. package/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  95. package/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
  96. package/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  97. package/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
  98. package/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  99. package/skills/claude-api/LICENSE.txt +202 -0
  100. package/skills/claude-api/SKILL.md +246 -0
  101. package/skills/claude-api/SYNC.md +5 -0
  102. package/skills/claude-api/csharp/claude-api.md +400 -0
  103. package/skills/claude-api/curl/examples.md +193 -0
  104. package/skills/claude-api/go/claude-api.md +404 -0
  105. package/skills/claude-api/java/claude-api.md +430 -0
  106. package/skills/claude-api/php/claude-api.md +241 -0
  107. package/skills/claude-api/python/agent-sdk/README.md +345 -0
  108. package/skills/claude-api/python/agent-sdk/patterns.md +359 -0
  109. package/skills/claude-api/python/claude-api/README.md +410 -0
  110. package/skills/claude-api/python/claude-api/batches.md +185 -0
  111. package/skills/claude-api/python/claude-api/files-api.md +165 -0
  112. package/skills/claude-api/python/claude-api/streaming.md +162 -0
  113. package/skills/claude-api/python/claude-api/tool-use.md +590 -0
  114. package/skills/claude-api/ruby/claude-api.md +92 -0
  115. package/skills/claude-api/shared/error-codes.md +206 -0
  116. package/skills/claude-api/shared/live-sources.md +121 -0
  117. package/skills/claude-api/shared/models.md +119 -0
  118. package/skills/claude-api/shared/tool-use-concepts.md +305 -0
  119. package/skills/claude-api/typescript/agent-sdk/README.md +296 -0
  120. package/skills/claude-api/typescript/agent-sdk/patterns.md +209 -0
  121. package/skills/claude-api/typescript/claude-api/README.md +321 -0
  122. package/skills/claude-api/typescript/claude-api/batches.md +106 -0
  123. package/skills/claude-api/typescript/claude-api/files-api.md +98 -0
  124. package/skills/claude-api/typescript/claude-api/streaming.md +178 -0
  125. package/skills/claude-api/typescript/claude-api/tool-use.md +527 -0
  126. package/skills/doc-coauthoring/SKILL.md +375 -0
  127. package/skills/doc-coauthoring/SYNC.md +5 -0
  128. package/skills/docx/LICENSE.txt +30 -0
  129. package/skills/docx/SKILL.md +590 -0
  130. package/skills/docx/SYNC.md +5 -0
  131. package/skills/docx/scripts/__init__.py +1 -0
  132. package/skills/docx/scripts/accept_changes.py +135 -0
  133. package/skills/docx/scripts/comment.py +318 -0
  134. package/skills/docx/scripts/office/helpers/__init__.py +0 -0
  135. package/skills/docx/scripts/office/helpers/merge_runs.py +199 -0
  136. package/skills/docx/scripts/office/helpers/simplify_redlines.py +197 -0
  137. package/skills/docx/scripts/office/pack.py +159 -0
  138. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  139. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  140. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  141. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  142. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  143. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  144. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  145. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  146. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  147. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  148. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  149. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  150. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  151. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  152. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  153. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  154. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  155. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  156. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  157. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  158. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  159. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  160. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  161. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  162. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  163. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  164. package/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  165. package/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  166. package/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  167. package/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  168. package/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  169. package/skills/docx/scripts/office/schemas/mce/mc.xsd +75 -0
  170. package/skills/docx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  171. package/skills/docx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  172. package/skills/docx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  173. package/skills/docx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  174. package/skills/docx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  175. package/skills/docx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  176. package/skills/docx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  177. package/skills/docx/scripts/office/soffice.py +183 -0
  178. package/skills/docx/scripts/office/unpack.py +132 -0
  179. package/skills/docx/scripts/office/validate.py +111 -0
  180. package/skills/docx/scripts/office/validators/__init__.py +15 -0
  181. package/skills/docx/scripts/office/validators/base.py +847 -0
  182. package/skills/docx/scripts/office/validators/docx.py +446 -0
  183. package/skills/docx/scripts/office/validators/pptx.py +275 -0
  184. package/skills/docx/scripts/office/validators/redlining.py +247 -0
  185. package/skills/docx/scripts/templates/comments.xml +3 -0
  186. package/skills/docx/scripts/templates/commentsExtended.xml +3 -0
  187. package/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  188. package/skills/docx/scripts/templates/commentsIds.xml +3 -0
  189. package/skills/docx/scripts/templates/people.xml +3 -0
  190. package/skills/frontend-design/LICENSE.txt +177 -0
  191. package/skills/frontend-design/SKILL.md +42 -0
  192. package/skills/frontend-design/SYNC.md +5 -0
  193. package/skills/internal-comms/LICENSE.txt +202 -0
  194. package/skills/internal-comms/SKILL.md +32 -0
  195. package/skills/internal-comms/SYNC.md +5 -0
  196. package/skills/internal-comms/examples/3p-updates.md +47 -0
  197. package/skills/internal-comms/examples/company-newsletter.md +65 -0
  198. package/skills/internal-comms/examples/faq-answers.md +30 -0
  199. package/skills/internal-comms/examples/general-comms.md +16 -0
  200. package/skills/mcp-builder/LICENSE.txt +202 -0
  201. package/skills/mcp-builder/SKILL.md +236 -0
  202. package/skills/mcp-builder/SYNC.md +5 -0
  203. package/skills/mcp-builder/reference/evaluation.md +602 -0
  204. package/skills/mcp-builder/reference/mcp_best_practices.md +249 -0
  205. package/skills/mcp-builder/reference/node_mcp_server.md +970 -0
  206. package/skills/mcp-builder/reference/python_mcp_server.md +719 -0
  207. package/skills/mcp-builder/scripts/connections.py +151 -0
  208. package/skills/mcp-builder/scripts/evaluation.py +373 -0
  209. package/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  210. package/skills/mcp-builder/scripts/requirements.txt +2 -0
  211. package/skills/next-best-practices/SKILL.md +153 -0
  212. package/skills/next-best-practices/SYNC.md +5 -0
  213. package/skills/next-best-practices/async-patterns.md +87 -0
  214. package/skills/next-best-practices/bundling.md +180 -0
  215. package/skills/next-best-practices/data-patterns.md +297 -0
  216. package/skills/next-best-practices/debug-tricks.md +105 -0
  217. package/skills/next-best-practices/directives.md +73 -0
  218. package/skills/next-best-practices/error-handling.md +227 -0
  219. package/skills/next-best-practices/file-conventions.md +140 -0
  220. package/skills/next-best-practices/font.md +245 -0
  221. package/skills/next-best-practices/functions.md +108 -0
  222. package/skills/next-best-practices/hydration-error.md +91 -0
  223. package/skills/next-best-practices/image.md +173 -0
  224. package/skills/next-best-practices/metadata.md +301 -0
  225. package/skills/next-best-practices/parallel-routes.md +287 -0
  226. package/skills/next-best-practices/route-handlers.md +146 -0
  227. package/skills/next-best-practices/rsc-boundaries.md +159 -0
  228. package/skills/next-best-practices/runtime-selection.md +39 -0
  229. package/skills/next-best-practices/scripts.md +141 -0
  230. package/skills/next-best-practices/self-hosting.md +371 -0
  231. package/skills/next-best-practices/suspense-boundaries.md +67 -0
  232. package/skills/next-cache-components/SKILL.md +411 -0
  233. package/skills/next-cache-components/SYNC.md +5 -0
  234. package/skills/next-upgrade/SKILL.md +50 -0
  235. package/skills/next-upgrade/SYNC.md +5 -0
  236. package/skills/pdf/LICENSE.txt +30 -0
  237. package/skills/pdf/SKILL.md +314 -0
  238. package/skills/pdf/SYNC.md +5 -0
  239. package/skills/pdf/forms.md +294 -0
  240. package/skills/pdf/reference.md +612 -0
  241. package/skills/pdf/scripts/check_bounding_boxes.py +65 -0
  242. package/skills/pdf/scripts/check_fillable_fields.py +11 -0
  243. package/skills/pdf/scripts/convert_pdf_to_images.py +33 -0
  244. package/skills/pdf/scripts/create_validation_image.py +37 -0
  245. package/skills/pdf/scripts/extract_form_field_info.py +122 -0
  246. package/skills/pdf/scripts/extract_form_structure.py +115 -0
  247. package/skills/pdf/scripts/fill_fillable_fields.py +98 -0
  248. package/skills/pdf/scripts/fill_pdf_form_with_annotations.py +107 -0
  249. package/skills/pptx/LICENSE.txt +30 -0
  250. package/skills/pptx/SKILL.md +232 -0
  251. package/skills/pptx/SYNC.md +5 -0
  252. package/skills/pptx/editing.md +205 -0
  253. package/skills/pptx/pptxgenjs.md +420 -0
  254. package/skills/pptx/scripts/__init__.py +0 -0
  255. package/skills/pptx/scripts/add_slide.py +195 -0
  256. package/skills/pptx/scripts/clean.py +286 -0
  257. package/skills/pptx/scripts/office/helpers/__init__.py +0 -0
  258. package/skills/pptx/scripts/office/helpers/merge_runs.py +199 -0
  259. package/skills/pptx/scripts/office/helpers/simplify_redlines.py +197 -0
  260. package/skills/pptx/scripts/office/pack.py +159 -0
  261. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  262. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  263. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  264. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  265. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  266. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  267. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  268. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  269. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  270. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  271. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  272. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  273. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  274. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  275. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  276. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  277. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  278. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  279. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  280. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  281. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  282. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  283. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  284. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  285. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  286. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  287. package/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  288. package/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  289. package/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  290. package/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  291. package/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  292. package/skills/pptx/scripts/office/schemas/mce/mc.xsd +75 -0
  293. package/skills/pptx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  294. package/skills/pptx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  295. package/skills/pptx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  296. package/skills/pptx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  297. package/skills/pptx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  298. package/skills/pptx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  299. package/skills/pptx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  300. package/skills/pptx/scripts/office/soffice.py +183 -0
  301. package/skills/pptx/scripts/office/unpack.py +132 -0
  302. package/skills/pptx/scripts/office/validate.py +111 -0
  303. package/skills/pptx/scripts/office/validators/__init__.py +15 -0
  304. package/skills/pptx/scripts/office/validators/base.py +847 -0
  305. package/skills/pptx/scripts/office/validators/docx.py +446 -0
  306. package/skills/pptx/scripts/office/validators/pptx.py +275 -0
  307. package/skills/pptx/scripts/office/validators/redlining.py +247 -0
  308. package/skills/pptx/scripts/thumbnail.py +289 -0
  309. package/skills/shadcn/LICENSE.md +21 -0
  310. package/skills/shadcn/SKILL.md +242 -0
  311. package/skills/shadcn/SYNC.md +5 -0
  312. package/skills/shadcn/agents/openai.yml +5 -0
  313. package/skills/shadcn/assets/shadcn-small.png +0 -0
  314. package/skills/shadcn/assets/shadcn.png +0 -0
  315. package/skills/shadcn/cli.md +257 -0
  316. package/skills/shadcn/customization.md +202 -0
  317. package/skills/shadcn/evals/evals.json +47 -0
  318. package/skills/shadcn/mcp.md +94 -0
  319. package/skills/shadcn/rules/base-vs-radix.md +306 -0
  320. package/skills/shadcn/rules/composition.md +195 -0
  321. package/skills/shadcn/rules/forms.md +192 -0
  322. package/skills/shadcn/rules/icons.md +101 -0
  323. package/skills/shadcn/rules/styling.md +162 -0
  324. package/skills/skill-creator/LICENSE.txt +202 -0
  325. package/skills/skill-creator/SKILL.md +485 -0
  326. package/skills/skill-creator/SYNC.md +5 -0
  327. package/skills/skill-creator/agents/analyzer.md +274 -0
  328. package/skills/skill-creator/agents/comparator.md +202 -0
  329. package/skills/skill-creator/agents/grader.md +223 -0
  330. package/skills/skill-creator/assets/eval_review.html +146 -0
  331. package/skills/skill-creator/eval-viewer/generate_review.py +471 -0
  332. package/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  333. package/skills/skill-creator/references/schemas.md +430 -0
  334. package/skills/skill-creator/scripts/__init__.py +0 -0
  335. package/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
  336. package/skills/skill-creator/scripts/generate_report.py +326 -0
  337. package/skills/skill-creator/scripts/improve_description.py +247 -0
  338. package/skills/skill-creator/scripts/package_skill.py +136 -0
  339. package/skills/skill-creator/scripts/quick_validate.py +103 -0
  340. package/skills/skill-creator/scripts/run_eval.py +310 -0
  341. package/skills/skill-creator/scripts/run_loop.py +328 -0
  342. package/skills/skill-creator/scripts/utils.py +47 -0
  343. package/skills/slack-gif-creator/LICENSE.txt +202 -0
  344. package/skills/slack-gif-creator/SKILL.md +254 -0
  345. package/skills/slack-gif-creator/SYNC.md +5 -0
  346. package/skills/slack-gif-creator/core/easing.py +234 -0
  347. package/skills/slack-gif-creator/core/frame_composer.py +176 -0
  348. package/skills/slack-gif-creator/core/gif_builder.py +269 -0
  349. package/skills/slack-gif-creator/core/validators.py +136 -0
  350. package/skills/slack-gif-creator/requirements.txt +4 -0
  351. package/skills/theme-factory/LICENSE.txt +202 -0
  352. package/skills/theme-factory/SKILL.md +59 -0
  353. package/skills/theme-factory/SYNC.md +5 -0
  354. package/skills/theme-factory/theme-showcase.pdf +0 -0
  355. package/skills/theme-factory/themes/arctic-frost.md +19 -0
  356. package/skills/theme-factory/themes/botanical-garden.md +19 -0
  357. package/skills/theme-factory/themes/desert-rose.md +19 -0
  358. package/skills/theme-factory/themes/forest-canopy.md +19 -0
  359. package/skills/theme-factory/themes/golden-hour.md +19 -0
  360. package/skills/theme-factory/themes/midnight-galaxy.md +19 -0
  361. package/skills/theme-factory/themes/modern-minimalist.md +19 -0
  362. package/skills/theme-factory/themes/ocean-depths.md +19 -0
  363. package/skills/theme-factory/themes/sunset-boulevard.md +19 -0
  364. package/skills/theme-factory/themes/tech-innovation.md +19 -0
  365. package/skills/vue-best-practices/SYNC.md +1 -1
  366. package/skills/vue-jsx-best-practices/SYNC.md +1 -1
  367. package/skills/vue-options-api-best-practices/SYNC.md +1 -1
  368. package/skills/vue-pinia-best-practices/SYNC.md +1 -1
  369. package/skills/vue-router-best-practices/SYNC.md +1 -1
  370. package/skills/vue-testing-best-practices/SYNC.md +1 -1
  371. package/skills/web-artifacts-builder/LICENSE.txt +202 -0
  372. package/skills/web-artifacts-builder/SKILL.md +74 -0
  373. package/skills/web-artifacts-builder/SYNC.md +5 -0
  374. package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +54 -0
  375. package/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -0
  376. package/skills/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  377. package/skills/webapp-testing/LICENSE.txt +202 -0
  378. package/skills/webapp-testing/SKILL.md +96 -0
  379. package/skills/webapp-testing/SYNC.md +5 -0
  380. package/skills/webapp-testing/examples/console_logging.py +35 -0
  381. package/skills/webapp-testing/examples/element_discovery.py +40 -0
  382. package/skills/webapp-testing/examples/static_html_automation.py +33 -0
  383. package/skills/webapp-testing/scripts/with_server.py +106 -0
  384. package/skills/xlsx/LICENSE.txt +30 -0
  385. package/skills/xlsx/SKILL.md +292 -0
  386. package/skills/xlsx/SYNC.md +5 -0
  387. package/skills/xlsx/scripts/office/helpers/__init__.py +0 -0
  388. package/skills/xlsx/scripts/office/helpers/merge_runs.py +199 -0
  389. package/skills/xlsx/scripts/office/helpers/simplify_redlines.py +197 -0
  390. package/skills/xlsx/scripts/office/pack.py +159 -0
  391. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  392. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  393. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  394. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  395. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  396. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  397. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  398. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  399. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  400. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  401. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  402. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  403. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  404. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  405. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  406. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  407. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  408. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  409. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  410. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  411. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  412. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  413. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  414. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  415. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  416. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  417. package/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  418. package/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  419. package/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  420. package/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  421. package/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  422. package/skills/xlsx/scripts/office/schemas/mce/mc.xsd +75 -0
  423. package/skills/xlsx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
  424. package/skills/xlsx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
  425. package/skills/xlsx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
  426. package/skills/xlsx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
  427. package/skills/xlsx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
  428. package/skills/xlsx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  429. package/skills/xlsx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
  430. package/skills/xlsx/scripts/office/soffice.py +183 -0
  431. package/skills/xlsx/scripts/office/unpack.py +132 -0
  432. package/skills/xlsx/scripts/office/validate.py +111 -0
  433. package/skills/xlsx/scripts/office/validators/__init__.py +15 -0
  434. package/skills/xlsx/scripts/office/validators/base.py +847 -0
  435. package/skills/xlsx/scripts/office/validators/docx.py +446 -0
  436. package/skills/xlsx/scripts/office/validators/pptx.py +275 -0
  437. package/skills/xlsx/scripts/office/validators/redlining.py +247 -0
  438. package/skills/xlsx/scripts/recalc.py +184 -0
@@ -0,0 +1,209 @@
1
+ # Agent SDK Patterns — TypeScript
2
+
3
+ ## Basic Agent
4
+
5
+ ```typescript
6
+ import { query } from "@anthropic-ai/claude-agent-sdk";
7
+
8
+ async function main() {
9
+ for await (const message of query({
10
+ prompt: "Explain what this repository does",
11
+ options: {
12
+ cwd: "/path/to/project",
13
+ allowedTools: ["Read", "Glob", "Grep"],
14
+ },
15
+ })) {
16
+ if ("result" in message) {
17
+ console.log(message.result);
18
+ }
19
+ }
20
+ }
21
+
22
+ main();
23
+ ```
24
+
25
+ ---
26
+
27
+ ## Hooks
28
+
29
+ ### After Tool Use Hook
30
+
31
+ ```typescript
32
+ import { query, HookCallback } from "@anthropic-ai/claude-agent-sdk";
33
+ import { appendFileSync } from "fs";
34
+
35
+ const logFileChange: HookCallback = async (input) => {
36
+ const filePath = (input as any).tool_input?.file_path ?? "unknown";
37
+ appendFileSync(
38
+ "./audit.log",
39
+ `${new Date().toISOString()}: modified ${filePath}\n`,
40
+ );
41
+ return {};
42
+ };
43
+
44
+ for await (const message of query({
45
+ prompt: "Refactor utils.py to improve readability",
46
+ options: {
47
+ allowedTools: ["Read", "Edit", "Write"],
48
+ permissionMode: "acceptEdits",
49
+ hooks: {
50
+ PostToolUse: [{ matcher: "Edit|Write", hooks: [logFileChange] }],
51
+ },
52
+ },
53
+ })) {
54
+ if ("result" in message) console.log(message.result);
55
+ }
56
+ ```
57
+
58
+ ---
59
+
60
+ ## Subagents
61
+
62
+ ```typescript
63
+ import { query } from "@anthropic-ai/claude-agent-sdk";
64
+
65
+ for await (const message of query({
66
+ prompt: "Use the code-reviewer agent to review this codebase",
67
+ options: {
68
+ allowedTools: ["Read", "Glob", "Grep", "Agent"],
69
+ agents: {
70
+ "code-reviewer": {
71
+ description: "Expert code reviewer for quality and security reviews.",
72
+ prompt: "Analyze code quality and suggest improvements.",
73
+ tools: ["Read", "Glob", "Grep"],
74
+ },
75
+ },
76
+ },
77
+ })) {
78
+ if ("result" in message) console.log(message.result);
79
+ }
80
+ ```
81
+
82
+ ---
83
+
84
+ ## MCP Server Integration
85
+
86
+ ### Browser Automation (Playwright)
87
+
88
+ ```typescript
89
+ for await (const message of query({
90
+ prompt: "Open example.com and describe what you see",
91
+ options: {
92
+ mcpServers: {
93
+ playwright: { command: "npx", args: ["@playwright/mcp@latest"] },
94
+ },
95
+ },
96
+ })) {
97
+ if ("result" in message) console.log(message.result);
98
+ }
99
+ ```
100
+
101
+ ---
102
+
103
+ ## Session Resumption
104
+
105
+ ```typescript
106
+ import { query } from "@anthropic-ai/claude-agent-sdk";
107
+
108
+ let sessionId: string | undefined;
109
+
110
+ // First query: capture the session ID
111
+ for await (const message of query({
112
+ prompt: "Read the authentication module",
113
+ options: { allowedTools: ["Read", "Glob"] },
114
+ })) {
115
+ if (message.type === "system" && message.subtype === "init") {
116
+ sessionId = message.session_id;
117
+ }
118
+ }
119
+
120
+ // Resume with full context from the first query
121
+ for await (const message of query({
122
+ prompt: "Now find all places that call it",
123
+ options: { resume: sessionId },
124
+ })) {
125
+ if ("result" in message) console.log(message.result);
126
+ }
127
+ ```
128
+
129
+ ---
130
+
131
+ ## Session History
132
+
133
+ ```typescript
134
+ import { listSessions, getSessionMessages, getSessionInfo } from "@anthropic-ai/claude-agent-sdk";
135
+
136
+ async function main() {
137
+ // List past sessions (supports pagination via limit/offset)
138
+ const sessions = await listSessions();
139
+ for (const session of sessions) {
140
+ console.log(`Session ${session.sessionId} in ${session.cwd} (tag: ${session.tag})`);
141
+ }
142
+
143
+ // Get metadata for a single session
144
+ if (sessions.length > 0) {
145
+ const info = await getSessionInfo(sessions[0].sessionId);
146
+ console.log(`Created: ${info.createdAt}, Tag: ${info.tag}`);
147
+ }
148
+
149
+ // Retrieve messages from the most recent session
150
+ if (sessions.length > 0) {
151
+ const messages = await getSessionMessages(sessions[0].sessionId, { limit: 50 });
152
+ for (const msg of messages) {
153
+ console.log(msg);
154
+ }
155
+ }
156
+ }
157
+
158
+ main();
159
+ ```
160
+
161
+ ---
162
+
163
+ ## Session Mutations
164
+
165
+ ```typescript
166
+ import { renameSession, tagSession, forkSession } from "@anthropic-ai/claude-agent-sdk";
167
+
168
+ async function main() {
169
+ const sessionId = "your-session-id";
170
+
171
+ // Rename a session
172
+ await renameSession(sessionId, "Refactoring auth module");
173
+
174
+ // Tag a session for filtering
175
+ await tagSession(sessionId, "experiment-v2");
176
+
177
+ // Clear a tag
178
+ await tagSession(sessionId, null);
179
+
180
+ // Fork a conversation to branch from a point
181
+ const { sessionId: forkedId } = await forkSession(sessionId);
182
+ console.log(`Forked session: ${forkedId}`);
183
+ }
184
+
185
+ main();
186
+ ```
187
+
188
+ ---
189
+
190
+ ## Custom System Prompt
191
+
192
+ ```typescript
193
+ import { query } from "@anthropic-ai/claude-agent-sdk";
194
+
195
+ for await (const message of query({
196
+ prompt: "Review this code",
197
+ options: {
198
+ allowedTools: ["Read", "Glob", "Grep"],
199
+ systemPrompt: `You are a senior code reviewer focused on:
200
+ 1. Security vulnerabilities
201
+ 2. Performance issues
202
+ 3. Code maintainability
203
+
204
+ Always provide specific line numbers and suggestions for improvement.`,
205
+ },
206
+ })) {
207
+ if ("result" in message) console.log(message.result);
208
+ }
209
+ ```
@@ -0,0 +1,321 @@
1
+ # Claude API — TypeScript
2
+
3
+ ## Installation
4
+
5
+ ```bash
6
+ npm install @anthropic-ai/sdk
7
+ ```
8
+
9
+ ## Client Initialization
10
+
11
+ ```typescript
12
+ import Anthropic from "@anthropic-ai/sdk";
13
+
14
+ // Default (uses ANTHROPIC_API_KEY env var)
15
+ const client = new Anthropic();
16
+
17
+ // Explicit API key
18
+ const client = new Anthropic({ apiKey: "your-api-key" });
19
+ ```
20
+
21
+ ---
22
+
23
+ ## Basic Message Request
24
+
25
+ ```typescript
26
+ const response = await client.messages.create({
27
+ model: "claude-opus-4-6",
28
+ max_tokens: 16000,
29
+ messages: [{ role: "user", content: "What is the capital of France?" }],
30
+ });
31
+ // response.content is ContentBlock[] — a discriminated union. Narrow by .type
32
+ // before accessing .text (TypeScript will error on content[0].text without this).
33
+ for (const block of response.content) {
34
+ if (block.type === "text") {
35
+ console.log(block.text);
36
+ }
37
+ }
38
+ ```
39
+
40
+ ---
41
+
42
+ ## System Prompts
43
+
44
+ ```typescript
45
+ const response = await client.messages.create({
46
+ model: "claude-opus-4-6",
47
+ max_tokens: 16000,
48
+ system:
49
+ "You are a helpful coding assistant. Always provide examples in Python.",
50
+ messages: [{ role: "user", content: "How do I read a JSON file?" }],
51
+ });
52
+ ```
53
+
54
+ ---
55
+
56
+ ## Vision (Images)
57
+
58
+ ### URL
59
+
60
+ ```typescript
61
+ const response = await client.messages.create({
62
+ model: "claude-opus-4-6",
63
+ max_tokens: 16000,
64
+ messages: [
65
+ {
66
+ role: "user",
67
+ content: [
68
+ {
69
+ type: "image",
70
+ source: { type: "url", url: "https://example.com/image.png" },
71
+ },
72
+ { type: "text", text: "Describe this image" },
73
+ ],
74
+ },
75
+ ],
76
+ });
77
+ ```
78
+
79
+ ### Base64
80
+
81
+ ```typescript
82
+ import fs from "fs";
83
+
84
+ const imageData = fs.readFileSync("image.png").toString("base64");
85
+
86
+ const response = await client.messages.create({
87
+ model: "claude-opus-4-6",
88
+ max_tokens: 16000,
89
+ messages: [
90
+ {
91
+ role: "user",
92
+ content: [
93
+ {
94
+ type: "image",
95
+ source: { type: "base64", media_type: "image/png", data: imageData },
96
+ },
97
+ { type: "text", text: "What's in this image?" },
98
+ ],
99
+ },
100
+ ],
101
+ });
102
+ ```
103
+
104
+ ---
105
+
106
+ ## Prompt Caching
107
+
108
+ ### Automatic Caching (Recommended)
109
+
110
+ Use top-level `cache_control` to automatically cache the last cacheable block in the request:
111
+
112
+ ```typescript
113
+ const response = await client.messages.create({
114
+ model: "claude-opus-4-6",
115
+ max_tokens: 16000,
116
+ cache_control: { type: "ephemeral" }, // auto-caches the last cacheable block
117
+ system: "You are an expert on this large document...",
118
+ messages: [{ role: "user", content: "Summarize the key points" }],
119
+ });
120
+ ```
121
+
122
+ ### Manual Cache Control
123
+
124
+ For fine-grained control, add `cache_control` to specific content blocks:
125
+
126
+ ```typescript
127
+ const response = await client.messages.create({
128
+ model: "claude-opus-4-6",
129
+ max_tokens: 16000,
130
+ system: [
131
+ {
132
+ type: "text",
133
+ text: "You are an expert on this large document...",
134
+ cache_control: { type: "ephemeral" }, // default TTL is 5 minutes
135
+ },
136
+ ],
137
+ messages: [{ role: "user", content: "Summarize the key points" }],
138
+ });
139
+
140
+ // With explicit TTL (time-to-live)
141
+ const response2 = await client.messages.create({
142
+ model: "claude-opus-4-6",
143
+ max_tokens: 16000,
144
+ system: [
145
+ {
146
+ type: "text",
147
+ text: "You are an expert on this large document...",
148
+ cache_control: { type: "ephemeral", ttl: "1h" }, // 1 hour TTL
149
+ },
150
+ ],
151
+ messages: [{ role: "user", content: "Summarize the key points" }],
152
+ });
153
+ ```
154
+
155
+ ---
156
+
157
+ ## Extended Thinking
158
+
159
+ > **Opus 4.6 and Sonnet 4.6:** Use adaptive thinking. `budget_tokens` is deprecated on both Opus 4.6 and Sonnet 4.6.
160
+ > **Older models:** Use `thinking: {type: "enabled", budget_tokens: N}` (must be < `max_tokens`, min 1024).
161
+
162
+ ```typescript
163
+ // Opus 4.6: adaptive thinking (recommended)
164
+ const response = await client.messages.create({
165
+ model: "claude-opus-4-6",
166
+ max_tokens: 16000,
167
+ thinking: { type: "adaptive" },
168
+ output_config: { effort: "high" }, // low | medium | high | max
169
+ messages: [
170
+ { role: "user", content: "Solve this math problem step by step..." },
171
+ ],
172
+ });
173
+
174
+ for (const block of response.content) {
175
+ if (block.type === "thinking") {
176
+ console.log("Thinking:", block.thinking);
177
+ } else if (block.type === "text") {
178
+ console.log("Response:", block.text);
179
+ }
180
+ }
181
+ ```
182
+
183
+ ---
184
+
185
+ ## Error Handling
186
+
187
+ Use the SDK's typed exception classes — never check error messages with string matching:
188
+
189
+ ```typescript
190
+ import Anthropic from "@anthropic-ai/sdk";
191
+
192
+ try {
193
+ const response = await client.messages.create({...});
194
+ } catch (error) {
195
+ if (error instanceof Anthropic.BadRequestError) {
196
+ console.error("Bad request:", error.message);
197
+ } else if (error instanceof Anthropic.AuthenticationError) {
198
+ console.error("Invalid API key");
199
+ } else if (error instanceof Anthropic.RateLimitError) {
200
+ console.error("Rate limited - retry later");
201
+ } else if (error instanceof Anthropic.APIError) {
202
+ console.error(`API error ${error.status}:`, error.message);
203
+ }
204
+ }
205
+ ```
206
+
207
+ All classes extend `Anthropic.APIError` with a typed `status` field. Check from most specific to least specific. See [shared/error-codes.md](../../shared/error-codes.md) for the full error code reference.
208
+
209
+ ---
210
+
211
+ ## Multi-Turn Conversations
212
+
213
+ The API is stateless — send the full conversation history each time. Use `Anthropic.MessageParam[]` to type the messages array:
214
+
215
+ ```typescript
216
+ const messages: Anthropic.MessageParam[] = [
217
+ { role: "user", content: "My name is Alice." },
218
+ { role: "assistant", content: "Hello Alice! Nice to meet you." },
219
+ { role: "user", content: "What's my name?" },
220
+ ];
221
+
222
+ const response = await client.messages.create({
223
+ model: "claude-opus-4-6",
224
+ max_tokens: 16000,
225
+ messages: messages,
226
+ });
227
+ ```
228
+
229
+ **Rules:**
230
+
231
+ - Consecutive same-role messages are allowed — the API combines them into a single turn
232
+ - First message must be `user`
233
+ - Use SDK types (`Anthropic.MessageParam`, `Anthropic.Message`, `Anthropic.Tool`, etc.) for all API data structures — don't redefine equivalent interfaces
234
+
235
+ ---
236
+
237
+ ### Compaction (long conversations)
238
+
239
+ > **Beta, Opus 4.6 and Sonnet 4.6.** When conversations approach the 200K context window, compaction automatically summarizes earlier context server-side. The API returns a `compaction` block; you must pass it back on subsequent requests — append `response.content`, not just the text.
240
+
241
+ ```typescript
242
+ import Anthropic from "@anthropic-ai/sdk";
243
+
244
+ const client = new Anthropic();
245
+ const messages: Anthropic.Beta.BetaMessageParam[] = [];
246
+
247
+ async function chat(userMessage: string): Promise<string> {
248
+ messages.push({ role: "user", content: userMessage });
249
+
250
+ const response = await client.beta.messages.create({
251
+ betas: ["compact-2026-01-12"],
252
+ model: "claude-opus-4-6",
253
+ max_tokens: 16000,
254
+ messages,
255
+ context_management: {
256
+ edits: [{ type: "compact_20260112" }],
257
+ },
258
+ });
259
+
260
+ // Append full content — compaction blocks must be preserved
261
+ messages.push({ role: "assistant", content: response.content });
262
+
263
+ const textBlock = response.content.find(
264
+ (b): b is Anthropic.Beta.BetaTextBlock => b.type === "text",
265
+ );
266
+ return textBlock?.text ?? "";
267
+ }
268
+
269
+ // Compaction triggers automatically when context grows large
270
+ console.log(await chat("Help me build a Python web scraper"));
271
+ console.log(await chat("Add support for JavaScript-rendered pages"));
272
+ console.log(await chat("Now add rate limiting and error handling"));
273
+ ```
274
+
275
+ ---
276
+
277
+ ## Stop Reasons
278
+
279
+ The `stop_reason` field in the response indicates why the model stopped generating:
280
+
281
+ | Value | Meaning |
282
+ | --------------- | --------------------------------------------------------------- |
283
+ | `end_turn` | Claude finished its response naturally |
284
+ | `max_tokens` | Hit the `max_tokens` limit — increase it or use streaming |
285
+ | `stop_sequence` | Hit a custom stop sequence |
286
+ | `tool_use` | Claude wants to call a tool — execute it and continue |
287
+ | `pause_turn` | Model paused and can be resumed (agentic flows) |
288
+ | `refusal` | Claude refused for safety reasons — output may not match schema |
289
+
290
+ ---
291
+
292
+ ## Cost Optimization Strategies
293
+
294
+ ### 1. Use Prompt Caching for Repeated Context
295
+
296
+ ```typescript
297
+ // Automatic caching (simplest — caches the last cacheable block)
298
+ const response = await client.messages.create({
299
+ model: "claude-opus-4-6",
300
+ max_tokens: 16000,
301
+ cache_control: { type: "ephemeral" },
302
+ system: largeDocumentText, // e.g., 50KB of context
303
+ messages: [{ role: "user", content: "Summarize the key points" }],
304
+ });
305
+
306
+ // First request: full cost
307
+ // Subsequent requests: ~90% cheaper for cached portion
308
+ ```
309
+
310
+ ### 2. Use Token Counting Before Requests
311
+
312
+ ```typescript
313
+ const countResponse = await client.messages.countTokens({
314
+ model: "claude-opus-4-6",
315
+ messages: messages,
316
+ system: system,
317
+ });
318
+
319
+ const estimatedInputCost = countResponse.input_tokens * 0.000005; // $5/1M tokens
320
+ console.log(`Estimated input cost: $${estimatedInputCost.toFixed(4)}`);
321
+ ```
@@ -0,0 +1,106 @@
1
+ # Message Batches API — TypeScript
2
+
3
+ The Batches API (`POST /v1/messages/batches`) processes Messages API requests asynchronously at 50% of standard prices.
4
+
5
+ ## Key Facts
6
+
7
+ - Up to 100,000 requests or 256 MB per batch
8
+ - Most batches complete within 1 hour; maximum 24 hours
9
+ - Results available for 29 days after creation
10
+ - 50% cost reduction on all token usage
11
+ - All Messages API features supported (vision, tools, caching, etc.)
12
+
13
+ ---
14
+
15
+ ## Create a Batch
16
+
17
+ ```typescript
18
+ import Anthropic from "@anthropic-ai/sdk";
19
+
20
+ const client = new Anthropic();
21
+
22
+ const messageBatch = await client.messages.batches.create({
23
+ requests: [
24
+ {
25
+ custom_id: "request-1",
26
+ params: {
27
+ model: "claude-opus-4-6",
28
+ max_tokens: 16000,
29
+ messages: [
30
+ { role: "user", content: "Summarize climate change impacts" },
31
+ ],
32
+ },
33
+ },
34
+ {
35
+ custom_id: "request-2",
36
+ params: {
37
+ model: "claude-opus-4-6",
38
+ max_tokens: 16000,
39
+ messages: [
40
+ { role: "user", content: "Explain quantum computing basics" },
41
+ ],
42
+ },
43
+ },
44
+ ],
45
+ });
46
+
47
+ console.log(`Batch ID: ${messageBatch.id}`);
48
+ console.log(`Status: ${messageBatch.processing_status}`);
49
+ ```
50
+
51
+ ---
52
+
53
+ ## Poll for Completion
54
+
55
+ ```typescript
56
+ let batch;
57
+ while (true) {
58
+ batch = await client.messages.batches.retrieve(messageBatch.id);
59
+ if (batch.processing_status === "ended") break;
60
+ console.log(
61
+ `Status: ${batch.processing_status}, processing: ${batch.request_counts.processing}`,
62
+ );
63
+ await new Promise((resolve) => setTimeout(resolve, 60_000));
64
+ }
65
+
66
+ console.log("Batch complete!");
67
+ console.log(`Succeeded: ${batch.request_counts.succeeded}`);
68
+ console.log(`Errored: ${batch.request_counts.errored}`);
69
+ ```
70
+
71
+ ---
72
+
73
+ ## Retrieve Results
74
+
75
+ ```typescript
76
+ for await (const result of await client.messages.batches.results(
77
+ messageBatch.id,
78
+ )) {
79
+ switch (result.result.type) {
80
+ case "succeeded":
81
+ console.log(
82
+ `[${result.custom_id}] ${result.result.message.content[0].text.slice(0, 100)}`,
83
+ );
84
+ break;
85
+ case "errored":
86
+ if (result.result.error.type === "invalid_request") {
87
+ console.log(`[${result.custom_id}] Validation error - fix and retry`);
88
+ } else {
89
+ console.log(`[${result.custom_id}] Server error - safe to retry`);
90
+ }
91
+ break;
92
+ case "expired":
93
+ console.log(`[${result.custom_id}] Expired - resubmit`);
94
+ break;
95
+ }
96
+ }
97
+ ```
98
+
99
+ ---
100
+
101
+ ## Cancel a Batch
102
+
103
+ ```typescript
104
+ const cancelled = await client.messages.batches.cancel(messageBatch.id);
105
+ console.log(`Status: ${cancelled.processing_status}`); // "canceling"
106
+ ```