@waoooo/claude-skills 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (264) hide show
  1. package/README.md +48 -0
  2. package/package.json +28 -0
  3. package/registry.json +431 -0
  4. package/skills/acceptance-review/SKILL.md +537 -0
  5. package/skills/all-plan/SKILL.md +19 -0
  6. package/skills/all-plan/references/flow.md +750 -0
  7. package/skills/api-docs-generate/SKILL.md +204 -0
  8. package/skills/api-docs-generate/assets/templates/api.mdx +140 -0
  9. package/skills/api-docs-generate/scripts/generate-api-docs.ts +308 -0
  10. package/skills/ask/SKILL.md +42 -0
  11. package/skills/autonew/SKILL.md +34 -0
  12. package/skills/capability-analyze/SKILL.md +300 -0
  13. package/skills/capability-analyze/scripts/analyze-capabilities.ts +531 -0
  14. package/skills/capability-docs-generate/SKILL.md +155 -0
  15. package/skills/capability-docs-generate/assets/templates/capability.mdx +271 -0
  16. package/skills/capability-docs-generate/scripts/generate-capability-docs.ts +358 -0
  17. package/skills/capability-tree-query/SKILL.md +112 -0
  18. package/skills/capability-tree-query/scripts/build-capability-tree.ts +402 -0
  19. package/skills/changelog-generator/SKILL.md +104 -0
  20. package/skills/continue/SKILL.md +39 -0
  21. package/skills/continue/agents/openai.yaml +3 -0
  22. package/skills/creating-skills/SKILL.md +158 -0
  23. package/skills/creating-skills/references/official_best_practices.md +128 -0
  24. package/skills/creating-skills/references/skill_examples.md +199 -0
  25. package/skills/docx/LICENSE.txt +30 -0
  26. package/skills/docx/SKILL.md +197 -0
  27. package/skills/docx/docx-js.md +350 -0
  28. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  29. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  30. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  31. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  32. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  33. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  34. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  35. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  36. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  37. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  38. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  39. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  40. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  41. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  42. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  43. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  44. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  45. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  46. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  47. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  48. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  49. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  50. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  51. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  52. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  53. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  54. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  55. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  56. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  57. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  58. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  59. package/skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
  60. package/skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  61. package/skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  62. package/skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  63. package/skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  64. package/skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  65. package/skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  66. package/skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  67. package/skills/docx/ooxml/scripts/pack.py +159 -0
  68. package/skills/docx/ooxml/scripts/unpack.py +29 -0
  69. package/skills/docx/ooxml/scripts/validate.py +69 -0
  70. package/skills/docx/ooxml/scripts/validation/__init__.py +15 -0
  71. package/skills/docx/ooxml/scripts/validation/base.py +951 -0
  72. package/skills/docx/ooxml/scripts/validation/docx.py +274 -0
  73. package/skills/docx/ooxml/scripts/validation/pptx.py +315 -0
  74. package/skills/docx/ooxml/scripts/validation/redlining.py +279 -0
  75. package/skills/docx/ooxml.md +610 -0
  76. package/skills/docx/scripts/__init__.py +1 -0
  77. package/skills/docx/scripts/document.py +1276 -0
  78. package/skills/docx/scripts/templates/comments.xml +3 -0
  79. package/skills/docx/scripts/templates/commentsExtended.xml +3 -0
  80. package/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  81. package/skills/docx/scripts/templates/commentsIds.xml +3 -0
  82. package/skills/docx/scripts/templates/people.xml +3 -0
  83. package/skills/docx/scripts/utilities.py +374 -0
  84. package/skills/git-branch-create/SKILL.md +170 -0
  85. package/skills/git-branch-merge/SKILL.md +176 -0
  86. package/skills/git-commit/SKILL.md +56 -0
  87. package/skills/git-commit/references/commit_examples.md +311 -0
  88. package/skills/github-actions-trigger/SKILL.md +367 -0
  89. package/skills/github-issue-create/SKILL.md +294 -0
  90. package/skills/github-pr-creation/SKILL.md +137 -0
  91. package/skills/github-pr-creation/references/pr_templates.md +187 -0
  92. package/skills/github-pr-merge/SKILL.md +112 -0
  93. package/skills/github-pr-review/SKILL.md +110 -0
  94. package/skills/github-pr-review/references/severity_guide.md +168 -0
  95. package/skills/job-create/SKILL.md +294 -0
  96. package/skills/job-create/scripts/create-job.ts +105 -0
  97. package/skills/job-workflow/SKILL.md +212 -0
  98. package/skills/keyword-extract/SKILL.md +229 -0
  99. package/skills/mcp-builder/LICENSE.txt +202 -0
  100. package/skills/mcp-builder/SKILL.md +236 -0
  101. package/skills/mcp-builder/reference/evaluation.md +602 -0
  102. package/skills/mcp-builder/reference/mcp_best_practices.md +249 -0
  103. package/skills/mcp-builder/reference/node_mcp_server.md +970 -0
  104. package/skills/mcp-builder/reference/python_mcp_server.md +719 -0
  105. package/skills/mcp-builder/scripts/connections.py +151 -0
  106. package/skills/mcp-builder/scripts/evaluation.py +373 -0
  107. package/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  108. package/skills/mcp-builder/scripts/requirements.txt +2 -0
  109. package/skills/mdx-to-openspec/SKILL.md +827 -0
  110. package/skills/mdx-to-openspec/scripts/mdx-to-openspec.ts +320 -0
  111. package/skills/mounted/SKILL.md +20 -0
  112. package/skills/multi-model-review/SKILL.md +459 -0
  113. package/skills/notion-automation/SKILL.md +215 -0
  114. package/skills/openspec-review/SKILL.md +513 -0
  115. package/skills/pdf/LICENSE.txt +30 -0
  116. package/skills/pdf/SKILL.md +294 -0
  117. package/skills/pdf/forms.md +205 -0
  118. package/skills/pdf/reference.md +612 -0
  119. package/skills/pdf/scripts/check_bounding_boxes.py +70 -0
  120. package/skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
  121. package/skills/pdf/scripts/check_fillable_fields.py +12 -0
  122. package/skills/pdf/scripts/convert_pdf_to_images.py +35 -0
  123. package/skills/pdf/scripts/create_validation_image.py +41 -0
  124. package/skills/pdf/scripts/extract_form_field_info.py +152 -0
  125. package/skills/pdf/scripts/fill_fillable_fields.py +114 -0
  126. package/skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
  127. package/skills/pend/SKILL.md +33 -0
  128. package/skills/ping/SKILL.md +39 -0
  129. package/skills/pptx/LICENSE.txt +30 -0
  130. package/skills/pptx/SKILL.md +484 -0
  131. package/skills/pptx/html2pptx.md +625 -0
  132. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  133. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  134. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  135. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  136. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  137. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  138. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  139. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  140. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  141. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  142. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  143. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  144. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  145. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  146. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  147. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  148. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  149. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  150. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  151. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  152. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  153. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  154. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  155. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  156. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  157. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  158. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  159. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  160. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  161. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  162. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  163. package/skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
  164. package/skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  165. package/skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  166. package/skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  167. package/skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  168. package/skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  169. package/skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  170. package/skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  171. package/skills/pptx/ooxml/scripts/pack.py +159 -0
  172. package/skills/pptx/ooxml/scripts/unpack.py +29 -0
  173. package/skills/pptx/ooxml/scripts/validate.py +69 -0
  174. package/skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
  175. package/skills/pptx/ooxml/scripts/validation/base.py +951 -0
  176. package/skills/pptx/ooxml/scripts/validation/docx.py +274 -0
  177. package/skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
  178. package/skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
  179. package/skills/pptx/ooxml.md +427 -0
  180. package/skills/pptx/scripts/html2pptx.js +979 -0
  181. package/skills/pptx/scripts/inventory.py +1020 -0
  182. package/skills/pptx/scripts/rearrange.py +231 -0
  183. package/skills/pptx/scripts/replace.py +385 -0
  184. package/skills/pptx/scripts/thumbnail.py +450 -0
  185. package/skills/progress-update/SKILL.md +394 -0
  186. package/skills/progress-update/scripts/update-progress.ts +221 -0
  187. package/skills/release-automation/SKILL.md +306 -0
  188. package/skills/requirement-parse/SKILL.md +212 -0
  189. package/skills/requirement-parse/scripts/infer-builder-config.ts +346 -0
  190. package/skills/requirement-parse/scripts/merge-requirements.ts +228 -0
  191. package/skills/requirement-parse/scripts/parse-docs.ts +206 -0
  192. package/skills/requirement-parse/scripts/parse-openspec.ts +168 -0
  193. package/skills/roadmap-docs-generate/SKILL.md +483 -0
  194. package/skills/roadmap-docs-generate/assets/templates/ROADMAP.mdx +75 -0
  195. package/skills/roadmap-docs-generate/assets/templates/ROADMAP.mdx.template +330 -0
  196. package/skills/roadmap-docs-generate/assets/templates/TODO.mdx +56 -0
  197. package/skills/roadmap-docs-generate/assets/templates/TODO.mdx.template +363 -0
  198. package/skills/roadmap-docs-generate/scripts/json-to-mdx.ts +445 -0
  199. package/skills/roadmap-docs-generate/scripts/json-to-mdx.ts.backup +411 -0
  200. package/skills/roadmap-generate/SKILL.md +396 -0
  201. package/skills/roadmap-generate/scripts/generate-roadmap.ts +496 -0
  202. package/skills/skill-creator/LICENSE.txt +202 -0
  203. package/skills/skill-creator/SKILL.md +356 -0
  204. package/skills/skill-creator/references/output-patterns.md +82 -0
  205. package/skills/skill-creator/references/workflows.md +28 -0
  206. package/skills/skill-creator/scripts/init_skill.py +303 -0
  207. package/skills/skill-creator/scripts/package_skill.py +110 -0
  208. package/skills/skill-creator/scripts/quick_validate.py +95 -0
  209. package/skills/spec-generate/SKILL.md +408 -0
  210. package/skills/spec-generate/scripts/generate-specs.ts +538 -0
  211. package/skills/spec-generate/scripts/generate-tasks.ts +174 -0
  212. package/skills/specs-review/SKILL.md +370 -0
  213. package/skills/task-execute/SKILL.md +399 -0
  214. package/skills/task-update-status/SKILL.md +349 -0
  215. package/skills/task-update-status/scripts/update-task-status.ts +192 -0
  216. package/skills/task-verify/SKILL.md +407 -0
  217. package/skills/ui-ux-pro-max/SKILL.md +386 -0
  218. package/skills/ui-ux-pro-max/data/charts.csv +26 -0
  219. package/skills/ui-ux-pro-max/data/colors.csv +97 -0
  220. package/skills/ui-ux-pro-max/data/icons.csv +101 -0
  221. package/skills/ui-ux-pro-max/data/landing.csv +31 -0
  222. package/skills/ui-ux-pro-max/data/products.csv +97 -0
  223. package/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  224. package/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -0
  225. package/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  226. package/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  227. package/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
  228. package/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  229. package/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  230. package/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  231. package/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  232. package/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
  233. package/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  234. package/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  235. package/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  236. package/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  237. package/skills/ui-ux-pro-max/data/styles.csv +68 -0
  238. package/skills/ui-ux-pro-max/data/typography.csv +58 -0
  239. package/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  240. package/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  241. package/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
  242. package/skills/ui-ux-pro-max/scripts/core.py +253 -0
  243. package/skills/ui-ux-pro-max/scripts/design_system.py +1067 -0
  244. package/skills/ui-ux-pro-max/scripts/search.py +114 -0
  245. package/skills/vercel-automation/SKILL.md +226 -0
  246. package/skills/webapp-testing/LICENSE.txt +202 -0
  247. package/skills/webapp-testing/SKILL.md +96 -0
  248. package/skills/webapp-testing/examples/console_logging.py +35 -0
  249. package/skills/webapp-testing/examples/element_discovery.py +40 -0
  250. package/skills/webapp-testing/examples/static_html_automation.py +33 -0
  251. package/skills/webapp-testing/scripts/with_server.py +106 -0
  252. package/skills/worktree-manager/SKILL.md +725 -0
  253. package/skills/worktree-manager/config.json +15 -0
  254. package/skills/worktree-manager/scripts/allocate-ports.sh +100 -0
  255. package/skills/worktree-manager/scripts/cleanup.sh +185 -0
  256. package/skills/worktree-manager/scripts/launch-agent.sh +155 -0
  257. package/skills/worktree-manager/scripts/register.sh +125 -0
  258. package/skills/worktree-manager/scripts/release-ports.sh +48 -0
  259. package/skills/worktree-manager/scripts/status.sh +169 -0
  260. package/skills/worktree-manager/scripts/sync.sh +168 -0
  261. package/skills/worktree-manager/templates/worktree.json +23 -0
  262. package/skills/xlsx/LICENSE.txt +30 -0
  263. package/skills/xlsx/SKILL.md +289 -0
  264. package/skills/xlsx/recalc.py +178 -0
@@ -0,0 +1,394 @@
1
+ # Skill: progress-update
2
+
3
+ ## 功能
4
+
5
+ 更新 progress.json,跟踪任务执行进度,减少会话长度。
6
+
7
+ ## 何时调用
8
+
9
+ - 步骤 18:任务状态更新后
10
+ - 需要记录进度时
11
+ - 生成进度报告时
12
+
13
+ ## 输入
14
+
15
+ - `taskId` - 任务 ID(例如:TASK-001)
16
+ - `jobId` - Job ID(例如:2026-02-10-1520-pricing-system)
17
+ - `status` - 新状态(pending / in-progress / completed / failed)
18
+ - `notes` - 备注信息(可选)
19
+
20
+ ## 输出
21
+
22
+ - 更新后的 progress.json
23
+ - 进度统计
24
+
25
+ ## 执行步骤
26
+
27
+ ### 1. 读取 progress.json
28
+
29
+ ```typescript
30
+ const progressPath = `exports/jobs/${jobId}/specs/progress.json`
31
+ const progress = JSON.parse(readFile(progressPath))
32
+ ```
33
+
34
+ ### 2. 更新任务状态
35
+
36
+ ```typescript
37
+ // 查找任务
38
+ const taskIndex = progress.tasks?.findIndex(t => t.taskId === taskId)
39
+
40
+ if (taskIndex === -1) {
41
+ // 任务不存在,添加新任务
42
+ if (!progress.tasks) {
43
+ progress.tasks = []
44
+ }
45
+
46
+ progress.tasks.push({
47
+ taskId: taskId,
48
+ status: status,
49
+ startedAt: status === 'in-progress' ? new Date().toISOString() : null,
50
+ completedAt: status === 'completed' ? new Date().toISOString() : null,
51
+ failedAt: status === 'failed' ? new Date().toISOString() : null,
52
+ notes: notes || null
53
+ })
54
+ } else {
55
+ // 更新现有任务
56
+ const task = progress.tasks[taskIndex]
57
+ const oldStatus = task.status
58
+
59
+ task.status = status
60
+
61
+ // 更新时间戳
62
+ if (status === 'in-progress' && !task.startedAt) {
63
+ task.startedAt = new Date().toISOString()
64
+ }
65
+
66
+ if (status === 'completed' && !task.completedAt) {
67
+ task.completedAt = new Date().toISOString()
68
+
69
+ // 计算实际耗时
70
+ if (task.startedAt) {
71
+ task.duration = calculateDuration(task.startedAt, task.completedAt)
72
+ }
73
+ }
74
+
75
+ if (status === 'failed' && !task.failedAt) {
76
+ task.failedAt = new Date().toISOString()
77
+ }
78
+
79
+ // 添加备注
80
+ if (notes) {
81
+ task.notes = notes
82
+ }
83
+ }
84
+ ```
85
+
86
+ ### 3. 更新统计信息
87
+
88
+ ```typescript
89
+ // 重新计算统计
90
+ const allTasks = progress.tasks || []
91
+
92
+ progress.progress = {
93
+ totalTasks: allTasks.length,
94
+ completed: allTasks.filter(t => t.status === 'completed').length,
95
+ inProgress: allTasks.filter(t => t.status === 'in-progress').length,
96
+ pending: allTasks.filter(t => t.status === 'pending').length,
97
+ failed: allTasks.filter(t => t.status === 'failed').length,
98
+ percentage: Math.round(
99
+ (allTasks.filter(t => t.status === 'completed').length / allTasks.length) * 100
100
+ )
101
+ }
102
+
103
+ // 更新整体状态
104
+ if (progress.progress.failed > 0) {
105
+ progress.status = 'failed'
106
+ } else if (progress.progress.inProgress > 0) {
107
+ progress.status = 'in-progress'
108
+ } else if (progress.progress.completed === progress.progress.totalTasks) {
109
+ progress.status = 'completed'
110
+ } else {
111
+ progress.status = 'pending'
112
+ }
113
+
114
+ // 更新时间戳
115
+ progress.updatedAt = new Date().toISOString()
116
+ ```
117
+
118
+ ### 4. 添加时间线事件
119
+
120
+ ```typescript
121
+ if (!progress.timeline) {
122
+ progress.timeline = []
123
+ }
124
+
125
+ progress.timeline.push({
126
+ timestamp: new Date().toISOString(),
127
+ event: `task-${status}`,
128
+ taskId: taskId,
129
+ description: `Task ${taskId} ${status}`,
130
+ notes: notes || null
131
+ })
132
+
133
+ // 限制时间线长度(保留最近 100 条)
134
+ if (progress.timeline.length > 100) {
135
+ progress.timeline = progress.timeline.slice(-100)
136
+ }
137
+ ```
138
+
139
+ ### 5. 更新当前任务和下一个任务
140
+
141
+ ```typescript
142
+ // 更新当前任务
143
+ if (status === 'in-progress') {
144
+ progress.currentTask = taskId
145
+ } else if (status === 'completed' || status === 'failed') {
146
+ progress.currentTask = null
147
+ }
148
+
149
+ // 查找下一个可执行任务
150
+ const tasks = JSON.parse(readFile(`exports/jobs/${jobId}/specs/tasks.json`))
151
+ const nextTask = tasks.tasks.find(t =>
152
+ t.status === 'pending' &&
153
+ (!t.blockedBy || t.blockedBy.length === 0 ||
154
+ t.blockedBy.every(id =>
155
+ allTasks.find(pt => pt.taskId === id && pt.status === 'completed')
156
+ ))
157
+ )
158
+
159
+ progress.nextTask = nextTask ? nextTask.taskId : null
160
+ ```
161
+
162
+ ### 6. 写入文件
163
+
164
+ ```typescript
165
+ writeFile(progressPath, JSON.stringify(progress, null, 2))
166
+ ```
167
+
168
+ ## progress.json 结构
169
+
170
+ ```json
171
+ {
172
+ "version": "1.0.0",
173
+ "jobId": "2026-02-10-1520-pricing-system",
174
+ "updatedAt": "2026-02-11T10:30:00Z",
175
+ "status": "in-progress",
176
+
177
+ "progress": {
178
+ "totalTasks": 12,
179
+ "completed": 5,
180
+ "inProgress": 1,
181
+ "pending": 6,
182
+ "failed": 0,
183
+ "percentage": 42
184
+ },
185
+
186
+ "tasks": [
187
+ {
188
+ "taskId": "TASK-001",
189
+ "status": "completed",
190
+ "startedAt": "2026-02-11T03:00:00Z",
191
+ "completedAt": "2026-02-11T10:30:00Z",
192
+ "duration": "7h 30m",
193
+ "notes": null
194
+ },
195
+ {
196
+ "taskId": "TASK-002",
197
+ "status": "in-progress",
198
+ "startedAt": "2026-02-11T10:35:00Z",
199
+ "completedAt": null,
200
+ "duration": null,
201
+ "notes": "Working on invoice calculation"
202
+ }
203
+ ],
204
+
205
+ "timeline": [
206
+ {
207
+ "timestamp": "2026-02-11T03:00:00Z",
208
+ "event": "task-in-progress",
209
+ "taskId": "TASK-001",
210
+ "description": "Task TASK-001 in-progress"
211
+ },
212
+ {
213
+ "timestamp": "2026-02-11T10:30:00Z",
214
+ "event": "task-completed",
215
+ "taskId": "TASK-001",
216
+ "description": "Task TASK-001 completed"
217
+ }
218
+ ],
219
+
220
+ "currentTask": "TASK-002",
221
+ "nextTask": "TASK-003",
222
+ "blockers": []
223
+ }
224
+ ```
225
+
226
+ ## 使用示例
227
+
228
+ ### 示例 1:标记任务开始
229
+
230
+ ```
231
+ Agent 调用 progress-update:
232
+ 输入:
233
+ - taskId: TASK-001
234
+ - jobId: 2026-02-10-1520-pricing-system
235
+ - status: in-progress
236
+
237
+ 执行:
238
+ 🔧 步骤 1: 读取 progress.json
239
+ ⏳ 当前进度: 0/12 (0%)
240
+
241
+ 🔧 步骤 2: 更新任务状态
242
+ 📝 TASK-001: pending → in-progress
243
+ 📝 开始时间: 2026-02-11 03:00:00
244
+
245
+ 🔧 步骤 3: 更新统计
246
+ 📊 进度: 0/12 → 0/12 (in-progress: 0 → 1)
247
+
248
+ 🔧 步骤 4: 添加时间线
249
+ ✅ 事件: task-in-progress
250
+
251
+ 🔧 步骤 5: 更新当前任务
252
+ 📝 当前任务: null → TASK-001
253
+
254
+ 🔧 步骤 6: 写入文件
255
+ ✅ 已保存
256
+
257
+ 显示结果:
258
+ ✅ 进度已更新
259
+
260
+ 📊 当前进度:
261
+ - 总任务: 12
262
+ - 已完成: 0 (0%)
263
+ - 进行中: 1 (TASK-001)
264
+ - 待开始: 11
265
+
266
+ 💡 下一步:
267
+ 继续执行 TASK-001
268
+ ```
269
+
270
+ ### 示例 2:标记任务完成
271
+
272
+ ```
273
+ Agent 调用 progress-update:
274
+ 输入:
275
+ - taskId: TASK-001
276
+ - jobId: 2026-02-10-1520-pricing-system
277
+ - status: completed
278
+ - notes: "All subtasks completed, tests passed"
279
+
280
+ 执行:
281
+ 🔧 步骤 1-6: 更新进度
282
+
283
+ 显示结果:
284
+ ✅ 进度已更新
285
+
286
+ 📊 当前进度:
287
+ - 总任务: 12
288
+ - 已完成: 1 (8%)
289
+ - 进行中: 0
290
+ - 待开始: 11
291
+
292
+ ✅ TASK-001 已完成:
293
+ - 开始: 2026-02-11 03:00:00
294
+ - 完成: 2026-02-11 10:30:00
295
+ - 耗时: 7h 30m
296
+ - 备注: All subtasks completed, tests passed
297
+
298
+ 📝 下一个任务: TASK-002
299
+
300
+ 💡 下一步:
301
+ 可以开始执行 TASK-002
302
+ ```
303
+
304
+ ### 示例 3:批量更新
305
+
306
+ ```
307
+ Agent 调用 progress-update (批量):
308
+ 输入:
309
+ - updates: [
310
+ { taskId: "TASK-001", status: "completed" },
311
+ { taskId: "TASK-002", status: "completed" },
312
+ { taskId: "TASK-003", status: "in-progress" }
313
+ ]
314
+ - jobId: 2026-02-10-1520-pricing-system
315
+
316
+ 执行:
317
+ 🔧 批量更新 3 个任务
318
+
319
+ 显示结果:
320
+ ✅ 批量更新完成
321
+
322
+ 📊 当前进度:
323
+ - 总任务: 12
324
+ - 已完成: 2 (17%)
325
+ - 进行中: 1
326
+ - 待开始: 9
327
+
328
+ 💡 进度提升: 0% → 17%
329
+ ```
330
+
331
+ ## 错误处理
332
+
333
+ ### 错误 1:progress.json 不存在
334
+
335
+ ```
336
+ ❌ 错误: progress.json 不存在
337
+ 🔍 原因: 文件未找到
338
+
339
+ 💡 建议:
340
+ 1. 检查 Job 路径
341
+ 2. 重新运行 spec-generate
342
+ ```
343
+
344
+ ### 错误 2:JSON 格式错误
345
+
346
+ ```
347
+ ❌ 错误: JSON 解析失败
348
+ 🔍 原因: progress.json 格式不正确
349
+
350
+ 💡 建议:
351
+ 1. 检查 JSON 格式
352
+ 2. 恢复备份文件
353
+ 3. 或重新生成
354
+ ```
355
+
356
+ ## 注意事项
357
+
358
+ 1. **减少会话长度** - 这是创建此 Skill 的主要原因
359
+ 2. **原子操作** - 读取-修改-写入作为原子操作
360
+ 3. **时间线限制** - 保留最近 100 条事件
361
+ 4. **自动计算** - 自动计算进度百分比和耗时
362
+ 5. **下一个任务** - 自动查找下一个可执行任务
363
+
364
+ ## 性能优化
365
+
366
+ ### 为什么需要独立 Skill?
367
+
368
+ **问题**:
369
+ ```
370
+ ❌ 没有独立 Skill:
371
+ 主 Agent → 读取 progress.json (500 行)
372
+ → 修改一个字段
373
+ → 写入 progress.json (500 行)
374
+ → 上下文消耗:1000+ tokens
375
+ ```
376
+
377
+ **解决**:
378
+ ```
379
+ ✅ 有独立 Skill:
380
+ 主 Agent → skill(name="progress-update", params={taskId, status})
381
+ → Skill 内部处理(不占用主会话上下文)
382
+ → 返回简单结果:"✅ 已更新"
383
+ → 上下文消耗:50 tokens
384
+ ```
385
+
386
+ **效果**:
387
+ - 节省 95% 的上下文消耗
388
+ - 提高执行效率
389
+ - 减少会话长度
390
+
391
+ ## 相关文件
392
+
393
+ - `exports/jobs/<job-id>/specs/progress.json` - 进度跟踪
394
+ - `exports/jobs/<job-id>/specs/tasks.json` - 任务列表
@@ -0,0 +1,221 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Update Progress Tracking File
4
+ *
5
+ * This script updates progress.json file:
6
+ * - Update task completion status
7
+ * - Recalculate progress percentage
8
+ * - Update timestamps
9
+ *
10
+ * Usage:
11
+ * npx tsx update-progress.ts \
12
+ * --job-id <job-id> \
13
+ * --task <task-id> \
14
+ * --status <completed|in_progress|failed>
15
+ *
16
+ * Example:
17
+ * npx tsx update-progress.ts \
18
+ * --job-id 2026-02-10-1520-pricing-system \
19
+ * --task TASK-001 \
20
+ * --status completed
21
+ */
22
+
23
+ import fs from 'fs';
24
+ import path from 'path';
25
+ import { fileURLToPath } from 'url';
26
+
27
+ const __filename = fileURLToPath(import.meta.url);
28
+ const __dirname = path.dirname(__filename);
29
+
30
+ // ============================================================================
31
+ // Types
32
+ // ============================================================================
33
+
34
+ type TaskStatus = 'completed' | 'in_progress' | 'failed' | 'pending';
35
+
36
+ interface Task {
37
+ id: string;
38
+ title: string;
39
+ status: TaskStatus;
40
+ startedAt?: string;
41
+ completedAt?: string;
42
+ estimatedHours?: number;
43
+ actualHours?: number;
44
+ }
45
+
46
+ interface Progress {
47
+ version: string;
48
+ jobId: string;
49
+ updatedAt: string;
50
+ summary: {
51
+ total: number;
52
+ completed: number;
53
+ inProgress: number;
54
+ failed: number;
55
+ pending: number;
56
+ percentage: number;
57
+ };
58
+ tasks: Task[];
59
+ }
60
+
61
+ interface UpdateOptions {
62
+ jobId: string;
63
+ taskId: string;
64
+ status: TaskStatus;
65
+ actualHours?: number;
66
+ }
67
+
68
+ // ============================================================================
69
+ // CLI Arguments
70
+ // ============================================================================
71
+
72
+ function parseArgs(): UpdateOptions {
73
+ const args = process.argv.slice(2);
74
+ const result: any = {};
75
+
76
+ for (let i = 0; i < args.length; i += 2) {
77
+ const key = args[i].replace('--', '');
78
+ const value = args[i + 1];
79
+ result[key] = value;
80
+ }
81
+
82
+ if (!result['job-id'] || !result.task || !result.status) {
83
+ console.error('❌ Missing required arguments');
84
+ console.error('Usage: update-progress.ts --job-id <id> --task <id> --status <status>');
85
+ process.exit(1);
86
+ }
87
+
88
+ return {
89
+ jobId: result['job-id'],
90
+ taskId: result.task,
91
+ status: result.status as TaskStatus,
92
+ actualHours: result['actual-hours'] ? parseFloat(result['actual-hours']) : undefined,
93
+ };
94
+ }
95
+
96
+ // ============================================================================
97
+ // Progress File Operations
98
+ // ============================================================================
99
+
100
+ function getProgressPath(jobId: string): string {
101
+ return path.resolve(__dirname, `../../../../exports/jobs/${jobId}/specs/progress.json`);
102
+ }
103
+
104
+ function readProgress(jobId: string): Progress {
105
+ const progressPath = getProgressPath(jobId);
106
+
107
+ if (!fs.existsSync(progressPath)) {
108
+ throw new Error(`progress.json not found: ${progressPath}`);
109
+ }
110
+
111
+ return JSON.parse(fs.readFileSync(progressPath, 'utf-8'));
112
+ }
113
+
114
+ function writeProgress(jobId: string, progress: Progress): void {
115
+ const progressPath = getProgressPath(jobId);
116
+ fs.writeFileSync(progressPath, JSON.stringify(progress, null, 2), 'utf-8');
117
+ }
118
+
119
+ function updateTaskInProgress(
120
+ progress: Progress,
121
+ taskId: string,
122
+ status: TaskStatus,
123
+ actualHours?: number
124
+ ): Progress {
125
+ const task = progress.tasks.find(t => t.id === taskId);
126
+
127
+ if (!task) {
128
+ throw new Error(`Task ${taskId} not found in progress.json`);
129
+ }
130
+
131
+ const now = new Date().toISOString();
132
+
133
+ // Update task status
134
+ const oldStatus = task.status;
135
+ task.status = status;
136
+
137
+ // Update timestamps
138
+ if (status === 'in_progress' && !task.startedAt) {
139
+ task.startedAt = now;
140
+ }
141
+
142
+ if (status === 'completed' && !task.completedAt) {
143
+ task.completedAt = now;
144
+ if (actualHours !== undefined) {
145
+ task.actualHours = actualHours;
146
+ }
147
+ }
148
+
149
+ // Recalculate summary
150
+ progress.summary = {
151
+ total: progress.tasks.length,
152
+ completed: progress.tasks.filter(t => t.status === 'completed').length,
153
+ inProgress: progress.tasks.filter(t => t.status === 'in_progress').length,
154
+ failed: progress.tasks.filter(t => t.status === 'failed').length,
155
+ pending: progress.tasks.filter(t => t.status === 'pending').length,
156
+ percentage: 0,
157
+ };
158
+
159
+ progress.summary.percentage = Math.round(
160
+ (progress.summary.completed / progress.summary.total) * 100
161
+ );
162
+
163
+ // Update timestamp
164
+ progress.updatedAt = now;
165
+
166
+ return progress;
167
+ }
168
+
169
+ // ============================================================================
170
+ // Main
171
+ // ============================================================================
172
+
173
+ async function main() {
174
+ console.log('📊 Updating progress tracking...\n');
175
+
176
+ const options = parseArgs();
177
+
178
+ console.log('📥 Input:');
179
+ console.log(` - Job ID: ${options.jobId}`);
180
+ console.log(` - Task ID: ${options.taskId}`);
181
+ console.log(` - Status: ${options.status}`);
182
+ if (options.actualHours) {
183
+ console.log(` - Actual Hours: ${options.actualHours}h`);
184
+ }
185
+ console.log('');
186
+
187
+ // Step 1: Read progress.json
188
+ console.log('📖 Step 1/3: Reading progress.json...');
189
+ const progress = readProgress(options.jobId);
190
+ console.log(`✅ Read (${progress.tasks.length} tasks)\n`);
191
+
192
+ // Step 2: Update task
193
+ console.log('🔧 Step 2/3: Updating task...');
194
+ const updatedProgress = updateTaskInProgress(
195
+ progress,
196
+ options.taskId,
197
+ options.status,
198
+ options.actualHours
199
+ );
200
+ console.log('✅ Updated\n');
201
+
202
+ // Step 3: Write back
203
+ console.log('💾 Step 3/3: Writing progress.json...');
204
+ writeProgress(options.jobId, updatedProgress);
205
+ console.log('✅ Written\n');
206
+
207
+ console.log('📊 Progress Summary:');
208
+ console.log(` - Total: ${updatedProgress.summary.total}`);
209
+ console.log(` - Completed: ${updatedProgress.summary.completed}`);
210
+ console.log(` - In Progress: ${updatedProgress.summary.inProgress}`);
211
+ console.log(` - Failed: ${updatedProgress.summary.failed}`);
212
+ console.log(` - Pending: ${updatedProgress.summary.pending}`);
213
+ console.log(` - Percentage: ${updatedProgress.summary.percentage}%\n`);
214
+
215
+ console.log('🎉 Done!');
216
+ }
217
+
218
+ main().catch(error => {
219
+ console.error('❌ Error:', error.message);
220
+ process.exit(1);
221
+ });