ma-agents 2.22.1 → 3.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 (480) hide show
  1. package/.opencode/skills/.ma-agents.json +99 -99
  2. package/lib/bmad-cache/bmb/.claude-plugin/marketplace.json +22 -0
  3. package/lib/bmad-cache/bmb/.markdownlint-cli2.yaml +1 -0
  4. package/lib/bmad-cache/bmb/_git_preserved/index +0 -0
  5. package/lib/bmad-cache/bmb/_git_preserved/logs/HEAD +1 -1
  6. package/lib/bmad-cache/bmb/_git_preserved/logs/refs/heads/main +1 -1
  7. package/lib/bmad-cache/bmb/_git_preserved/logs/refs/remotes/origin/HEAD +1 -1
  8. package/lib/bmad-cache/bmb/_git_preserved/objects/pack/pack-0de89e0854d5b2b3b3b0c1ee56eee73a739f15e7.idx +0 -0
  9. package/lib/bmad-cache/bmb/_git_preserved/objects/pack/pack-0de89e0854d5b2b3b3b0c1ee56eee73a739f15e7.pack +0 -0
  10. package/lib/bmad-cache/bmb/_git_preserved/objects/pack/pack-0de89e0854d5b2b3b3b0c1ee56eee73a739f15e7.rev +0 -0
  11. package/lib/bmad-cache/bmb/_git_preserved/packed-refs +1 -1
  12. package/lib/bmad-cache/bmb/_git_preserved/refs/heads/main +1 -1
  13. package/lib/bmad-cache/bmb/_git_preserved/shallow +1 -1
  14. package/lib/bmad-cache/bmb/package-lock.json +2 -2
  15. package/lib/bmad-cache/bmb/package.json +7 -4
  16. package/lib/bmad-cache/bmb/skills/bmad-agent-builder/scripts/generate-html-report.py +534 -0
  17. package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-agent-builder/scripts/prepass-execution-deps.py +4 -35
  18. package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-agent-builder/scripts/prepass-prompt-metrics.py +2 -75
  19. package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-agent-builder/scripts/prepass-structure-capabilities.py +3 -194
  20. package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-agent-builder/scripts/scan-path-standards.py +104 -18
  21. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/assets/module-help.csv +6 -0
  22. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/assets/module.yaml +20 -0
  23. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/scripts/cleanup-legacy.py +259 -0
  24. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/scripts/merge-config.py +408 -0
  25. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/scripts/merge-help-csv.py +220 -0
  26. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/scripts/tests/test-cleanup-legacy.py +429 -0
  27. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/scripts/tests/test-merge-config.py +644 -0
  28. package/lib/bmad-cache/bmb/skills/bmad-builder-setup/scripts/tests/test-merge-help-csv.py +237 -0
  29. package/lib/bmad-cache/bmb/skills/bmad-workflow-builder/scripts/generate-html-report.py +539 -0
  30. package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-workflow-builder/scripts/prepass-execution-deps.py +5 -30
  31. package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-workflow-builder/scripts/prepass-workflow-integrity.py +0 -5
  32. package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-workflow-builder/scripts/scan-path-standards.py +103 -16
  33. package/lib/bmad-cache/bmb/skills/module-help.csv +6 -0
  34. package/lib/bmad-cache/bmb/skills/module.yaml +20 -0
  35. package/lib/bmad-cache/bmb/tools/validate-doc-links.cjs +407 -0
  36. package/lib/bmad-cache/bmb/tools/validate-file-refs.mjs +1 -1
  37. package/lib/bmad-cache/cache-manifest.json +16 -10
  38. package/lib/bmad-cache/cis/.claude-plugin/marketplace.json +33 -0
  39. package/lib/bmad-cache/cis/_git_preserved/index +0 -0
  40. package/lib/bmad-cache/cis/_git_preserved/logs/HEAD +1 -1
  41. package/lib/bmad-cache/cis/_git_preserved/logs/refs/heads/main +1 -1
  42. package/lib/bmad-cache/cis/_git_preserved/logs/refs/remotes/origin/HEAD +1 -1
  43. package/lib/bmad-cache/cis/_git_preserved/objects/pack/pack-9d60aae6b09bbea0d0c5e79fdbe96e8f66de84e6.idx +0 -0
  44. package/lib/bmad-cache/cis/_git_preserved/objects/pack/{pack-157d7eb8d527233a8607d926fc74ebf87f2ae0d3.pack → pack-9d60aae6b09bbea0d0c5e79fdbe96e8f66de84e6.pack} +0 -0
  45. package/lib/bmad-cache/cis/_git_preserved/objects/pack/pack-9d60aae6b09bbea0d0c5e79fdbe96e8f66de84e6.rev +0 -0
  46. package/lib/bmad-cache/cis/_git_preserved/packed-refs +1 -1
  47. package/lib/bmad-cache/cis/_git_preserved/refs/heads/main +1 -1
  48. package/lib/bmad-cache/cis/_git_preserved/shallow +1 -1
  49. package/lib/bmad-cache/cis/package-lock.json +17015 -0
  50. package/lib/bmad-cache/cis/package.json +3 -4
  51. package/lib/bmad-cache/cis/src/module-help.csv +6 -6
  52. package/lib/bmad-cache/cis/src/skills/bmad-cis-agent-brainstorming-coach/bmad-skill-manifest.yaml +11 -0
  53. package/lib/bmad-cache/cis/src/skills/bmad-cis-agent-creative-problem-solver/bmad-skill-manifest.yaml +11 -0
  54. package/lib/bmad-cache/cis/src/skills/bmad-cis-agent-design-thinking-coach/bmad-skill-manifest.yaml +11 -0
  55. package/lib/bmad-cache/cis/src/skills/bmad-cis-agent-innovation-strategist/bmad-skill-manifest.yaml +11 -0
  56. package/lib/bmad-cache/cis/src/skills/bmad-cis-agent-presentation-master/bmad-skill-manifest.yaml +11 -0
  57. package/lib/bmad-cache/cis/src/skills/bmad-cis-agent-storyteller/bmad-skill-manifest.yaml +11 -0
  58. package/lib/bmad-cache/gds/.claude-plugin/marketplace.json +58 -0
  59. package/lib/bmad-cache/gds/_git_preserved/index +0 -0
  60. package/lib/bmad-cache/gds/_git_preserved/logs/HEAD +1 -1
  61. package/lib/bmad-cache/gds/_git_preserved/logs/refs/heads/main +1 -1
  62. package/lib/bmad-cache/gds/_git_preserved/logs/refs/remotes/origin/HEAD +1 -1
  63. package/lib/bmad-cache/gds/_git_preserved/objects/pack/pack-8099a88fca0ad946a573316a00887a2921ca1712.idx +0 -0
  64. package/lib/bmad-cache/gds/_git_preserved/objects/pack/{pack-44faafb9245b4ca17ad81bd6c9e6fc52fb5915a1.pack → pack-8099a88fca0ad946a573316a00887a2921ca1712.pack} +0 -0
  65. package/lib/bmad-cache/gds/_git_preserved/objects/pack/pack-8099a88fca0ad946a573316a00887a2921ca1712.rev +0 -0
  66. package/lib/bmad-cache/gds/_git_preserved/packed-refs +1 -1
  67. package/lib/bmad-cache/gds/_git_preserved/refs/heads/main +1 -1
  68. package/lib/bmad-cache/gds/_git_preserved/shallow +1 -1
  69. package/lib/bmad-cache/gds/package.json +1 -0
  70. package/lib/bmad-cache/gds/src/module-help.csv +35 -35
  71. package/lib/bmad-cache/tea/.claude-plugin/marketplace.json +33 -0
  72. package/lib/bmad-cache/tea/CHANGELOG.md +2 -14
  73. package/lib/bmad-cache/tea/README.md +31 -18
  74. package/lib/bmad-cache/tea/_git_preserved/index +0 -0
  75. package/lib/bmad-cache/tea/_git_preserved/objects/pack/pack-d243f64f83b36190434d68872a69a40870c53030.idx +0 -0
  76. package/lib/bmad-cache/tea/_git_preserved/objects/pack/{pack-96ec1ce3a9ef4c891e00e060795b4434ba8f7163.pack → pack-d243f64f83b36190434d68872a69a40870c53030.pack} +0 -0
  77. package/lib/bmad-cache/tea/_git_preserved/objects/pack/pack-d243f64f83b36190434d68872a69a40870c53030.rev +0 -0
  78. package/lib/bmad-cache/tea/_git_preserved/packed-refs +1 -1
  79. package/lib/bmad-cache/tea/_git_preserved/refs/heads/main +1 -1
  80. package/lib/bmad-cache/tea/_git_preserved/refs/tags/v1.7.3 +1 -0
  81. package/lib/bmad-cache/tea/_git_preserved/shallow +1 -1
  82. package/lib/bmad-cache/tea/docs/explanation/knowledge-base-system.md +5 -5
  83. package/lib/bmad-cache/tea/docs/explanation/step-file-architecture.md +2 -2
  84. package/lib/bmad-cache/tea/docs/explanation/tea-overview.md +3 -3
  85. package/lib/bmad-cache/tea/docs/glossary/index.md +1 -1
  86. package/lib/bmad-cache/tea/docs/how-to/customization/extend-tea-with-custom-workflows.md +73 -0
  87. package/lib/bmad-cache/tea/docs/how-to/workflows/teach-me-testing.md +7 -7
  88. package/lib/bmad-cache/tea/docs/index.md +2 -1
  89. package/lib/bmad-cache/tea/docs/reference/commands.md +4 -1
  90. package/lib/bmad-cache/tea/docs/reference/configuration.md +37 -15
  91. package/lib/bmad-cache/tea/docs/reference/knowledge-base.md +75 -73
  92. package/lib/bmad-cache/tea/docs/reference/troubleshooting.md +32 -19
  93. package/lib/bmad-cache/tea/docs/tutorials/learn-testing-tea-academy.md +3 -3
  94. package/lib/bmad-cache/tea/package-lock.json +2 -2
  95. package/lib/bmad-cache/tea/package.json +2 -1
  96. package/lib/bmad-cache/tea/src/agents/bmad-tea/SKILL.md +70 -0
  97. package/lib/bmad-cache/tea/src/agents/bmad-tea/bmad-skill-manifest.yaml +14 -0
  98. package/lib/bmad-cache/tea/src/module-help.csv +10 -10
  99. package/lib/bmad-cache/tea/src/module.yaml +8 -8
  100. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/checklist.md +1 -1
  101. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/curriculum.yaml +1 -1
  102. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/session-content-map.yaml +26 -14
  103. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/tea-resources-index.yaml +108 -73
  104. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/instructions.md +2 -2
  105. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-03-session-menu.md +1 -1
  106. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-01.md +3 -3
  107. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-07.md +14 -6
  108. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-05-completion.md +3 -3
  109. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/templates/certificate-template.md +1 -1
  110. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/workflow-plan-teach-me-testing.md +8 -8
  111. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/atdd-checklist-template.md +1 -1
  112. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-01-preflight-and-context.md +3 -3
  113. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-04a-subagent-api-failing.md +9 -1
  114. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-01-preflight-and-context.md +1 -1
  115. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-03b-subagent-e2e.md +2 -2
  116. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-c/step-02-generate-pipeline.md +6 -0
  117. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-c/step-03-configure-quality-gates.md +6 -1
  118. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-c/step-03-scaffold-framework.md +3 -2
  119. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-01-load-context.md +1 -1
  120. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-c/step-02-load-context.md +1 -1
  121. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-01-load-context.md +1 -1
  122. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/test-review-template.md +11 -11
  123. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-c/step-01-load-context.md +1 -1
  124. package/lib/bmad-cache/tea/test/test-installation-components.js +85 -21
  125. package/lib/bmad-cache/tea/test/test-knowledge-base.js +1 -1
  126. package/lib/bmad-cache/tea/tools/validate-agent-schema.js +105 -5
  127. package/lib/bmad-cache/wds/.claude-plugin/marketplace.json +35 -0
  128. package/lib/bmad-cache/wds/.markdownlint-cli2.yaml +38 -0
  129. package/lib/bmad-cache/wds/.nvmrc +1 -0
  130. package/lib/bmad-cache/wds/.prettierignore +9 -0
  131. package/lib/bmad-cache/wds/LICENSE +27 -0
  132. package/lib/bmad-cache/wds/README.md +126 -0
  133. package/lib/bmad-cache/wds/_git_preserved/HEAD +1 -0
  134. package/lib/bmad-cache/wds/_git_preserved/config +13 -0
  135. package/lib/bmad-cache/wds/_git_preserved/description +1 -0
  136. package/lib/bmad-cache/wds/_git_preserved/hooks/applypatch-msg.sample +15 -0
  137. package/lib/bmad-cache/wds/_git_preserved/hooks/commit-msg.sample +24 -0
  138. package/lib/bmad-cache/wds/_git_preserved/hooks/fsmonitor-watchman.sample +174 -0
  139. package/lib/bmad-cache/wds/_git_preserved/hooks/post-update.sample +8 -0
  140. package/lib/bmad-cache/wds/_git_preserved/hooks/pre-applypatch.sample +14 -0
  141. package/lib/bmad-cache/wds/_git_preserved/hooks/pre-commit.sample +49 -0
  142. package/lib/bmad-cache/wds/_git_preserved/hooks/pre-merge-commit.sample +13 -0
  143. package/lib/bmad-cache/wds/_git_preserved/hooks/pre-push.sample +53 -0
  144. package/lib/bmad-cache/wds/_git_preserved/hooks/pre-rebase.sample +169 -0
  145. package/lib/bmad-cache/wds/_git_preserved/hooks/pre-receive.sample +24 -0
  146. package/lib/bmad-cache/wds/_git_preserved/hooks/prepare-commit-msg.sample +42 -0
  147. package/lib/bmad-cache/wds/_git_preserved/hooks/push-to-checkout.sample +78 -0
  148. package/lib/bmad-cache/wds/_git_preserved/hooks/sendemail-validate.sample +77 -0
  149. package/lib/bmad-cache/wds/_git_preserved/hooks/update.sample +128 -0
  150. package/lib/bmad-cache/wds/_git_preserved/index +0 -0
  151. package/lib/bmad-cache/wds/_git_preserved/info/exclude +6 -0
  152. package/lib/bmad-cache/wds/_git_preserved/logs/HEAD +1 -0
  153. package/lib/bmad-cache/wds/_git_preserved/logs/refs/heads/main +1 -0
  154. package/lib/bmad-cache/wds/_git_preserved/logs/refs/remotes/origin/HEAD +1 -0
  155. package/lib/bmad-cache/wds/_git_preserved/objects/pack/pack-92d32f26e3a97a0786dcea5cb2c24bf90384521c.idx +0 -0
  156. package/lib/bmad-cache/wds/_git_preserved/objects/pack/pack-92d32f26e3a97a0786dcea5cb2c24bf90384521c.pack +0 -0
  157. package/lib/bmad-cache/wds/_git_preserved/objects/pack/pack-92d32f26e3a97a0786dcea5cb2c24bf90384521c.rev +0 -0
  158. package/lib/bmad-cache/wds/_git_preserved/packed-refs +2 -0
  159. package/lib/bmad-cache/wds/_git_preserved/refs/heads/main +1 -0
  160. package/lib/bmad-cache/wds/_git_preserved/refs/remotes/origin/HEAD +1 -0
  161. package/lib/bmad-cache/wds/_git_preserved/shallow +1 -0
  162. package/lib/bmad-cache/wds/eslint.config.mjs +152 -0
  163. package/lib/bmad-cache/wds/package.json +82 -0
  164. package/lib/bmad-cache/wds/prettier.config.mjs +32 -0
  165. package/lib/bmad-cache/wds/src/agents/wds-agent-freya-ux/bmad-skill-manifest.yaml +12 -0
  166. package/lib/bmad-cache/wds/src/agents/wds-agent-saga-analyst/bmad-skill-manifest.yaml +12 -0
  167. package/lib/bmad-cache/wds/src/module-help.csv +18 -0
  168. package/lib/bmad-cache/wds/src/module.yaml +148 -0
  169. package/lib/bmad-cache/wds/src/workflows/wds-1-project-brief/bmad-skill-manifest.yaml +1 -0
  170. package/lib/bmad-cache/wds/src/workflows/wds-1-project-brief/templates/platform-requirements.template.yaml +69 -0
  171. package/lib/bmad-cache/wds/src/workflows/wds-2-trigger-mapping/bmad-skill-manifest.yaml +1 -0
  172. package/lib/bmad-cache/wds/src/workflows/wds-3-scenarios/bmad-skill-manifest.yaml +1 -0
  173. package/lib/bmad-cache/wds/src/workflows/wds-4-ux-design/bmad-skill-manifest.yaml +1 -0
  174. package/lib/bmad-cache/wds/src/workflows/wds-4-ux-design/templates/design-delivery.template.yaml +104 -0
  175. package/lib/bmad-cache/wds/src/workflows/wds-4-ux-design/templates/test-scenario.template.yaml +192 -0
  176. package/lib/bmad-cache/wds/src/workflows/wds-5-agentic-development/bmad-skill-manifest.yaml +1 -0
  177. package/lib/bmad-cache/wds/src/workflows/wds-5-agentic-development/templates/components/dev-mode.css +164 -0
  178. package/lib/bmad-cache/wds/src/workflows/wds-5-agentic-development/templates/components/dev-mode.html +18 -0
  179. package/lib/bmad-cache/wds/src/workflows/wds-5-agentic-development/templates/components/dev-mode.js +430 -0
  180. package/lib/bmad-cache/wds/src/workflows/wds-5-agentic-development/templates/demo-data-template.json +63 -0
  181. package/lib/bmad-cache/wds/src/workflows/wds-5-agentic-development/templates/page-template.html +465 -0
  182. package/lib/bmad-cache/wds/src/workflows/wds-5-agentic-development/templates/work-file-template.yaml +264 -0
  183. package/lib/bmad-cache/wds/src/workflows/wds-6-asset-generation/bmad-skill-manifest.yaml +1 -0
  184. package/lib/bmad-cache/wds/src/workflows/wds-7-design-system/bmad-skill-manifest.yaml +1 -0
  185. package/lib/bmad-cache/wds/src/workflows/wds-7-design-system/templates/catalog.template.html +363 -0
  186. package/lib/bmad-cache/wds/src/workflows/wds-8-product-evolution/bmad-skill-manifest.yaml +1 -0
  187. package/lib/bmad-customize/bmm-architect.customize.yaml +6 -0
  188. package/lib/bmad-customize/bmm-bmad-master.customize.yaml +6 -0
  189. package/lib/bmad-customize/bmm-dev.customize.yaml +6 -0
  190. package/lib/bmad-customize/bmm-pm.customize.yaml +6 -0
  191. package/lib/bmad-customize/bmm-qa.customize.yaml +6 -0
  192. package/lib/bmad-customize/bmm-sm.customize.yaml +6 -0
  193. package/lib/bmad-customize/bmm-tech-writer.customize.yaml +6 -0
  194. package/lib/bmad-customize/bmm-ux-designer.customize.yaml +6 -0
  195. package/lib/bmad-extension/module-help.csv +37 -7
  196. package/lib/bmad-extension/module.yaml +4 -2
  197. package/lib/bmad-extension/skills/add-sprint/.gitkeep +0 -0
  198. package/lib/bmad-extension/skills/add-sprint/SKILL.md +121 -0
  199. package/lib/bmad-extension/skills/add-sprint/bmad-skill-manifest.yaml +3 -0
  200. package/lib/bmad-extension/skills/add-to-sprint/.gitkeep +0 -0
  201. package/lib/bmad-extension/skills/add-to-sprint/SKILL.md +215 -0
  202. package/lib/bmad-extension/skills/add-to-sprint/bmad-skill-manifest.yaml +3 -0
  203. package/lib/bmad-extension/skills/bmad-ma-agent-cyber/.gitkeep +0 -0
  204. package/lib/bmad-extension/skills/bmad-ma-agent-cyber/SKILL.md +44 -0
  205. package/lib/bmad-extension/skills/bmad-ma-agent-cyber/bmad-skill-manifest.yaml +11 -0
  206. package/lib/bmad-extension/skills/bmad-ma-agent-devops/.gitkeep +0 -0
  207. package/lib/bmad-extension/skills/bmad-ma-agent-devops/SKILL.md +44 -0
  208. package/lib/bmad-extension/skills/bmad-ma-agent-devops/bmad-skill-manifest.yaml +11 -0
  209. package/lib/bmad-extension/skills/bmad-ma-agent-mil498/.gitkeep +0 -0
  210. package/lib/bmad-extension/skills/bmad-ma-agent-mil498/SKILL.md +48 -0
  211. package/lib/bmad-extension/skills/bmad-ma-agent-mil498/bmad-skill-manifest.yaml +11 -0
  212. package/lib/bmad-extension/skills/bmad-ma-agent-sre/.gitkeep +0 -0
  213. package/lib/bmad-extension/skills/bmad-ma-agent-sre/SKILL.md +44 -0
  214. package/lib/bmad-extension/skills/bmad-ma-agent-sre/bmad-skill-manifest.yaml +11 -0
  215. package/lib/bmad-extension/skills/create-bug-story/.gitkeep +0 -0
  216. package/lib/bmad-extension/skills/create-bug-story/SKILL.md +195 -0
  217. package/lib/bmad-extension/skills/create-bug-story/bmad-skill-manifest.yaml +3 -0
  218. package/lib/bmad-extension/skills/cyber-generate-certs/.gitkeep +0 -0
  219. package/lib/bmad-extension/skills/cyber-generate-certs/SKILL.md +27 -0
  220. package/lib/bmad-extension/skills/cyber-generate-certs/bmad-skill-manifest.yaml +3 -0
  221. package/lib/bmad-extension/skills/cyber-immunity-estimation/.gitkeep +0 -0
  222. package/lib/bmad-extension/skills/cyber-immunity-estimation/SKILL.md +29 -0
  223. package/lib/bmad-extension/skills/cyber-immunity-estimation/bmad-skill-manifest.yaml +3 -0
  224. package/lib/bmad-extension/skills/cyber-security-audit/.gitkeep +0 -0
  225. package/lib/bmad-extension/skills/cyber-security-audit/SKILL.md +27 -0
  226. package/lib/bmad-extension/skills/cyber-security-audit/bmad-skill-manifest.yaml +3 -0
  227. package/lib/bmad-extension/skills/cyber-vault-secrets/.gitkeep +0 -0
  228. package/lib/bmad-extension/skills/cyber-vault-secrets/SKILL.md +28 -0
  229. package/lib/bmad-extension/skills/cyber-vault-secrets/bmad-skill-manifest.yaml +3 -0
  230. package/lib/bmad-extension/skills/cyber-verify-docker-users/.gitkeep +0 -0
  231. package/lib/bmad-extension/skills/cyber-verify-docker-users/SKILL.md +23 -0
  232. package/lib/bmad-extension/skills/cyber-verify-docker-users/bmad-skill-manifest.yaml +3 -0
  233. package/lib/bmad-extension/skills/cyber-verify-image-signature/.gitkeep +0 -0
  234. package/lib/bmad-extension/skills/cyber-verify-image-signature/SKILL.md +22 -0
  235. package/lib/bmad-extension/skills/cyber-verify-image-signature/bmad-skill-manifest.yaml +3 -0
  236. package/lib/bmad-extension/skills/cyber-vulnerability-scan/.gitkeep +0 -0
  237. package/lib/bmad-extension/skills/cyber-vulnerability-scan/SKILL.md +28 -0
  238. package/lib/bmad-extension/skills/cyber-vulnerability-scan/bmad-skill-manifest.yaml +3 -0
  239. package/lib/bmad-extension/skills/devops-configure-infrastructure/.gitkeep +0 -0
  240. package/lib/bmad-extension/skills/devops-configure-infrastructure/SKILL.md +27 -0
  241. package/lib/bmad-extension/skills/devops-configure-infrastructure/bmad-skill-manifest.yaml +3 -0
  242. package/lib/bmad-extension/skills/devops-disconnected-deployment/.gitkeep +0 -0
  243. package/lib/bmad-extension/skills/devops-disconnected-deployment/SKILL.md +27 -0
  244. package/lib/bmad-extension/skills/devops-disconnected-deployment/bmad-skill-manifest.yaml +3 -0
  245. package/lib/bmad-extension/skills/devops-docker-compose-setup/.gitkeep +0 -0
  246. package/lib/bmad-extension/skills/devops-docker-compose-setup/SKILL.md +26 -0
  247. package/lib/bmad-extension/skills/devops-docker-compose-setup/bmad-skill-manifest.yaml +3 -0
  248. package/lib/bmad-extension/skills/devops-manage-helm/.gitkeep +0 -0
  249. package/lib/bmad-extension/skills/devops-manage-helm/SKILL.md +28 -0
  250. package/lib/bmad-extension/skills/devops-manage-helm/bmad-skill-manifest.yaml +3 -0
  251. package/lib/bmad-extension/skills/devops-sign-docker-image/.gitkeep +0 -0
  252. package/lib/bmad-extension/skills/devops-sign-docker-image/SKILL.md +24 -0
  253. package/lib/bmad-extension/skills/devops-sign-docker-image/bmad-skill-manifest.yaml +3 -0
  254. package/lib/bmad-extension/skills/mil498-ocd/.gitkeep +0 -0
  255. package/lib/bmad-extension/skills/mil498-ocd/SKILL.md +30 -0
  256. package/lib/bmad-extension/skills/mil498-ocd/bmad-skill-manifest.yaml +5 -0
  257. package/lib/bmad-extension/skills/mil498-ocd/prompts/01-discover-project-artifacts.md +26 -0
  258. package/lib/bmad-extension/skills/mil498-ocd/prompts/02-load-template.md +10 -0
  259. package/lib/bmad-extension/skills/mil498-ocd/prompts/03-generate-document.md +90 -0
  260. package/lib/bmad-extension/skills/mil498-ocd/prompts/04-validate.md +14 -0
  261. package/lib/bmad-extension/skills/mil498-ocd/prompts/05-review.md +15 -0
  262. package/lib/bmad-extension/skills/mil498-ocd/prompts/06-save.md +15 -0
  263. package/lib/bmad-extension/skills/mil498-ocd/template.md +169 -0
  264. package/lib/bmad-extension/skills/mil498-sdd/.gitkeep +0 -0
  265. package/lib/bmad-extension/skills/mil498-sdd/SKILL.md +30 -0
  266. package/lib/bmad-extension/skills/mil498-sdd/bmad-skill-manifest.yaml +5 -0
  267. package/lib/bmad-extension/skills/mil498-sdd/prompts/01-discover-project-artifacts.md +50 -0
  268. package/lib/bmad-extension/skills/mil498-sdd/prompts/02-load-template.md +10 -0
  269. package/lib/bmad-extension/skills/mil498-sdd/prompts/03-generate-document.md +98 -0
  270. package/lib/bmad-extension/skills/mil498-sdd/prompts/04-validate.md +16 -0
  271. package/lib/bmad-extension/skills/mil498-sdd/prompts/05-review.md +15 -0
  272. package/lib/bmad-extension/skills/mil498-sdd/prompts/06-save.md +19 -0
  273. package/lib/bmad-extension/skills/mil498-sdd/template.md +163 -0
  274. package/lib/bmad-extension/skills/mil498-sdp/.gitkeep +0 -0
  275. package/lib/bmad-extension/skills/mil498-sdp/SKILL.md +30 -0
  276. package/lib/bmad-extension/skills/mil498-sdp/bmad-skill-manifest.yaml +5 -0
  277. package/lib/bmad-extension/skills/mil498-sdp/prompts/01-discover-project-artifacts.md +32 -0
  278. package/lib/bmad-extension/skills/mil498-sdp/prompts/02-load-template.md +10 -0
  279. package/lib/bmad-extension/skills/mil498-sdp/prompts/03-generate-document.md +187 -0
  280. package/lib/bmad-extension/skills/mil498-sdp/prompts/04-validate.md +13 -0
  281. package/lib/bmad-extension/skills/mil498-sdp/prompts/05-review.md +15 -0
  282. package/lib/bmad-extension/skills/mil498-sdp/prompts/06-save.md +14 -0
  283. package/lib/bmad-extension/skills/mil498-sdp/template.md +307 -0
  284. package/lib/bmad-extension/skills/mil498-srs/.gitkeep +0 -0
  285. package/lib/bmad-extension/skills/mil498-srs/SKILL.md +30 -0
  286. package/lib/bmad-extension/skills/mil498-srs/bmad-skill-manifest.yaml +5 -0
  287. package/lib/bmad-extension/skills/mil498-srs/prompts/01-discover-project-artifacts.md +42 -0
  288. package/lib/bmad-extension/skills/mil498-srs/prompts/02-load-template.md +10 -0
  289. package/lib/bmad-extension/skills/mil498-srs/prompts/03-generate-document.md +100 -0
  290. package/lib/bmad-extension/skills/mil498-srs/prompts/04-validate.md +16 -0
  291. package/lib/bmad-extension/skills/mil498-srs/prompts/05-review.md +15 -0
  292. package/lib/bmad-extension/skills/mil498-srs/prompts/06-save.md +18 -0
  293. package/lib/bmad-extension/skills/mil498-srs/template.md +219 -0
  294. package/lib/bmad-extension/skills/mil498-ssdd/.gitkeep +0 -0
  295. package/lib/bmad-extension/skills/mil498-ssdd/SKILL.md +32 -0
  296. package/lib/bmad-extension/skills/mil498-ssdd/bmad-skill-manifest.yaml +5 -0
  297. package/lib/bmad-extension/skills/mil498-ssdd/prompts/01-discover-project-artifacts.md +32 -0
  298. package/lib/bmad-extension/skills/mil498-ssdd/prompts/02-load-template.md +10 -0
  299. package/lib/bmad-extension/skills/mil498-ssdd/prompts/03-csci-discovery-interview.md +43 -0
  300. package/lib/bmad-extension/skills/mil498-ssdd/prompts/04-generate-document.md +96 -0
  301. package/lib/bmad-extension/skills/mil498-ssdd/prompts/05-validate.md +14 -0
  302. package/lib/bmad-extension/skills/mil498-ssdd/prompts/06-review.md +16 -0
  303. package/lib/bmad-extension/skills/mil498-ssdd/prompts/07-save.md +16 -0
  304. package/lib/bmad-extension/skills/mil498-ssdd/template.md +154 -0
  305. package/lib/bmad-extension/skills/mil498-sss/.gitkeep +0 -0
  306. package/lib/bmad-extension/skills/mil498-sss/SKILL.md +31 -0
  307. package/lib/bmad-extension/skills/mil498-sss/bmad-skill-manifest.yaml +5 -0
  308. package/lib/bmad-extension/skills/mil498-sss/prompts/01-discover-project-artifacts.md +31 -0
  309. package/lib/bmad-extension/skills/mil498-sss/prompts/02-load-template.md +10 -0
  310. package/lib/bmad-extension/skills/mil498-sss/prompts/03-generate-document.md +108 -0
  311. package/lib/bmad-extension/skills/mil498-sss/prompts/04-validate.md +16 -0
  312. package/lib/bmad-extension/skills/mil498-sss/prompts/05-review.md +15 -0
  313. package/lib/bmad-extension/skills/mil498-sss/prompts/06-save.md +15 -0
  314. package/lib/bmad-extension/skills/mil498-sss/template.md +225 -0
  315. package/lib/bmad-extension/skills/mil498-std/.gitkeep +0 -0
  316. package/lib/bmad-extension/skills/mil498-std/SKILL.md +30 -0
  317. package/lib/bmad-extension/skills/mil498-std/bmad-skill-manifest.yaml +5 -0
  318. package/lib/bmad-extension/skills/mil498-std/prompts/01-discover-project-artifacts.md +42 -0
  319. package/lib/bmad-extension/skills/mil498-std/prompts/02-load-template.md +10 -0
  320. package/lib/bmad-extension/skills/mil498-std/prompts/03-generate-document.md +117 -0
  321. package/lib/bmad-extension/skills/mil498-std/prompts/04-validate.md +15 -0
  322. package/lib/bmad-extension/skills/mil498-std/prompts/05-review.md +15 -0
  323. package/lib/bmad-extension/skills/mil498-std/prompts/06-save.md +15 -0
  324. package/lib/bmad-extension/skills/mil498-std/template.md +188 -0
  325. package/lib/bmad-extension/skills/modify-sprint/.gitkeep +0 -0
  326. package/lib/bmad-extension/skills/modify-sprint/SKILL.md +259 -0
  327. package/lib/bmad-extension/skills/modify-sprint/bmad-skill-manifest.yaml +3 -0
  328. package/lib/bmad-extension/skills/project-context-expansion/.gitkeep +0 -0
  329. package/lib/bmad-extension/skills/project-context-expansion/SKILL.md +238 -0
  330. package/lib/bmad-extension/skills/project-context-expansion/bmad-skill-manifest.yaml +3 -0
  331. package/lib/bmad-extension/skills/sprint-status-view/.gitkeep +0 -0
  332. package/lib/bmad-extension/skills/sprint-status-view/SKILL.md +202 -0
  333. package/lib/bmad-extension/skills/sprint-status-view/bmad-skill-manifest.yaml +3 -0
  334. package/lib/bmad-extension/skills/sre-check-deployment-status/.gitkeep +0 -0
  335. package/lib/bmad-extension/skills/sre-check-deployment-status/SKILL.md +32 -0
  336. package/lib/bmad-extension/skills/sre-check-deployment-status/bmad-skill-manifest.yaml +3 -0
  337. package/lib/bmad-extension/skills/sre-check-secrets/.gitkeep +0 -0
  338. package/lib/bmad-extension/skills/sre-check-secrets/SKILL.md +23 -0
  339. package/lib/bmad-extension/skills/sre-check-secrets/bmad-skill-manifest.yaml +3 -0
  340. package/lib/bmad-extension/skills/sre-check-system-status/.gitkeep +0 -0
  341. package/lib/bmad-extension/skills/sre-check-system-status/SKILL.md +27 -0
  342. package/lib/bmad-extension/skills/sre-check-system-status/bmad-skill-manifest.yaml +3 -0
  343. package/lib/bmad-extension/skills/sre-day-2-ops/.gitkeep +0 -0
  344. package/lib/bmad-extension/skills/sre-day-2-ops/SKILL.md +26 -0
  345. package/lib/bmad-extension/skills/sre-day-2-ops/bmad-skill-manifest.yaml +3 -0
  346. package/lib/bmad-extension/skills/sre-deployment-strategies/.gitkeep +0 -0
  347. package/lib/bmad-extension/skills/sre-deployment-strategies/SKILL.md +28 -0
  348. package/lib/bmad-extension/skills/sre-deployment-strategies/bmad-skill-manifest.yaml +3 -0
  349. package/lib/bmad-extension/skills/sre-fix-deployments/.gitkeep +0 -0
  350. package/lib/bmad-extension/skills/sre-fix-deployments/SKILL.md +25 -0
  351. package/lib/bmad-extension/skills/sre-fix-deployments/bmad-skill-manifest.yaml +3 -0
  352. package/lib/bmad-extension/skills/sre-gitops-status/.gitkeep +0 -0
  353. package/lib/bmad-extension/skills/sre-gitops-status/SKILL.md +25 -0
  354. package/lib/bmad-extension/skills/sre-gitops-status/bmad-skill-manifest.yaml +3 -0
  355. package/lib/bmad.js +541 -1
  356. package/lib/installer.js +12 -8
  357. package/opencode.json +1 -4
  358. package/package.json +3 -3
  359. package/test/bmad-extension.test.js +115 -69
  360. package/test/bmad-version-bump.test.js +313 -0
  361. package/test/convert-agents-to-skills.test.js +245 -0
  362. package/test/extension-module-restructure.test.js +359 -0
  363. package/test/integration-verification.test.js +71 -40
  364. package/test/migration-validation.test.js +499 -0
  365. package/test/migration.test.js +832 -0
  366. package/test/opencode-json-injection.test.js +25 -17
  367. package/test/opencode-json-merge.test.js +52 -33
  368. package/test/story-15-5-workflow-skills.test.js +311 -0
  369. package/test/yes-flag.test.js +8 -1
  370. package/lib/bmad-cache/bmb/_git_preserved/objects/pack/pack-c6e539e2308f8ed764c5b54b6ab68a67f8a3796b.idx +0 -0
  371. package/lib/bmad-cache/bmb/_git_preserved/objects/pack/pack-c6e539e2308f8ed764c5b54b6ab68a67f8a3796b.pack +0 -0
  372. package/lib/bmad-cache/bmb/_git_preserved/objects/pack/pack-c6e539e2308f8ed764c5b54b6ab68a67f8a3796b.rev +0 -0
  373. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/bmad-manifest.json +0 -62
  374. package/lib/bmad-cache/bmb/samples/bmad-excalidraw/bmad-manifest.json +0 -18
  375. package/lib/bmad-cache/bmb/src/module-help.csv +0 -7
  376. package/lib/bmad-cache/bmb/src/module.yaml +0 -20
  377. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/bmad-manifest.json +0 -24
  378. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/bmad-manifest-schema.json +0 -103
  379. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/generate-html-report.py +0 -1002
  380. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/manifest.py +0 -420
  381. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/bmad-manifest.json +0 -23
  382. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/bmad-manifest-schema.json +0 -103
  383. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/generate-html-report.py +0 -1002
  384. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/manifest.py +0 -420
  385. package/lib/bmad-cache/cis/_git_preserved/objects/pack/pack-157d7eb8d527233a8607d926fc74ebf87f2ae0d3.idx +0 -0
  386. package/lib/bmad-cache/cis/_git_preserved/objects/pack/pack-157d7eb8d527233a8607d926fc74ebf87f2ae0d3.rev +0 -0
  387. package/lib/bmad-cache/cis/src/agents/brainstorming-coach.agent.yaml +0 -21
  388. package/lib/bmad-cache/cis/src/agents/creative-problem-solver.agent.yaml +0 -21
  389. package/lib/bmad-cache/cis/src/agents/design-thinking-coach.agent.yaml +0 -21
  390. package/lib/bmad-cache/cis/src/agents/innovation-strategist.agent.yaml +0 -21
  391. package/lib/bmad-cache/cis/src/agents/presentation-master.agent.yaml +0 -53
  392. package/lib/bmad-cache/cis/src/agents/storyteller/storyteller.agent.yaml +0 -25
  393. package/lib/bmad-cache/cis/src/teams/creative-squad.yaml +0 -7
  394. package/lib/bmad-cache/cis/src/teams/default-party.csv +0 -12
  395. package/lib/bmad-cache/cis/src/workflows/README.md +0 -175
  396. package/lib/bmad-cache/gds/_git_preserved/objects/pack/pack-44faafb9245b4ca17ad81bd6c9e6fc52fb5915a1.idx +0 -0
  397. package/lib/bmad-cache/gds/_git_preserved/objects/pack/pack-44faafb9245b4ca17ad81bd6c9e6fc52fb5915a1.rev +0 -0
  398. package/lib/bmad-cache/gds/_git_preserved/refs/tags/v0.2.2 +0 -1
  399. package/lib/bmad-cache/tea/_git_preserved/objects/pack/pack-96ec1ce3a9ef4c891e00e060795b4434ba8f7163.idx +0 -0
  400. package/lib/bmad-cache/tea/_git_preserved/objects/pack/pack-96ec1ce3a9ef4c891e00e060795b4434ba8f7163.rev +0 -0
  401. package/lib/bmad-cache/tea/_git_preserved/refs/tags/v1.7.0 +0 -1
  402. package/lib/bmad-cache/tea/docs/MIGRATION.md +0 -488
  403. package/lib/bmad-cache/tea/src/agents/tea.agent.yaml +0 -67
  404. package/lib/bmad-cache/tea/src/teams/default-party.csv +0 -2
  405. package/lib/bmad-customizations/bmm-cyber.customize.yaml +0 -24
  406. package/lib/bmad-customizations/bmm-devops.customize.yaml +0 -24
  407. package/lib/bmad-customizations/bmm-mil498.customize.yaml +0 -36
  408. package/lib/bmad-customizations/bmm-sre.customize.yaml +0 -24
  409. package/lib/bmad-customizations/cyber.md +0 -71
  410. package/lib/bmad-customizations/devops.md +0 -71
  411. package/lib/bmad-customizations/mil498.md +0 -75
  412. package/lib/bmad-customizations/sre.md +0 -71
  413. package/lib/bmad-extension/agents/bmm-architect.customize.yaml +0 -5
  414. package/lib/bmad-extension/agents/bmm-bmad-master.customize.yaml +0 -5
  415. package/lib/bmad-extension/agents/bmm-cyber.customize.yaml +0 -30
  416. package/lib/bmad-extension/agents/bmm-dev.customize.yaml +0 -5
  417. package/lib/bmad-extension/agents/bmm-devops.customize.yaml +0 -30
  418. package/lib/bmad-extension/agents/bmm-mil498.customize.yaml +0 -42
  419. package/lib/bmad-extension/agents/bmm-pm.customize.yaml +0 -5
  420. package/lib/bmad-extension/agents/bmm-qa.customize.yaml +0 -5
  421. package/lib/bmad-extension/agents/bmm-sm.customize.yaml +0 -5
  422. package/lib/bmad-extension/agents/bmm-sre.customize.yaml +0 -30
  423. package/lib/bmad-extension/agents/bmm-tech-writer.customize.yaml +0 -5
  424. package/lib/bmad-extension/agents/bmm-ux-designer.customize.yaml +0 -5
  425. /package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-agent-builder/scripts/scan-scripts.py +0 -0
  426. /package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-workflow-builder/scripts/prepass-prompt-metrics.py +0 -0
  427. /package/lib/bmad-cache/bmb/{src/skills → skills}/bmad-workflow-builder/scripts/scan-scripts.py +0 -0
  428. /package/lib/bmad-cache/{bmb/src/skills/bmad-agent-builder → cis/src/skills/bmad-cis-design-thinking}/bmad-skill-manifest.yaml +0 -0
  429. /package/lib/bmad-cache/cis/src/{workflows → skills}/bmad-cis-design-thinking/design-methods.csv +0 -0
  430. /package/lib/bmad-cache/{bmb/src/skills/bmad-workflow-builder → cis/src/skills/bmad-cis-innovation-strategy}/bmad-skill-manifest.yaml +0 -0
  431. /package/lib/bmad-cache/cis/src/{workflows → skills}/bmad-cis-innovation-strategy/innovation-frameworks.csv +0 -0
  432. /package/lib/bmad-cache/cis/src/{workflows/bmad-cis-design-thinking → skills/bmad-cis-problem-solving}/bmad-skill-manifest.yaml +0 -0
  433. /package/lib/bmad-cache/cis/src/{workflows → skills}/bmad-cis-problem-solving/solving-methods.csv +0 -0
  434. /package/lib/bmad-cache/cis/src/{workflows/bmad-cis-innovation-strategy → skills/bmad-cis-storytelling}/bmad-skill-manifest.yaml +0 -0
  435. /package/lib/bmad-cache/cis/src/{workflows → skills}/bmad-cis-storytelling/story-types.csv +0 -0
  436. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/adr-quality-readiness-checklist.md +0 -0
  437. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/api-request.md +0 -0
  438. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/api-testing-patterns.md +0 -0
  439. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/auth-session.md +0 -0
  440. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/burn-in.md +0 -0
  441. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/ci-burn-in.md +0 -0
  442. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/component-tdd.md +0 -0
  443. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/contract-testing.md +0 -0
  444. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/data-factories.md +0 -0
  445. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/email-auth.md +0 -0
  446. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/error-handling.md +0 -0
  447. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/feature-flags.md +0 -0
  448. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/file-utils.md +0 -0
  449. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/fixture-architecture.md +0 -0
  450. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/fixtures-composition.md +0 -0
  451. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/intercept-network-call.md +0 -0
  452. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/log.md +0 -0
  453. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/network-error-monitor.md +0 -0
  454. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/network-first.md +0 -0
  455. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/network-recorder.md +0 -0
  456. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/nfr-criteria.md +0 -0
  457. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/overview.md +0 -0
  458. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/pact-consumer-di.md +0 -0
  459. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/pact-consumer-framework-setup.md +0 -0
  460. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/pact-mcp.md +0 -0
  461. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/pactjs-utils-consumer-helpers.md +0 -0
  462. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/pactjs-utils-overview.md +0 -0
  463. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/pactjs-utils-provider-verifier.md +0 -0
  464. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/pactjs-utils-request-filter.md +0 -0
  465. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/playwright-cli.md +0 -0
  466. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/playwright-config.md +0 -0
  467. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/probability-impact.md +0 -0
  468. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/recurse.md +0 -0
  469. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/risk-governance.md +0 -0
  470. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/selective-testing.md +0 -0
  471. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/selector-resilience.md +0 -0
  472. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/test-healing-patterns.md +0 -0
  473. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/test-levels-framework.md +0 -0
  474. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/test-priorities-matrix.md +0 -0
  475. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/test-quality.md +0 -0
  476. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/timing-debugging.md +0 -0
  477. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/knowledge/visual-debugging.md +0 -0
  478. /package/lib/bmad-cache/tea/src/{testarch → agents/bmad-tea/resources}/tea-index.csv +0 -0
  479. /package/lib/bmad-cache/{cis/src/workflows/bmad-cis-problem-solving → wds/src/workflows/wds-0-alignment-signoff}/bmad-skill-manifest.yaml +0 -0
  480. /package/lib/bmad-cache/{cis/src/workflows/bmad-cis-storytelling → wds/src/workflows/wds-0-project-setup}/bmad-skill-manifest.yaml +0 -0
@@ -0,0 +1,534 @@
1
+ # /// script
2
+ # requires-python = ">=3.9"
3
+ # ///
4
+
5
+ #!/usr/bin/env python3
6
+ """
7
+ Generate an interactive HTML quality analysis report for a BMad agent.
8
+
9
+ Reads report-data.json produced by the report creator and renders a
10
+ self-contained HTML report with:
11
+ - BMad Method branding
12
+ - Agent portrait (icon, name, title, personality description)
13
+ - Capability dashboard with expandable per-capability findings
14
+ - Opportunity themes with "Fix This Theme" prompt generation
15
+ - Expandable strengths and detailed analysis
16
+
17
+ Usage:
18
+ python3 generate-html-report.py {quality-report-dir} [--open]
19
+ """
20
+
21
+ from __future__ import annotations
22
+
23
+ import argparse
24
+ import json
25
+ import platform
26
+ import subprocess
27
+ import sys
28
+ from pathlib import Path
29
+
30
+
31
+ def load_report_data(report_dir: Path) -> dict:
32
+ """Load report-data.json from the report directory."""
33
+ data_file = report_dir / 'report-data.json'
34
+ if not data_file.exists():
35
+ print(f'Error: {data_file} not found', file=sys.stderr)
36
+ sys.exit(2)
37
+ return json.loads(data_file.read_text(encoding='utf-8'))
38
+
39
+
40
+ HTML_TEMPLATE = r"""<!DOCTYPE html>
41
+ <html lang="en">
42
+ <head>
43
+ <meta charset="utf-8">
44
+ <meta name="viewport" content="width=device-width, initial-scale=1">
45
+ <title>BMad Method · Quality Analysis: SKILL_NAME</title>
46
+ <style>
47
+ :root {
48
+ --bg: #0d1117; --surface: #161b22; --surface2: #21262d; --border: #30363d;
49
+ --text: #e6edf3; --text-muted: #8b949e; --text-dim: #6e7681;
50
+ --critical: #f85149; --high: #f0883e; --medium: #d29922; --low: #58a6ff;
51
+ --strength: #3fb950; --suggestion: #a371f7;
52
+ --accent: #58a6ff; --accent-hover: #79c0ff;
53
+ --brand: #a371f7;
54
+ --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
55
+ --mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
56
+ }
57
+ @media (prefers-color-scheme: light) {
58
+ :root {
59
+ --bg: #ffffff; --surface: #f6f8fa; --surface2: #eaeef2; --border: #d0d7de;
60
+ --text: #1f2328; --text-muted: #656d76; --text-dim: #8c959f;
61
+ --critical: #cf222e; --high: #bc4c00; --medium: #9a6700; --low: #0969da;
62
+ --strength: #1a7f37; --suggestion: #8250df;
63
+ --accent: #0969da; --accent-hover: #0550ae;
64
+ --brand: #8250df;
65
+ }
66
+ }
67
+ * { margin: 0; padding: 0; box-sizing: border-box; }
68
+ body { font-family: var(--font); background: var(--bg); color: var(--text); line-height: 1.5; padding: 2rem; max-width: 900px; margin: 0 auto; }
69
+ .brand { color: var(--brand); font-size: 0.8rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 0.25rem; }
70
+ h1 { font-size: 1.5rem; margin-bottom: 0.25rem; }
71
+ .subtitle { color: var(--text-muted); font-size: 0.85rem; margin-bottom: 1.5rem; }
72
+ .subtitle a { color: var(--accent); text-decoration: none; }
73
+ .subtitle a:hover { text-decoration: underline; }
74
+ .portrait { background: var(--surface); border: 1px solid var(--border); border-radius: 0.5rem; padding: 1.25rem; margin-bottom: 1.5rem; }
75
+ .portrait-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.5rem; }
76
+ .portrait-icon { font-size: 2rem; }
77
+ .portrait-name { font-size: 1.25rem; font-weight: 700; }
78
+ .portrait-title { font-size: 0.9rem; color: var(--text-muted); }
79
+ .portrait-desc { font-size: 0.95rem; color: var(--text-muted); line-height: 1.6; font-style: italic; }
80
+ .grade { font-size: 2.5rem; font-weight: 700; margin: 0.5rem 0; }
81
+ .grade-Excellent { color: var(--strength); }
82
+ .grade-Good { color: var(--low); }
83
+ .grade-Fair { color: var(--medium); }
84
+ .grade-Poor { color: var(--critical); }
85
+ .narrative { color: var(--text-muted); font-size: 0.95rem; margin-bottom: 1.5rem; line-height: 1.6; }
86
+ .badge { display: inline-flex; align-items: center; padding: 0.15rem 0.5rem; border-radius: 2rem; font-size: 0.75rem; font-weight: 600; }
87
+ .badge-critical { background: color-mix(in srgb, var(--critical) 20%, transparent); color: var(--critical); }
88
+ .badge-high { background: color-mix(in srgb, var(--high) 20%, transparent); color: var(--high); }
89
+ .badge-medium { background: color-mix(in srgb, var(--medium) 20%, transparent); color: var(--medium); }
90
+ .badge-low { background: color-mix(in srgb, var(--low) 20%, transparent); color: var(--low); }
91
+ .badge-strength { background: color-mix(in srgb, var(--strength) 20%, transparent); color: var(--strength); }
92
+ .badge-good { background: color-mix(in srgb, var(--strength) 15%, transparent); color: var(--strength); }
93
+ .badge-attention { background: color-mix(in srgb, var(--medium) 15%, transparent); color: var(--medium); }
94
+ .section { border: 1px solid var(--border); border-radius: 0.5rem; margin: 0.75rem 0; overflow: hidden; }
95
+ .section-header { display: flex; align-items: center; gap: 0.75rem; padding: 0.75rem 1rem; background: var(--surface); cursor: pointer; user-select: none; }
96
+ .section-header:hover { background: var(--surface2); }
97
+ .section-header .arrow { font-size: 0.7rem; transition: transform 0.15s; color: var(--text-muted); width: 1rem; }
98
+ .section-header.open .arrow { transform: rotate(90deg); }
99
+ .section-header .label { font-weight: 600; flex: 1; }
100
+ .section-header .actions { display: flex; gap: 0.5rem; }
101
+ .section-body { display: none; }
102
+ .section-body.open { display: block; }
103
+ .cap-row { display: flex; align-items: center; gap: 0.75rem; padding: 0.6rem 1rem; border-top: 1px solid var(--border); }
104
+ .cap-row:hover { background: var(--surface); }
105
+ .cap-name { font-weight: 600; font-size: 0.9rem; flex: 1; }
106
+ .cap-file { font-family: var(--mono); font-size: 0.75rem; color: var(--text-dim); }
107
+ .cap-findings { display: none; padding: 0.5rem 1rem 0.5rem 2rem; border-top: 1px solid var(--border); background: var(--bg); }
108
+ .cap-findings.open { display: block; }
109
+ .cap-finding { font-size: 0.85rem; padding: 0.25rem 0; color: var(--text-muted); }
110
+ .item { padding: 0.75rem 1rem; border-top: 1px solid var(--border); }
111
+ .item:hover { background: var(--surface); }
112
+ .item-title { font-weight: 600; font-size: 0.9rem; }
113
+ .item-file { font-family: var(--mono); font-size: 0.75rem; color: var(--text-muted); }
114
+ .item-desc { font-size: 0.85rem; color: var(--text-muted); margin-top: 0.25rem; }
115
+ .item-action { font-size: 0.85rem; margin-top: 0.25rem; }
116
+ .item-action strong { color: var(--strength); }
117
+ .opp { padding: 1rem; border-top: 1px solid var(--border); }
118
+ .opp-header { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
119
+ .opp-name { font-weight: 600; font-size: 1rem; flex: 1; }
120
+ .opp-count { font-size: 0.8rem; color: var(--text-muted); }
121
+ .opp-desc { font-size: 0.9rem; color: var(--text-muted); margin: 0.5rem 0; }
122
+ .opp-impact { font-size: 0.85rem; color: var(--text-dim); font-style: italic; }
123
+ .opp-findings { margin-top: 0.75rem; padding-left: 1rem; border-left: 2px solid var(--border); display: none; }
124
+ .opp-findings.open { display: block; }
125
+ .opp-finding { font-size: 0.85rem; padding: 0.25rem 0; color: var(--text-muted); }
126
+ .opp-finding .source { font-size: 0.75rem; color: var(--text-dim); }
127
+ .btn { background: none; border: 1px solid var(--border); border-radius: 0.25rem; padding: 0.3rem 0.7rem; cursor: pointer; color: var(--text-muted); font-size: 0.8rem; transition: all 0.15s; }
128
+ .btn:hover { border-color: var(--accent); color: var(--accent); }
129
+ .btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); font-weight: 600; }
130
+ .btn-primary:hover { background: var(--accent-hover); }
131
+ .strength-item { padding: 0.5rem 1rem; border-top: 1px solid var(--border); }
132
+ .strength-item .title { font-weight: 600; font-size: 0.9rem; color: var(--strength); }
133
+ .strength-item .detail { font-size: 0.85rem; color: var(--text-muted); }
134
+ .analysis-section { padding: 0.75rem 1rem; border-top: 1px solid var(--border); }
135
+ .analysis-section h4 { font-size: 0.9rem; margin-bottom: 0.25rem; }
136
+ .analysis-section p { font-size: 0.85rem; color: var(--text-muted); }
137
+ .analysis-finding { font-size: 0.85rem; padding: 0.25rem 0 0.25rem 1rem; border-left: 2px solid var(--border); margin: 0.25rem 0; color: var(--text-muted); }
138
+ .recs { padding: 0.75rem 1rem; border-top: 1px solid var(--border); }
139
+ .rec { padding: 0.3rem 0; font-size: 0.9rem; }
140
+ .rec-rank { font-weight: 700; color: var(--accent); margin-right: 0.5rem; }
141
+ .rec-resolves { font-size: 0.8rem; color: var(--text-dim); }
142
+ .modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 200; align-items: center; justify-content: center; }
143
+ .modal-overlay.visible { display: flex; }
144
+ .modal { background: var(--surface); border: 1px solid var(--border); border-radius: 0.5rem; padding: 1.5rem; width: 90%; max-width: 700px; max-height: 80vh; overflow-y: auto; }
145
+ .modal h3 { margin-bottom: 0.75rem; }
146
+ .modal pre { background: var(--bg); border: 1px solid var(--border); border-radius: 0.375rem; padding: 1rem; font-family: var(--mono); font-size: 0.8rem; white-space: pre-wrap; word-wrap: break-word; max-height: 50vh; overflow-y: auto; }
147
+ .modal-actions { display: flex; gap: 0.75rem; margin-top: 1rem; justify-content: flex-end; }
148
+ </style>
149
+ </head>
150
+ <body>
151
+
152
+ <div class="brand">BMad Method</div>
153
+ <h1>Quality Analysis: <span id="skill-name"></span></h1>
154
+ <div class="subtitle" id="subtitle"></div>
155
+
156
+ <div id="portrait"></div>
157
+ <div id="grade-area"></div>
158
+ <div class="narrative" id="narrative"></div>
159
+
160
+ <div id="capabilities-section"></div>
161
+ <div id="broken-section"></div>
162
+ <div id="opportunities-section"></div>
163
+ <div id="strengths-section"></div>
164
+ <div id="recommendations-section"></div>
165
+ <div id="detailed-section"></div>
166
+
167
+ <div class="modal-overlay" id="modal" onclick="if(event.target===this)closeModal()">
168
+ <div class="modal">
169
+ <h3 id="modal-title">Generated Prompt</h3>
170
+ <pre id="modal-content"></pre>
171
+ <div class="modal-actions">
172
+ <button class="btn" onclick="closeModal()">Close</button>
173
+ <button class="btn btn-primary" onclick="copyModal()">Copy to Clipboard</button>
174
+ </div>
175
+ </div>
176
+ </div>
177
+
178
+ <script>
179
+ const RAW = JSON.parse(document.getElementById('report-data').textContent);
180
+ const DATA = normalize(RAW);
181
+
182
+ function normalize(d) {
183
+ if (d.meta) {
184
+ d.meta.skill_name = d.meta.skill_name || d.meta.skill || d.meta.name || 'Unknown';
185
+ d.meta.scanner_count = typeof d.meta.scanner_count === 'number' ? d.meta.scanner_count
186
+ : Array.isArray(d.meta.scanners_run) ? d.meta.scanners_run.length
187
+ : d.meta.scanner_count || 0;
188
+ }
189
+ d.strengths = (d.strengths || []).map(s =>
190
+ typeof s === 'string' ? { title: s, detail: '' } : { title: s.title || '', detail: s.detail || '' }
191
+ );
192
+ (d.opportunities || []).forEach(o => {
193
+ o.name = o.name || o.title || '';
194
+ o.finding_count = o.finding_count || (o.findings || o.findings_resolved || []).length;
195
+ if (!o.findings && o.findings_resolved) o.findings = [];
196
+ o.action = o.action || o.fix || '';
197
+ });
198
+ (d.broken || []).forEach(b => {
199
+ b.detail = b.detail || b.description || '';
200
+ b.action = b.action || b.fix || '';
201
+ });
202
+ (d.recommendations || []).forEach((r, i) => {
203
+ r.action = r.action || r.description || '';
204
+ r.rank = r.rank || i + 1;
205
+ });
206
+ // Fix journeys
207
+ if (d.detailed_analysis && d.detailed_analysis.experience) {
208
+ d.detailed_analysis.experience.journeys = (d.detailed_analysis.experience.journeys || []).map(j => ({
209
+ archetype: j.archetype || j.persona || j.name || 'Unknown',
210
+ summary: j.summary || j.journey_summary || j.description || j.friction || '',
211
+ friction_points: j.friction_points || (j.friction ? [j.friction] : []),
212
+ bright_spots: j.bright_spots || (j.bright ? [j.bright] : [])
213
+ }));
214
+ }
215
+ // Fix capabilities
216
+ (d.capabilities || []).forEach(c => {
217
+ c.finding_count = c.finding_count || (c.findings || []).length;
218
+ c.status = c.status || (c.finding_count > 0 ? 'needs-attention' : 'good');
219
+ });
220
+ return d;
221
+ }
222
+
223
+ function esc(s) {
224
+ if (!s) return '';
225
+ const d = document.createElement('div');
226
+ d.textContent = String(s);
227
+ return d.innerHTML;
228
+ }
229
+
230
+ function init() {
231
+ const m = DATA.meta;
232
+ document.getElementById('skill-name').textContent = m.skill_name;
233
+ document.getElementById('subtitle').innerHTML =
234
+ `${esc(m.skill_path)} &bull; ${m.timestamp ? m.timestamp.split('T')[0] : ''} &bull; ${m.scanner_count || 0} scanners &bull; <a href="quality-report.md">Full Report &nearr;</a>`;
235
+
236
+ renderPortrait();
237
+ document.getElementById('grade-area').innerHTML = `<div class="grade grade-${DATA.grade}">${esc(DATA.grade)}</div>`;
238
+ document.getElementById('narrative').textContent = DATA.narrative || '';
239
+
240
+ renderCapabilities();
241
+ renderBroken();
242
+ renderOpportunities();
243
+ renderStrengths();
244
+ renderRecommendations();
245
+ renderDetailed();
246
+ }
247
+
248
+ function renderPortrait() {
249
+ const p = DATA.agent_profile;
250
+ if (!p) return;
251
+ let html = `<div class="portrait"><div class="portrait-header">`;
252
+ if (p.icon) html += `<span class="portrait-icon">${esc(p.icon)}</span>`;
253
+ html += `<div><div class="portrait-name">${esc(p.display_name)}</div>`;
254
+ if (p.title) html += `<div class="portrait-title">${esc(p.title)}</div>`;
255
+ html += `</div></div>`;
256
+ if (p.portrait) html += `<div class="portrait-desc">${esc(p.portrait)}</div>`;
257
+ html += `</div>`;
258
+ document.getElementById('portrait').innerHTML = html;
259
+ }
260
+
261
+ function renderCapabilities() {
262
+ const caps = DATA.capabilities || [];
263
+ if (!caps.length) return;
264
+ const good = caps.filter(c => c.status === 'good').length;
265
+ const attn = caps.length - good;
266
+ let summary = `${caps.length} capabilities`;
267
+ if (attn > 0) summary += ` \u00b7 ${attn} need attention`;
268
+
269
+ let html = `<div class="section"><div class="section-header open" onclick="toggleSection(this)">`;
270
+ html += `<span class="arrow">&#9654;</span><span class="label">Capabilities (${summary})</span>`;
271
+ html += `</div><div class="section-body open">`;
272
+ caps.forEach((cap, idx) => {
273
+ const statusBadge = cap.status === 'good'
274
+ ? `<span class="badge badge-good">Good</span>`
275
+ : `<span class="badge badge-attention">${cap.finding_count} observation${cap.finding_count !== 1 ? 's' : ''}</span>`;
276
+ const hasFindings = cap.findings && cap.findings.length > 0;
277
+ html += `<div class="cap-row" ${hasFindings ? `onclick="toggleCapFindings(${idx})" style="cursor:pointer"` : ''}>`;
278
+ html += `${statusBadge} <span class="cap-name">${esc(cap.name)}</span>`;
279
+ if (cap.file) html += `<span class="cap-file">${esc(cap.file)}</span>`;
280
+ html += `</div>`;
281
+ if (hasFindings) {
282
+ html += `<div class="cap-findings" id="cap-findings-${idx}">`;
283
+ cap.findings.forEach(f => {
284
+ html += `<div class="cap-finding">`;
285
+ if (f.severity) html += `<span class="badge badge-${f.severity}">${esc(f.severity)}</span> `;
286
+ html += `${esc(f.title)}`;
287
+ if (f.source) html += ` <span class="source" style="font-size:0.75rem;color:var(--text-dim)">[${esc(f.source)}]</span>`;
288
+ html += `</div>`;
289
+ });
290
+ html += `</div>`;
291
+ }
292
+ });
293
+ html += `</div></div>`;
294
+ document.getElementById('capabilities-section').innerHTML = html;
295
+ }
296
+
297
+ function renderBroken() {
298
+ const items = DATA.broken || [];
299
+ if (!items.length) return;
300
+ let html = `<div class="section"><div class="section-header open" onclick="toggleSection(this)">`;
301
+ html += `<span class="arrow">&#9654;</span><span class="label">Broken / Critical (${items.length})</span>`;
302
+ html += `<div class="actions"><button class="btn btn-primary" onclick="event.stopPropagation();showBrokenPrompt()">Fix These</button></div>`;
303
+ html += `</div><div class="section-body open">`;
304
+ items.forEach(item => {
305
+ const loc = item.file ? `${item.file}${item.line ? ':'+item.line : ''}` : '';
306
+ html += `<div class="item"><span class="badge badge-${item.severity || 'high'}">${esc(item.severity || 'high')}</span> `;
307
+ if (loc) html += `<span class="item-file">${esc(loc)}</span>`;
308
+ html += `<div class="item-title">${esc(item.title)}</div>`;
309
+ if (item.detail) html += `<div class="item-desc">${esc(item.detail)}</div>`;
310
+ if (item.action) html += `<div class="item-action"><strong>Fix:</strong> ${esc(item.action)}</div>`;
311
+ html += `</div>`;
312
+ });
313
+ html += `</div></div>`;
314
+ document.getElementById('broken-section').innerHTML = html;
315
+ }
316
+
317
+ function renderOpportunities() {
318
+ const opps = DATA.opportunities || [];
319
+ if (!opps.length) return;
320
+ let html = `<div class="section"><div class="section-header open" onclick="toggleSection(this)">`;
321
+ html += `<span class="arrow">&#9654;</span><span class="label">Opportunities (${opps.length})</span>`;
322
+ html += `</div><div class="section-body open">`;
323
+ opps.forEach((opp, idx) => {
324
+ html += `<div class="opp"><div class="opp-header">`;
325
+ html += `<span class="badge badge-${opp.severity || 'medium'}">${esc(opp.severity || 'medium')}</span>`;
326
+ html += `<span class="opp-name">${idx+1}. ${esc(opp.name)}</span>`;
327
+ html += `<span class="opp-count">${opp.finding_count || (opp.findings||[]).length} observations</span>`;
328
+ html += `<button class="btn" onclick="toggleFindings(${idx})">Details</button>`;
329
+ html += `<button class="btn btn-primary" onclick="showThemePrompt(${idx})">Fix This</button>`;
330
+ html += `</div>`;
331
+ html += `<div class="opp-desc">${esc(opp.description)}</div>`;
332
+ if (opp.impact) html += `<div class="opp-impact">Impact: ${esc(opp.impact)}</div>`;
333
+ html += `<div class="opp-findings" id="findings-${idx}">`;
334
+ (opp.findings || []).forEach(f => {
335
+ const loc = f.file ? `${f.file}${f.line ? ':'+f.line : ''}` : '';
336
+ html += `<div class="opp-finding"><strong>${esc(f.title)}</strong>`;
337
+ if (loc) html += ` <span class="item-file">${esc(loc)}</span>`;
338
+ if (f.source) html += ` <span class="source">[${esc(f.source)}]</span>`;
339
+ if (f.detail) html += `<br>${esc(f.detail)}`;
340
+ html += `</div>`;
341
+ });
342
+ html += `</div></div>`;
343
+ });
344
+ html += `</div></div>`;
345
+ document.getElementById('opportunities-section').innerHTML = html;
346
+ }
347
+
348
+ function renderStrengths() {
349
+ const items = DATA.strengths || [];
350
+ if (!items.length) return;
351
+ let html = `<div class="section"><div class="section-header" onclick="toggleSection(this)">`;
352
+ html += `<span class="arrow">&#9654;</span><span class="label">Strengths (${items.length})</span>`;
353
+ html += `</div><div class="section-body">`;
354
+ items.forEach(s => {
355
+ html += `<div class="strength-item"><div class="title">${esc(s.title)}</div>`;
356
+ if (s.detail) html += `<div class="detail">${esc(s.detail)}</div>`;
357
+ html += `</div>`;
358
+ });
359
+ html += `</div></div>`;
360
+ document.getElementById('strengths-section').innerHTML = html;
361
+ }
362
+
363
+ function renderRecommendations() {
364
+ const recs = DATA.recommendations || [];
365
+ if (!recs.length) return;
366
+ let html = `<div class="section"><div class="section-header open" onclick="toggleSection(this)">`;
367
+ html += `<span class="arrow">&#9654;</span><span class="label">Recommendations</span>`;
368
+ html += `</div><div class="section-body open"><div class="recs">`;
369
+ recs.forEach(r => {
370
+ html += `<div class="rec"><span class="rec-rank">#${r.rank}</span>${esc(r.action)}`;
371
+ if (r.resolves) html += ` <span class="rec-resolves">(resolves ${r.resolves} observations)</span>`;
372
+ html += `</div>`;
373
+ });
374
+ html += `</div></div></div>`;
375
+ document.getElementById('recommendations-section').innerHTML = html;
376
+ }
377
+
378
+ function renderDetailed() {
379
+ const da = DATA.detailed_analysis;
380
+ if (!da) return;
381
+ const dims = [
382
+ ['structure', 'Structure & Capabilities'],
383
+ ['persona', 'Persona & Voice'],
384
+ ['cohesion', 'Identity Cohesion'],
385
+ ['efficiency', 'Execution Efficiency'],
386
+ ['experience', 'Conversation Experience'],
387
+ ['scripts', 'Script Opportunities']
388
+ ];
389
+ let html = `<div class="section"><div class="section-header" onclick="toggleSection(this)">`;
390
+ html += `<span class="arrow">&#9654;</span><span class="label">Detailed Analysis</span>`;
391
+ html += `</div><div class="section-body">`;
392
+ dims.forEach(([key, label]) => {
393
+ const dim = da[key];
394
+ if (!dim) return;
395
+ html += `<div class="analysis-section"><h4>${label}</h4>`;
396
+ if (dim.assessment) html += `<p>${esc(dim.assessment)}</p>`;
397
+ if (dim.dimensions) {
398
+ html += `<table style="width:100%;font-size:0.85rem;margin:0.5rem 0;border-collapse:collapse;">`;
399
+ html += `<tr><th style="text-align:left;padding:0.3rem;border-bottom:1px solid var(--border)">Dimension</th><th style="text-align:left;padding:0.3rem;border-bottom:1px solid var(--border)">Score</th><th style="text-align:left;padding:0.3rem;border-bottom:1px solid var(--border)">Notes</th></tr>`;
400
+ Object.entries(dim.dimensions).forEach(([d, v]) => {
401
+ if (v && typeof v === 'object') {
402
+ html += `<tr><td style="padding:0.3rem;border-bottom:1px solid var(--border)">${esc(d.replace(/_/g,' '))}</td><td style="padding:0.3rem;border-bottom:1px solid var(--border)">${esc(v.score||'')}</td><td style="padding:0.3rem;border-bottom:1px solid var(--border)">${esc(v.notes||'')}</td></tr>`;
403
+ }
404
+ });
405
+ html += `</table>`;
406
+ }
407
+ if (dim.journeys && dim.journeys.length) {
408
+ dim.journeys.forEach(j => {
409
+ html += `<div style="margin:0.5rem 0"><strong>${esc(j.archetype)}</strong>: ${esc(j.summary || j.journey_summary || '')}`;
410
+ if (j.friction_points && j.friction_points.length) {
411
+ html += `<ul style="color:var(--high);font-size:0.85rem;padding-left:1.25rem">`;
412
+ j.friction_points.forEach(fp => { html += `<li>${esc(fp)}</li>`; });
413
+ html += `</ul>`;
414
+ }
415
+ html += `</div>`;
416
+ });
417
+ }
418
+ if (dim.autonomous) {
419
+ const a = dim.autonomous;
420
+ html += `<p><strong>Headless Potential:</strong> ${esc(a.potential||'')}`;
421
+ if (a.notes) html += ` \u2014 ${esc(a.notes)}`;
422
+ html += `</p>`;
423
+ }
424
+ (dim.findings || []).forEach(f => {
425
+ const loc = f.file ? `${f.file}${f.line ? ':'+f.line : ''}` : '';
426
+ html += `<div class="analysis-finding">`;
427
+ if (f.severity) html += `<span class="badge badge-${f.severity}">${esc(f.severity)}</span> `;
428
+ html += `${esc(f.title)}`;
429
+ if (loc) html += ` <span class="item-file">${esc(loc)}</span>`;
430
+ html += `</div>`;
431
+ });
432
+ html += `</div>`;
433
+ });
434
+ html += `</div></div>`;
435
+ document.getElementById('detailed-section').innerHTML = html;
436
+ }
437
+
438
+ function toggleSection(el) { el.classList.toggle('open'); el.nextElementSibling.classList.toggle('open'); }
439
+ function toggleFindings(idx) { document.getElementById('findings-'+idx).classList.toggle('open'); }
440
+ function toggleCapFindings(idx) { document.getElementById('cap-findings-'+idx).classList.toggle('open'); }
441
+
442
+ function showThemePrompt(idx) {
443
+ const opp = DATA.opportunities[idx];
444
+ if (!opp) return;
445
+ let prompt = `## Task: ${opp.name}\nAgent path: ${DATA.meta.skill_path}\n\n### Problem\n${opp.description}\n\n### Fix\n${opp.action}\n\n`;
446
+ if (opp.findings && opp.findings.length) {
447
+ prompt += `### Specific observations to address:\n\n`;
448
+ opp.findings.forEach((f, i) => {
449
+ const loc = f.file ? (f.line ? `${f.file}:${f.line}` : f.file) : '';
450
+ prompt += `${i+1}. **${f.title}**`;
451
+ if (loc) prompt += ` (${loc})`;
452
+ if (f.detail) prompt += `\n ${f.detail}`;
453
+ prompt += `\n`;
454
+ });
455
+ }
456
+ document.getElementById('modal-title').textContent = `Fix: ${opp.name}`;
457
+ document.getElementById('modal-content').textContent = prompt.trim();
458
+ document.getElementById('modal').classList.add('visible');
459
+ }
460
+
461
+ function showBrokenPrompt() {
462
+ const items = DATA.broken || [];
463
+ let prompt = `## Task: Fix Critical Issues\nAgent path: ${DATA.meta.skill_path}\n\n`;
464
+ items.forEach((item, i) => {
465
+ const loc = item.file ? (item.line ? `${item.file}:${item.line}` : item.file) : '';
466
+ prompt += `${i+1}. **[${(item.severity||'high').toUpperCase()}] ${item.title}**\n`;
467
+ if (loc) prompt += ` File: ${loc}\n`;
468
+ if (item.detail) prompt += ` Context: ${item.detail}\n`;
469
+ if (item.action) prompt += ` Fix: ${item.action}\n\n`;
470
+ });
471
+ document.getElementById('modal-title').textContent = 'Fix Critical Issues';
472
+ document.getElementById('modal-content').textContent = prompt.trim();
473
+ document.getElementById('modal').classList.add('visible');
474
+ }
475
+
476
+ function closeModal() { document.getElementById('modal').classList.remove('visible'); }
477
+ function copyModal() {
478
+ navigator.clipboard.writeText(document.getElementById('modal-content').textContent).then(() => {
479
+ const btn = document.querySelector('.modal .btn-primary');
480
+ btn.textContent = 'Copied!';
481
+ setTimeout(() => { btn.textContent = 'Copy to Clipboard'; }, 1500);
482
+ });
483
+ }
484
+
485
+ init();
486
+ </script>
487
+ </body>
488
+ </html>"""
489
+
490
+
491
+ def generate_html(report_data: dict) -> str:
492
+ data_json = json.dumps(report_data, indent=None, ensure_ascii=False)
493
+ data_tag = f'<script id="report-data" type="application/json">{data_json}</script>'
494
+ html = HTML_TEMPLATE.replace('<script>\nconst RAW', f'{data_tag}\n<script>\nconst RAW')
495
+ html = html.replace('SKILL_NAME', report_data.get('meta', {}).get('skill_name', 'Unknown'))
496
+ return html
497
+
498
+
499
+ def main() -> int:
500
+ parser = argparse.ArgumentParser(description='Generate interactive HTML quality analysis report for a BMad agent')
501
+ parser.add_argument('report_dir', type=Path, help='Directory containing report-data.json')
502
+ parser.add_argument('--open', action='store_true', help='Open in default browser')
503
+ parser.add_argument('--output', '-o', type=Path, help='Output HTML file path')
504
+ args = parser.parse_args()
505
+
506
+ if not args.report_dir.is_dir():
507
+ print(f'Error: {args.report_dir} is not a directory', file=sys.stderr)
508
+ return 2
509
+
510
+ report_data = load_report_data(args.report_dir)
511
+ html = generate_html(report_data)
512
+ output_path = args.output or (args.report_dir / 'quality-report.html')
513
+ output_path.write_text(html, encoding='utf-8')
514
+
515
+ print(json.dumps({
516
+ 'html_report': str(output_path),
517
+ 'grade': report_data.get('grade', 'Unknown'),
518
+ 'opportunities': len(report_data.get('opportunities', [])),
519
+ 'broken': len(report_data.get('broken', [])),
520
+ }))
521
+
522
+ if args.open:
523
+ system = platform.system()
524
+ if system == 'Darwin':
525
+ subprocess.run(['open', str(output_path)])
526
+ elif system == 'Linux':
527
+ subprocess.run(['xdg-open', str(output_path)])
528
+ elif system == 'Windows':
529
+ subprocess.run(['start', str(output_path)], shell=True)
530
+ return 0
531
+
532
+
533
+ if __name__ == '__main__':
534
+ sys.exit(main())
@@ -5,7 +5,7 @@ Extracts dependency graph data and execution patterns from a BMad agent skill
5
5
  so the LLM scanner can evaluate efficiency from compact structured data.
6
6
 
7
7
  Covers:
8
- - Dependency graph from bmad-manifest.json (bmad-requires, bmad-prefer-after)
8
+ - Dependency graph from skill structure
9
9
  - Circular dependency detection
10
10
  - Transitive dependency redundancy
11
11
  - Parallelizable stage groups (independent nodes)
@@ -199,42 +199,12 @@ def scan_sequential_patterns(filepath: Path, rel_path: str) -> list[dict]:
199
199
 
200
200
  def scan_execution_deps(skill_path: Path) -> dict:
201
201
  """Run all deterministic execution efficiency checks."""
202
- # Parse bmad-manifest.json for dependency graph
202
+ # Build dependency graph from skill structure
203
203
  dep_graph: dict[str, list[str]] = {}
204
204
  prefer_after: dict[str, list[str]] = {}
205
205
  all_stages: set[str] = set()
206
- manifest_found = False
207
-
208
- manifest_path = skill_path / 'bmad-manifest.json'
209
- if manifest_path.exists():
210
- manifest_found = True
211
- try:
212
- data = json.loads(manifest_path.read_text(encoding='utf-8'))
213
- if isinstance(data, dict):
214
- # Parse capabilities for dependency info
215
- capabilities = data.get('capabilities', [])
216
- if isinstance(capabilities, list):
217
- for cap in capabilities:
218
- if isinstance(cap, dict):
219
- name = cap.get('name')
220
- if name:
221
- all_stages.add(name)
222
- dep_graph[name] = cap.get('bmad-requires', []) or []
223
- prefer_after[name] = cap.get('bmad-prefer-after', []) or []
224
-
225
- # Also check top-level dependencies
226
- top_name = data.get('name')
227
- if top_name and top_name not in all_stages:
228
- all_stages.add(top_name)
229
- top_requires = data.get('bmad-requires', []) or []
230
- top_prefer = data.get('bmad-prefer-after', []) or []
231
- if top_requires or top_prefer:
232
- dep_graph[top_name] = top_requires
233
- prefer_after[top_name] = top_prefer
234
- except (json.JSONDecodeError, OSError):
235
- pass
236
-
237
- # Also check for stage-level manifests or stage definitions in SKILL.md
206
+
207
+ # Check for stage definitions in prompt files
238
208
  prompts_dir = skill_path / 'prompts'
239
209
  if prompts_dir.exists():
240
210
  for f in sorted(prompts_dir.iterdir()):
@@ -314,7 +284,6 @@ def scan_execution_deps(skill_path: Path) -> dict:
314
284
  'timestamp': datetime.now(timezone.utc).isoformat(),
315
285
  'status': status,
316
286
  'dependency_graph': {
317
- 'manifest_found': manifest_found,
318
287
  'stages': sorted(all_stages),
319
288
  'hard_dependencies': dep_graph,
320
289
  'soft_dependencies': prefer_after,