bmalph 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.
- package/README.md +217 -0
- package/bin/bmalph.js +14 -0
- package/bmad/bmm/agents/analyst.agent.yaml +36 -0
- package/bmad/bmm/agents/architect.agent.yaml +28 -0
- package/bmad/bmm/agents/dev.agent.yaml +38 -0
- package/bmad/bmm/agents/pm.agent.yaml +46 -0
- package/bmad/bmm/agents/quick-flow-solo-dev.agent.yaml +32 -0
- package/bmad/bmm/agents/sm.agent.yaml +36 -0
- package/bmad/bmm/agents/tea.agent.yaml +63 -0
- package/bmad/bmm/agents/tech-writer/tech-writer-sidecar/documentation-standards.md +224 -0
- package/bmad/bmm/agents/tech-writer/tech-writer.agent.yaml +45 -0
- package/bmad/bmm/agents/ux-designer.agent.yaml +26 -0
- package/bmad/bmm/data/project-context-template.md +26 -0
- package/bmad/bmm/module-help.csv +31 -0
- package/bmad/bmm/module.yaml +44 -0
- package/bmad/bmm/sub-modules/claude-code/config.yaml +4 -0
- package/bmad/bmm/sub-modules/claude-code/injections.yaml +242 -0
- package/bmad/bmm/sub-modules/claude-code/readme.md +87 -0
- package/bmad/bmm/teams/default-party.csv +21 -0
- package/bmad/bmm/teams/team-fullstack.yaml +12 -0
- package/bmad/bmm/testarch/knowledge/adr-quality-readiness-checklist.md +350 -0
- package/bmad/bmm/testarch/knowledge/api-request.md +442 -0
- package/bmad/bmm/testarch/knowledge/api-testing-patterns.md +843 -0
- package/bmad/bmm/testarch/knowledge/auth-session.md +552 -0
- package/bmad/bmm/testarch/knowledge/burn-in.md +273 -0
- package/bmad/bmm/testarch/knowledge/ci-burn-in.md +675 -0
- package/bmad/bmm/testarch/knowledge/component-tdd.md +486 -0
- package/bmad/bmm/testarch/knowledge/contract-testing.md +957 -0
- package/bmad/bmm/testarch/knowledge/data-factories.md +500 -0
- package/bmad/bmm/testarch/knowledge/email-auth.md +721 -0
- package/bmad/bmm/testarch/knowledge/error-handling.md +725 -0
- package/bmad/bmm/testarch/knowledge/feature-flags.md +750 -0
- package/bmad/bmm/testarch/knowledge/file-utils.md +463 -0
- package/bmad/bmm/testarch/knowledge/fixture-architecture.md +401 -0
- package/bmad/bmm/testarch/knowledge/fixtures-composition.md +382 -0
- package/bmad/bmm/testarch/knowledge/intercept-network-call.md +430 -0
- package/bmad/bmm/testarch/knowledge/log.md +429 -0
- package/bmad/bmm/testarch/knowledge/network-error-monitor.md +405 -0
- package/bmad/bmm/testarch/knowledge/network-first.md +486 -0
- package/bmad/bmm/testarch/knowledge/network-recorder.md +527 -0
- package/bmad/bmm/testarch/knowledge/nfr-criteria.md +670 -0
- package/bmad/bmm/testarch/knowledge/overview.md +286 -0
- package/bmad/bmm/testarch/knowledge/playwright-config.md +730 -0
- package/bmad/bmm/testarch/knowledge/probability-impact.md +601 -0
- package/bmad/bmm/testarch/knowledge/recurse.md +421 -0
- package/bmad/bmm/testarch/knowledge/risk-governance.md +615 -0
- package/bmad/bmm/testarch/knowledge/selective-testing.md +732 -0
- package/bmad/bmm/testarch/knowledge/selector-resilience.md +527 -0
- package/bmad/bmm/testarch/knowledge/test-healing-patterns.md +644 -0
- package/bmad/bmm/testarch/knowledge/test-levels-framework.md +473 -0
- package/bmad/bmm/testarch/knowledge/test-priorities-matrix.md +373 -0
- package/bmad/bmm/testarch/knowledge/test-quality.md +664 -0
- package/bmad/bmm/testarch/knowledge/timing-debugging.md +372 -0
- package/bmad/bmm/testarch/knowledge/visual-debugging.md +524 -0
- package/bmad/bmm/testarch/tea-index.csv +35 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +177 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +161 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +199 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +202 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +205 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +219 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +162 -0
- package/bmad/bmm/workflows/1-analysis/create-product-brief/workflow.md +58 -0
- package/bmad/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +137 -0
- package/bmad/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +229 -0
- package/bmad/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +238 -0
- package/bmad/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +206 -0
- package/bmad/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +234 -0
- package/bmad/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +443 -0
- package/bmad/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
- package/bmad/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
- package/bmad/bmm/workflows/1-analysis/research/market-steps/step-02-customer-insights.md +200 -0
- package/bmad/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
- package/bmad/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
- package/bmad/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
- package/bmad/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +475 -0
- package/bmad/bmm/workflows/1-analysis/research/research.template.md +29 -0
- package/bmad/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +137 -0
- package/bmad/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +239 -0
- package/bmad/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +248 -0
- package/bmad/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +202 -0
- package/bmad/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +239 -0
- package/bmad/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +486 -0
- package/bmad/bmm/workflows/1-analysis/research/workflow.md +173 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +135 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +127 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +190 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +216 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +219 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +234 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +252 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +254 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +224 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +224 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +241 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +248 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +237 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +264 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +171 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
- package/bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +43 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/data/domain-complexity.csv +13 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/data/prd-purpose.md +197 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/data/project-types.csv +11 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-01-init.md +191 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-01b-continue.md +153 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-02-discovery.md +224 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-03-success.md +226 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-04-journeys.md +213 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-05-domain.md +207 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-06-innovation.md +226 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-07-project-type.md +237 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-08-scoping.md +228 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-09-functional.md +231 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-10-nonfunctional.md +242 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-11-polish.md +217 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-c/step-12-complete.md +124 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-01-discovery.md +247 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-02-review.md +249 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-03-edit.md +253 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-e/step-e-04-complete.md +168 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-01-discovery.md +218 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-02-format-detection.md +191 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-02b-parity-check.md +209 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-03-density-validation.md +174 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-05-measurability-validation.md +228 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-06-traceability-validation.md +217 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-09-project-type-validation.md +263 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-10-smart-validation.md +209 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-12-completeness-validation.md +242 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/steps-v/step-v-13-report-complete.md +231 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/templates/prd-template.md +10 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/validation-report-prd-workflow.md +433 -0
- package/bmad/bmm/workflows/2-plan-workflows/prd/workflow.md +150 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +190 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +178 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +179 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +139 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +252 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +135 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
- package/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +55 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +11 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +153 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +164 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +224 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +331 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +318 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +359 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +379 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +359 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +76 -0
- package/bmad/bmm/workflows/3-solutioning/create-architecture/workflow.md +50 -0
- package/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +259 -0
- package/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +233 -0
- package/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +272 -0
- package/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +149 -0
- package/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
- package/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +59 -0
- package/bmad/bmm/workflows/4-implementation/code-review/checklist.md +23 -0
- package/bmad/bmm/workflows/4-implementation/code-review/instructions.xml +227 -0
- package/bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +51 -0
- package/bmad/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
- package/bmad/bmm/workflows/4-implementation/correct-course/instructions.md +206 -0
- package/bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +60 -0
- package/bmad/bmm/workflows/4-implementation/create-story/checklist.md +358 -0
- package/bmad/bmm/workflows/4-implementation/create-story/instructions.xml +345 -0
- package/bmad/bmm/workflows/4-implementation/create-story/template.md +49 -0
- package/bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +61 -0
- package/bmad/bmm/workflows/4-implementation/dev-story/checklist.md +80 -0
- package/bmad/bmm/workflows/4-implementation/dev-story/instructions.xml +410 -0
- package/bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +27 -0
- package/bmad/bmm/workflows/4-implementation/retrospective/instructions.md +1443 -0
- package/bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +58 -0
- package/bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
- package/bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +225 -0
- package/bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +55 -0
- package/bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +54 -0
- package/bmad/bmm/workflows/4-implementation/sprint-status/instructions.md +229 -0
- package/bmad/bmm/workflows/4-implementation/sprint-status/workflow.yaml +36 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/data/project-levels.yaml +59 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +156 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +120 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +113 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +113 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +106 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +140 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +50 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +189 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +144 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +128 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +191 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +74 -0
- package/bmad/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +79 -0
- package/bmad/bmm/workflows/document-project/checklist.md +245 -0
- package/bmad/bmm/workflows/document-project/documentation-requirements.csv +12 -0
- package/bmad/bmm/workflows/document-project/instructions.md +221 -0
- package/bmad/bmm/workflows/document-project/templates/deep-dive-template.md +345 -0
- package/bmad/bmm/workflows/document-project/templates/index-template.md +169 -0
- package/bmad/bmm/workflows/document-project/templates/project-overview-template.md +103 -0
- package/bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +160 -0
- package/bmad/bmm/workflows/document-project/templates/source-tree-template.md +135 -0
- package/bmad/bmm/workflows/document-project/workflow.yaml +30 -0
- package/bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +298 -0
- package/bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +31 -0
- package/bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +1106 -0
- package/bmad/bmm/workflows/document-project/workflows/full-scan.yaml +31 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-library.json +90 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-templates.yaml +127 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/checklist.md +39 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/instructions.md +130 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/workflow.yaml +27 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-diagram/checklist.md +43 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-diagram/instructions.md +141 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-diagram/workflow.yaml +27 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/checklist.md +49 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/instructions.md +241 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/workflow.yaml +27 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/checklist.md +38 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/instructions.md +133 -0
- package/bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/workflow.yaml +27 -0
- package/bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +363 -0
- package/bmad/bmm/workflows/testarch/atdd/checklist.md +374 -0
- package/bmad/bmm/workflows/testarch/atdd/instructions.md +806 -0
- package/bmad/bmm/workflows/testarch/atdd/workflow.yaml +47 -0
- package/bmad/bmm/workflows/testarch/automate/checklist.md +582 -0
- package/bmad/bmm/workflows/testarch/automate/instructions.md +1324 -0
- package/bmad/bmm/workflows/testarch/automate/workflow.yaml +54 -0
- package/bmad/bmm/workflows/testarch/ci/checklist.md +247 -0
- package/bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +198 -0
- package/bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +149 -0
- package/bmad/bmm/workflows/testarch/ci/instructions.md +536 -0
- package/bmad/bmm/workflows/testarch/ci/workflow.yaml +47 -0
- package/bmad/bmm/workflows/testarch/framework/checklist.md +320 -0
- package/bmad/bmm/workflows/testarch/framework/instructions.md +481 -0
- package/bmad/bmm/workflows/testarch/framework/workflow.yaml +49 -0
- package/bmad/bmm/workflows/testarch/nfr-assess/checklist.md +407 -0
- package/bmad/bmm/workflows/testarch/nfr-assess/instructions.md +726 -0
- package/bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +461 -0
- package/bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +49 -0
- package/bmad/bmm/workflows/testarch/test-design/checklist.md +407 -0
- package/bmad/bmm/workflows/testarch/test-design/instructions.md +1158 -0
- package/bmad/bmm/workflows/testarch/test-design/test-design-architecture-template.md +213 -0
- package/bmad/bmm/workflows/testarch/test-design/test-design-qa-template.md +286 -0
- package/bmad/bmm/workflows/testarch/test-design/test-design-template.md +294 -0
- package/bmad/bmm/workflows/testarch/test-design/workflow.yaml +71 -0
- package/bmad/bmm/workflows/testarch/test-review/checklist.md +472 -0
- package/bmad/bmm/workflows/testarch/test-review/instructions.md +628 -0
- package/bmad/bmm/workflows/testarch/test-review/test-review-template.md +390 -0
- package/bmad/bmm/workflows/testarch/test-review/workflow.yaml +48 -0
- package/bmad/bmm/workflows/testarch/trace/checklist.md +642 -0
- package/bmad/bmm/workflows/testarch/trace/instructions.md +1030 -0
- package/bmad/bmm/workflows/testarch/trace/trace-template.md +675 -0
- package/bmad/bmm/workflows/testarch/trace/workflow.yaml +57 -0
- package/bmad/core/agents/bmad-master.agent.yaml +30 -0
- package/bmad/core/module-help.csv +11 -0
- package/bmad/core/module.yaml +25 -0
- package/bmad/core/resources/excalidraw/README.md +160 -0
- package/bmad/core/resources/excalidraw/excalidraw-helpers.md +127 -0
- package/bmad/core/resources/excalidraw/library-loader.md +50 -0
- package/bmad/core/resources/excalidraw/validate-json-instructions.md +79 -0
- package/bmad/core/tasks/bmad-help.md +62 -0
- package/bmad/core/tasks/editorial-review-prose.xml +91 -0
- package/bmad/core/tasks/editorial-review-structure.xml +198 -0
- package/bmad/core/tasks/index-docs.xml +65 -0
- package/bmad/core/tasks/review-adversarial-general.xml +48 -0
- package/bmad/core/tasks/shard-doc.xml +109 -0
- package/bmad/core/tasks/workflow.xml +235 -0
- package/bmad/core/workflows/advanced-elicitation/methods.csv +51 -0
- package/bmad/core/workflows/advanced-elicitation/workflow.xml +117 -0
- package/bmad/core/workflows/brainstorming/brain-methods.csv +62 -0
- package/bmad/core/workflows/brainstorming/steps/step-01-session-setup.md +197 -0
- package/bmad/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
- package/bmad/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
- package/bmad/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
- package/bmad/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
- package/bmad/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
- package/bmad/core/workflows/brainstorming/steps/step-03-technique-execution.md +399 -0
- package/bmad/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
- package/bmad/core/workflows/brainstorming/template.md +15 -0
- package/bmad/core/workflows/brainstorming/workflow.md +58 -0
- package/bmad/core/workflows/party-mode/steps/step-01-agent-loading.md +138 -0
- package/bmad/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
- package/bmad/core/workflows/party-mode/steps/step-03-graceful-exit.md +157 -0
- package/bmad/core/workflows/party-mode/workflow.md +194 -0
- package/dist/cli.d.ts +1 -0
- package/dist/cli.js +26 -0
- package/dist/commands/doctor.d.ts +1 -0
- package/dist/commands/doctor.js +168 -0
- package/dist/commands/guide.d.ts +1 -0
- package/dist/commands/guide.js +19 -0
- package/dist/commands/implement.d.ts +1 -0
- package/dist/commands/implement.js +83 -0
- package/dist/commands/init.d.ts +6 -0
- package/dist/commands/init.js +67 -0
- package/dist/commands/plan.d.ts +5 -0
- package/dist/commands/plan.js +44 -0
- package/dist/commands/reset.d.ts +5 -0
- package/dist/commands/reset.js +35 -0
- package/dist/commands/resume.d.ts +1 -0
- package/dist/commands/resume.js +44 -0
- package/dist/commands/start.d.ts +5 -0
- package/dist/commands/start.js +54 -0
- package/dist/commands/status.d.ts +1 -0
- package/dist/commands/status.js +53 -0
- package/dist/commands/upgrade.d.ts +1 -0
- package/dist/commands/upgrade.js +34 -0
- package/dist/installer.d.ts +11 -0
- package/dist/installer.js +219 -0
- package/dist/transition.d.ts +52 -0
- package/dist/transition.js +656 -0
- package/dist/utils/config.d.ts +7 -0
- package/dist/utils/config.js +14 -0
- package/dist/utils/json.d.ts +7 -0
- package/dist/utils/json.js +26 -0
- package/dist/utils/logger.d.ts +3 -0
- package/dist/utils/logger.js +13 -0
- package/dist/utils/state.d.ts +29 -0
- package/dist/utils/state.js +78 -0
- package/dist/utils/validate.d.ts +4 -0
- package/dist/utils/validate.js +42 -0
- package/package.json +59 -0
- package/ralph/lib/circuit_breaker.sh +330 -0
- package/ralph/lib/date_utils.sh +53 -0
- package/ralph/lib/response_analyzer.sh +768 -0
- package/ralph/lib/timeout_utils.sh +145 -0
- package/ralph/ralph_loop.sh +1391 -0
- package/ralph/templates/AGENT.md +158 -0
- package/ralph/templates/PROMPT.md +292 -0
- package/ralph/templates/fix_plan.md +27 -0
- package/ralph/templates/specs/.gitkeep +2 -0
- package/slash-commands/advanced-elicitation.md +1 -0
- package/slash-commands/adversarial-review.md +1 -0
- package/slash-commands/analyst.md +1 -0
- package/slash-commands/architect.md +1 -0
- package/slash-commands/atdd.md +1 -0
- package/slash-commands/bmad-help.md +1 -0
- package/slash-commands/bmalph-implement.md +152 -0
- package/slash-commands/bmalph.md +1 -0
- package/slash-commands/brainstorm-project.md +1 -0
- package/slash-commands/brainstorming.md +1 -0
- package/slash-commands/continuous-integration.md +1 -0
- package/slash-commands/correct-course.md +1 -0
- package/slash-commands/create-architecture.md +1 -0
- package/slash-commands/create-brief.md +1 -0
- package/slash-commands/create-dataflow.md +1 -0
- package/slash-commands/create-diagram.md +1 -0
- package/slash-commands/create-epics-stories.md +1 -0
- package/slash-commands/create-flowchart.md +1 -0
- package/slash-commands/create-prd.md +1 -0
- package/slash-commands/create-story.md +1 -0
- package/slash-commands/create-ux.md +1 -0
- package/slash-commands/create-wireframe.md +1 -0
- package/slash-commands/dev.md +1 -0
- package/slash-commands/document-project.md +1 -0
- package/slash-commands/domain-research.md +1 -0
- package/slash-commands/editorial-prose.md +1 -0
- package/slash-commands/editorial-structure.md +1 -0
- package/slash-commands/execute-workflow.md +1 -0
- package/slash-commands/implementation-readiness.md +1 -0
- package/slash-commands/index-docs.md +1 -0
- package/slash-commands/market-research.md +1 -0
- package/slash-commands/nfr-assess.md +1 -0
- package/slash-commands/party-mode.md +1 -0
- package/slash-commands/pm.md +1 -0
- package/slash-commands/quick-dev.md +1 -0
- package/slash-commands/quick-flow-solo-dev.md +1 -0
- package/slash-commands/retrospective.md +1 -0
- package/slash-commands/shard-doc.md +1 -0
- package/slash-commands/sm.md +1 -0
- package/slash-commands/sprint-planning.md +1 -0
- package/slash-commands/sprint-status.md +1 -0
- package/slash-commands/tea.md +1 -0
- package/slash-commands/tech-spec.md +1 -0
- package/slash-commands/technical-research.md +1 -0
- package/slash-commands/test-automate.md +1 -0
- package/slash-commands/test-design.md +1 -0
- package/slash-commands/test-framework.md +1 -0
- package/slash-commands/test-review.md +1 -0
- package/slash-commands/test-trace.md +1 -0
- package/slash-commands/ux-designer.md +1 -0
- package/slash-commands/validate-architecture.md +1 -0
- package/slash-commands/validate-brief.md +1 -0
- package/slash-commands/validate-epics-stories.md +1 -0
- package/slash-commands/validate-prd.md +1 -0
- package/slash-commands/validate-story.md +1 -0
- package/slash-commands/validate-test-design.md +1 -0
- package/slash-commands/validate-ux.md +1 -0
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
# Test Architect workflow: trace (enhanced with gate decision)
|
|
2
|
+
name: testarch-trace
|
|
3
|
+
description: "Generate requirements-to-tests traceability matrix, analyze coverage, and make quality gate decision (PASS/CONCERNS/FAIL/WAIVED)"
|
|
4
|
+
author: "BMad"
|
|
5
|
+
|
|
6
|
+
# Critical variables from config
|
|
7
|
+
config_source: "{project-root}/_bmad/bmm/config.yaml"
|
|
8
|
+
output_folder: "{config_source}:output_folder"
|
|
9
|
+
user_name: "{config_source}:user_name"
|
|
10
|
+
communication_language: "{config_source}:communication_language"
|
|
11
|
+
document_output_language: "{config_source}:document_output_language"
|
|
12
|
+
date: system-generated
|
|
13
|
+
|
|
14
|
+
# Workflow components
|
|
15
|
+
installed_path: "{project-root}/_bmad/bmm/workflows/testarch/trace"
|
|
16
|
+
instructions: "{installed_path}/instructions.md"
|
|
17
|
+
validation: "{installed_path}/checklist.md"
|
|
18
|
+
template: "{installed_path}/trace-template.md"
|
|
19
|
+
|
|
20
|
+
# Variables and inputs
|
|
21
|
+
variables:
|
|
22
|
+
# Directory paths
|
|
23
|
+
test_dir: "{project-root}/tests" # Root test directory
|
|
24
|
+
source_dir: "{project-root}/src" # Source code directory
|
|
25
|
+
|
|
26
|
+
# Workflow behavior
|
|
27
|
+
coverage_levels: "e2e,api,component,unit" # Which test levels to trace
|
|
28
|
+
gate_type: "story" # story | epic | release | hotfix - determines gate scope
|
|
29
|
+
decision_mode: "deterministic" # deterministic (rule-based) | manual (team decision)
|
|
30
|
+
|
|
31
|
+
# Output configuration
|
|
32
|
+
default_output_file: "{output_folder}/traceability-matrix.md"
|
|
33
|
+
|
|
34
|
+
# Required tools
|
|
35
|
+
required_tools:
|
|
36
|
+
- read_file # Read story, test files, BMad artifacts
|
|
37
|
+
- write_file # Create traceability matrix, gate YAML
|
|
38
|
+
- list_files # Discover test files
|
|
39
|
+
- search_repo # Find tests by test ID, describe blocks
|
|
40
|
+
- glob # Find test files matching patterns
|
|
41
|
+
|
|
42
|
+
tags:
|
|
43
|
+
- qa
|
|
44
|
+
- traceability
|
|
45
|
+
- test-architect
|
|
46
|
+
- coverage
|
|
47
|
+
- requirements
|
|
48
|
+
- gate
|
|
49
|
+
- decision
|
|
50
|
+
- release
|
|
51
|
+
|
|
52
|
+
execution_hints:
|
|
53
|
+
interactive: false # Minimize prompts
|
|
54
|
+
autonomous: true # Proceed without user input unless blocked
|
|
55
|
+
iterative: true
|
|
56
|
+
|
|
57
|
+
web_bundle: false
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
# BMad Master Task Executor Agent
|
|
2
|
+
# Core system agent for task execution and resource management
|
|
3
|
+
|
|
4
|
+
agent:
|
|
5
|
+
metadata:
|
|
6
|
+
id: "_bmad/core/agents/bmad-master.md"
|
|
7
|
+
name: "BMad Master"
|
|
8
|
+
title: "BMad Master Executor, Knowledge Custodian, and Workflow Orchestrator"
|
|
9
|
+
icon: "🧙"
|
|
10
|
+
hasSidecar: false
|
|
11
|
+
|
|
12
|
+
persona:
|
|
13
|
+
role: "Master Task Executor + BMad Expert + Guiding Facilitator Orchestrator"
|
|
14
|
+
identity: "Master-level expert in the BMAD Core Platform and all loaded modules with comprehensive knowledge of all resources, tasks, and workflows. Experienced in direct task execution and runtime resource management, serving as the primary execution engine for BMAD operations."
|
|
15
|
+
communication_style: "Direct and comprehensive, refers to himself in the 3rd person. Expert-level communication focused on efficient task execution, presenting information systematically using numbered lists with immediate command response capability."
|
|
16
|
+
principles: |
|
|
17
|
+
- "Load resources at runtime never pre-load, and always present numbered lists for choices."
|
|
18
|
+
|
|
19
|
+
critical_actions:
|
|
20
|
+
- "Load into memory {project-root}/_bmad/core/config.yaml and set variable project_name, output_folder, user_name, communication_language"
|
|
21
|
+
- "ALWAYS communicate in {communication_language}"
|
|
22
|
+
|
|
23
|
+
menu:
|
|
24
|
+
- trigger: "LT or fuzzy match on list-tasks"
|
|
25
|
+
action: "list all tasks from {project-root}/_bmad/_config/task-manifest.csv"
|
|
26
|
+
description: "[LT] List Available Tasks"
|
|
27
|
+
|
|
28
|
+
- trigger: "LW or fuzzy match on list-workflows"
|
|
29
|
+
action: "list all workflows from {project-root}/_bmad/_config/workflow-manifest.csv"
|
|
30
|
+
description: "[LW] List Workflows"
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
module,phase,name,code,sequence,workflow-file,command,required,agent,options,description,output-location,outputs
|
|
2
|
+
core,,Advanced Elicitation,AE,10,_bmad/core/workflows/advanced-elicitation/workflow.xml,bmad_advanced-elicitation,false,,,"Apply elicitation methods iteratively to enhance content being generated, presenting options and allowing reshuffle or full method listing for comprehensive content improvement",,
|
|
3
|
+
core,,Brainstorming,BS,20,_bmad/core/workflows/brainstorming/workflow.md,bmad_brainstorming,false,analyst,,Facilitate interactive brainstorming sessions using diverse creative techniques and ideation methods,{output_folder}/brainstorming/brainstorming-session-{{date}}.md,,
|
|
4
|
+
core,,Party Mode,PM,30,_bmad/core/workflows/party-mode/workflow.md,bmad_party-mode,false,party-mode facilitator,,Orchestrates group discussions between all installed BMAD agents enabling natural multi-agent conversations,,
|
|
5
|
+
core,,bmad-help,BH,40,_bmad/core/tasks/bmad-help.md,bmad_help,false,system,,Get unstuck by showing what workflow steps come next or answering questions about what to do in the BMad Method,,
|
|
6
|
+
core,,Index Docs,ID,50,_bmad/core/tasks/index-docs.xml,bmad_index-docs,false,llm,,Generates or updates an index.md of all documents in the specified directory,,
|
|
7
|
+
core,,Execute Workflow,WF,60,_bmad/core/tasks/workflow.xml,bmad_workflow,false,llm,,Execute given workflow by loading its configuration following instructions and producing output,,
|
|
8
|
+
core,,Shard Document,SD,70,_bmad/core/tasks/shard-doc.xml,bmad_shard-doc,false,llm,,Splits large markdown documents into smaller organized files based on level 2 sections,,
|
|
9
|
+
core,,Editorial Review - Prose,EP,80,_bmad/core/tasks/editorial-review-prose.xml,bmad_editorial-review-prose,false,llm,reader_type,Clinical copy-editor that reviews text for communication issues,,"three-column markdown table with suggested fixes",
|
|
10
|
+
core,,Editorial Review - Structure,ES,90,_bmad/core/tasks/editorial-review-structure.xml,bmad_editorial-review-structure,false,llm,,Structural editor that proposes cuts reorganization and simplification while preserving comprehension,,
|
|
11
|
+
core,,Adversarial Review (General),AR,100,_bmad/core/tasks/review-adversarial-general.xml,bmad_review-adversarial-general,false,llm,,Cynically review content and produce findings,,
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
code: core
|
|
2
|
+
name: "BMad Core Module"
|
|
3
|
+
|
|
4
|
+
header: "BMad Core Configuration"
|
|
5
|
+
subheader: "Configure the core settings for your BMad installation.\nThese settings will be used across all modules and agents."
|
|
6
|
+
|
|
7
|
+
user_name:
|
|
8
|
+
prompt: "What should agents call you? (Use your name or a team name)"
|
|
9
|
+
default: "BMad"
|
|
10
|
+
result: "{value}"
|
|
11
|
+
|
|
12
|
+
communication_language:
|
|
13
|
+
prompt: "What language should agents use when chatting with you?"
|
|
14
|
+
default: "English"
|
|
15
|
+
result: "{value}"
|
|
16
|
+
|
|
17
|
+
document_output_language:
|
|
18
|
+
prompt: "Preferred document output language?"
|
|
19
|
+
default: "English"
|
|
20
|
+
result: "{value}"
|
|
21
|
+
|
|
22
|
+
output_folder:
|
|
23
|
+
prompt: "Where should output files be saved?"
|
|
24
|
+
default: "_bmad-output"
|
|
25
|
+
result: "{project-root}/{value}"
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
# Core Excalidraw Resources
|
|
2
|
+
|
|
3
|
+
Universal knowledge for creating Excalidraw diagrams. All agents that create Excalidraw files should reference these resources.
|
|
4
|
+
|
|
5
|
+
## Purpose
|
|
6
|
+
|
|
7
|
+
Provides the **HOW** (universal knowledge) while agents provide the **WHAT** (domain-specific application).
|
|
8
|
+
|
|
9
|
+
**Core = "How to create Excalidraw elements"**
|
|
10
|
+
|
|
11
|
+
- How to group shapes with text labels
|
|
12
|
+
- How to calculate text width
|
|
13
|
+
- How to create arrows with proper bindings
|
|
14
|
+
- How to validate JSON syntax
|
|
15
|
+
- Base structure and primitives
|
|
16
|
+
|
|
17
|
+
**Agents = "What diagrams to create"**
|
|
18
|
+
|
|
19
|
+
- Frame Expert (BMM): Technical flowcharts, architecture diagrams, wireframes
|
|
20
|
+
- Presentation Master (CIS): Pitch decks, creative visuals, Rube Goldberg machines
|
|
21
|
+
- Tech Writer (BMM): Documentation diagrams, concept explanations
|
|
22
|
+
|
|
23
|
+
## Files in This Directory
|
|
24
|
+
|
|
25
|
+
### excalidraw-helpers.md
|
|
26
|
+
|
|
27
|
+
**Universal element creation patterns**
|
|
28
|
+
|
|
29
|
+
- Text width calculation
|
|
30
|
+
- Element grouping rules (shapes + labels)
|
|
31
|
+
- Grid alignment
|
|
32
|
+
- Arrow creation (straight, elbow)
|
|
33
|
+
- Theme application
|
|
34
|
+
- Validation checklist
|
|
35
|
+
- Optimization rules
|
|
36
|
+
|
|
37
|
+
**Agents reference this to:**
|
|
38
|
+
|
|
39
|
+
- Create properly grouped shapes
|
|
40
|
+
- Calculate text dimensions
|
|
41
|
+
- Connect elements with arrows
|
|
42
|
+
- Ensure valid structure
|
|
43
|
+
|
|
44
|
+
### validate-json-instructions.md
|
|
45
|
+
|
|
46
|
+
**Universal JSON validation process**
|
|
47
|
+
|
|
48
|
+
- How to validate Excalidraw JSON
|
|
49
|
+
- Common errors and fixes
|
|
50
|
+
- Workflow integration
|
|
51
|
+
- Error recovery
|
|
52
|
+
|
|
53
|
+
**Agents reference this to:**
|
|
54
|
+
|
|
55
|
+
- Validate files after creation
|
|
56
|
+
- Fix syntax errors
|
|
57
|
+
- Ensure files can be opened in Excalidraw
|
|
58
|
+
|
|
59
|
+
### library-loader.md (Future)
|
|
60
|
+
|
|
61
|
+
**How to load external .excalidrawlib files**
|
|
62
|
+
|
|
63
|
+
- Programmatic library loading
|
|
64
|
+
- Community library integration
|
|
65
|
+
- Custom library management
|
|
66
|
+
|
|
67
|
+
**Status:** To be developed when implementing external library support.
|
|
68
|
+
|
|
69
|
+
## How Agents Use These Resources
|
|
70
|
+
|
|
71
|
+
### Example: Frame Expert (Technical Diagrams)
|
|
72
|
+
|
|
73
|
+
```yaml
|
|
74
|
+
# workflows/excalidraw-diagrams/create-flowchart/workflow.yaml
|
|
75
|
+
helpers: '{project-root}/_bmad/core/resources/excalidraw/excalidraw-helpers.md'
|
|
76
|
+
json_validation: '{project-root}/_bmad/core/resources/excalidraw/validate-json-instructions.md'
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
**Domain-specific additions:**
|
|
80
|
+
|
|
81
|
+
```yaml
|
|
82
|
+
# workflows/excalidraw-diagrams/_shared/flowchart-templates.yaml
|
|
83
|
+
flowchart:
|
|
84
|
+
start_node:
|
|
85
|
+
type: ellipse
|
|
86
|
+
width: 120
|
|
87
|
+
height: 60
|
|
88
|
+
process_box:
|
|
89
|
+
type: rectangle
|
|
90
|
+
width: 160
|
|
91
|
+
height: 80
|
|
92
|
+
decision_diamond:
|
|
93
|
+
type: diamond
|
|
94
|
+
width: 140
|
|
95
|
+
height: 100
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
### Example: Presentation Master (Creative Visuals)
|
|
99
|
+
|
|
100
|
+
```yaml
|
|
101
|
+
# workflows/create-visual-metaphor/workflow.yaml
|
|
102
|
+
helpers: '{project-root}/_bmad/core/resources/excalidraw/excalidraw-helpers.md'
|
|
103
|
+
json_validation: '{project-root}/_bmad/core/resources/excalidraw/validate-json-instructions.md'
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
**Domain-specific additions:**
|
|
107
|
+
|
|
108
|
+
```yaml
|
|
109
|
+
# workflows/_shared/creative-templates.yaml
|
|
110
|
+
rube_goldberg:
|
|
111
|
+
whimsical_connector:
|
|
112
|
+
type: arrow
|
|
113
|
+
strokeStyle: dashed
|
|
114
|
+
roughness: 2
|
|
115
|
+
playful_box:
|
|
116
|
+
type: rectangle
|
|
117
|
+
roundness: 12
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
## What Doesn't Belong in Core
|
|
121
|
+
|
|
122
|
+
**Domain-Specific Elements:**
|
|
123
|
+
|
|
124
|
+
- Flowchart-specific templates (belongs in Frame Expert)
|
|
125
|
+
- Pitch deck layouts (belongs in Presentation Master)
|
|
126
|
+
- Documentation-specific styles (belongs in Tech Writer)
|
|
127
|
+
|
|
128
|
+
**Agent Workflows:**
|
|
129
|
+
|
|
130
|
+
- How to create a flowchart (Frame Expert workflow)
|
|
131
|
+
- How to create a pitch deck (Presentation Master workflow)
|
|
132
|
+
- Step-by-step diagram creation (agent-specific)
|
|
133
|
+
|
|
134
|
+
**Theming:**
|
|
135
|
+
|
|
136
|
+
- Currently in agent workflows
|
|
137
|
+
- **Future:** Will be refactored to core as user-configurable themes
|
|
138
|
+
|
|
139
|
+
## Architecture Principle
|
|
140
|
+
|
|
141
|
+
**Single Source of Truth:**
|
|
142
|
+
|
|
143
|
+
- Core holds universal knowledge
|
|
144
|
+
- Agents reference core, don't duplicate
|
|
145
|
+
- Updates to core benefit all agents
|
|
146
|
+
- Agents specialize with domain knowledge
|
|
147
|
+
|
|
148
|
+
**DRY (Don't Repeat Yourself):**
|
|
149
|
+
|
|
150
|
+
- Element creation logic: ONCE in core
|
|
151
|
+
- Text width calculation: ONCE in core
|
|
152
|
+
- Validation process: ONCE in core
|
|
153
|
+
- Arrow binding patterns: ONCE in core
|
|
154
|
+
|
|
155
|
+
## Future Enhancements
|
|
156
|
+
|
|
157
|
+
1. **External Library Loader** - Load .excalidrawlib files from libraries.excalidraw.com
|
|
158
|
+
2. **Theme Management** - User-configurable color themes saved in core
|
|
159
|
+
3. **Component Library** - Shared reusable components across agents
|
|
160
|
+
4. **Layout Algorithms** - Auto-layout helpers for positioning elements
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
# Excalidraw Element Creation Guidelines
|
|
2
|
+
|
|
3
|
+
## Text Width Calculation
|
|
4
|
+
|
|
5
|
+
For text elements inside shapes (labels):
|
|
6
|
+
|
|
7
|
+
```
|
|
8
|
+
text_width = (text.length × fontSize × 0.6) + 20
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
Round to nearest 10 for grid alignment.
|
|
12
|
+
|
|
13
|
+
## Element Grouping Rules
|
|
14
|
+
|
|
15
|
+
**CRITICAL:** When creating shapes with labels:
|
|
16
|
+
|
|
17
|
+
1. Generate unique IDs:
|
|
18
|
+
- `shape-id` for the shape
|
|
19
|
+
- `text-id` for the text
|
|
20
|
+
- `group-id` for the group
|
|
21
|
+
|
|
22
|
+
2. Shape element must have:
|
|
23
|
+
- `groupIds: [group-id]`
|
|
24
|
+
- `boundElements: [{type: "text", id: text-id}]`
|
|
25
|
+
|
|
26
|
+
3. Text element must have:
|
|
27
|
+
- `containerId: shape-id`
|
|
28
|
+
- `groupIds: [group-id]` (SAME as shape)
|
|
29
|
+
- `textAlign: "center"`
|
|
30
|
+
- `verticalAlign: "middle"`
|
|
31
|
+
- `width: calculated_width`
|
|
32
|
+
|
|
33
|
+
## Grid Alignment
|
|
34
|
+
|
|
35
|
+
- Snap all `x`, `y` coordinates to 20px grid
|
|
36
|
+
- Formula: `Math.round(value / 20) * 20`
|
|
37
|
+
- Spacing between elements: 60px minimum
|
|
38
|
+
|
|
39
|
+
## Arrow Creation
|
|
40
|
+
|
|
41
|
+
### Straight Arrows
|
|
42
|
+
|
|
43
|
+
Use for forward flow (left-to-right, top-to-bottom):
|
|
44
|
+
|
|
45
|
+
```json
|
|
46
|
+
{
|
|
47
|
+
"type": "arrow",
|
|
48
|
+
"startBinding": {
|
|
49
|
+
"elementId": "source-shape-id",
|
|
50
|
+
"focus": 0,
|
|
51
|
+
"gap": 10
|
|
52
|
+
},
|
|
53
|
+
"endBinding": {
|
|
54
|
+
"elementId": "target-shape-id",
|
|
55
|
+
"focus": 0,
|
|
56
|
+
"gap": 10
|
|
57
|
+
},
|
|
58
|
+
"points": [[0, 0], [distance_x, distance_y]]
|
|
59
|
+
}
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
### Elbow Arrows
|
|
63
|
+
|
|
64
|
+
Use for upward flow, backward flow, or complex routing:
|
|
65
|
+
|
|
66
|
+
```json
|
|
67
|
+
{
|
|
68
|
+
"type": "arrow",
|
|
69
|
+
"startBinding": {...},
|
|
70
|
+
"endBinding": {...},
|
|
71
|
+
"points": [
|
|
72
|
+
[0, 0],
|
|
73
|
+
[intermediate_x, 0],
|
|
74
|
+
[intermediate_x, intermediate_y],
|
|
75
|
+
[final_x, final_y]
|
|
76
|
+
],
|
|
77
|
+
"elbowed": true
|
|
78
|
+
}
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
### Update Connected Shapes
|
|
82
|
+
|
|
83
|
+
After creating arrow, update `boundElements` on both connected shapes:
|
|
84
|
+
|
|
85
|
+
```json
|
|
86
|
+
{
|
|
87
|
+
"id": "shape-id",
|
|
88
|
+
"boundElements": [
|
|
89
|
+
{ "type": "text", "id": "text-id" },
|
|
90
|
+
{ "type": "arrow", "id": "arrow-id" }
|
|
91
|
+
]
|
|
92
|
+
}
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
## Theme Application
|
|
96
|
+
|
|
97
|
+
Theme colors should be applied consistently:
|
|
98
|
+
|
|
99
|
+
- **Shapes**: `backgroundColor` from theme primary fill
|
|
100
|
+
- **Borders**: `strokeColor` from theme accent
|
|
101
|
+
- **Text**: `strokeColor` = "#1e1e1e" (dark text)
|
|
102
|
+
- **Arrows**: `strokeColor` from theme accent
|
|
103
|
+
|
|
104
|
+
## Validation Checklist
|
|
105
|
+
|
|
106
|
+
Before saving, verify:
|
|
107
|
+
|
|
108
|
+
- [ ] All shapes with labels have matching `groupIds`
|
|
109
|
+
- [ ] All text elements have `containerId` pointing to parent shape
|
|
110
|
+
- [ ] Text width calculated properly (no cutoff)
|
|
111
|
+
- [ ] Text alignment set (`textAlign` + `verticalAlign`)
|
|
112
|
+
- [ ] All elements snapped to 20px grid
|
|
113
|
+
- [ ] All arrows have `startBinding` and `endBinding`
|
|
114
|
+
- [ ] `boundElements` array updated on connected shapes
|
|
115
|
+
- [ ] Theme colors applied consistently
|
|
116
|
+
- [ ] No metadata or history in final output
|
|
117
|
+
- [ ] All IDs are unique
|
|
118
|
+
|
|
119
|
+
## Optimization
|
|
120
|
+
|
|
121
|
+
Remove from final output:
|
|
122
|
+
|
|
123
|
+
- `appState` object
|
|
124
|
+
- `files` object (unless images used)
|
|
125
|
+
- All elements with `isDeleted: true`
|
|
126
|
+
- Unused library items
|
|
127
|
+
- Version history
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
# External Library Loader
|
|
2
|
+
|
|
3
|
+
**Status:** Placeholder for future implementation
|
|
4
|
+
|
|
5
|
+
## Purpose
|
|
6
|
+
|
|
7
|
+
Load external .excalidrawlib files from <https://libraries.excalidraw.com> or custom sources.
|
|
8
|
+
|
|
9
|
+
## Planned Capabilities
|
|
10
|
+
|
|
11
|
+
- Load libraries by URL
|
|
12
|
+
- Load libraries from local files
|
|
13
|
+
- Merge multiple libraries
|
|
14
|
+
- Filter library components
|
|
15
|
+
- Cache loaded libraries
|
|
16
|
+
|
|
17
|
+
## API Reference
|
|
18
|
+
|
|
19
|
+
Will document how to use:
|
|
20
|
+
|
|
21
|
+
- `importLibrary(url)` - Load library from URL
|
|
22
|
+
- `loadSceneOrLibraryFromBlob()` - Load from file
|
|
23
|
+
- `mergeLibraryItems()` - Combine libraries
|
|
24
|
+
|
|
25
|
+
## Usage Example
|
|
26
|
+
|
|
27
|
+
```yaml
|
|
28
|
+
# Future workflow.yaml structure
|
|
29
|
+
libraries:
|
|
30
|
+
- url: 'https://libraries.excalidraw.com/libraries/...'
|
|
31
|
+
filter: ['aws', 'cloud']
|
|
32
|
+
- path: '{project-root}/_data/custom-library.excalidrawlib'
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
## Implementation Notes
|
|
36
|
+
|
|
37
|
+
This will be developed when agents need to leverage the extensive library ecosystem available at <https://libraries.excalidraw.com>.
|
|
38
|
+
|
|
39
|
+
Hundreds of pre-built component libraries exist for:
|
|
40
|
+
|
|
41
|
+
- AWS/Cloud icons
|
|
42
|
+
- UI/UX components
|
|
43
|
+
- Business diagrams
|
|
44
|
+
- Mind map shapes
|
|
45
|
+
- Floor plans
|
|
46
|
+
- And much more...
|
|
47
|
+
|
|
48
|
+
## User Configuration
|
|
49
|
+
|
|
50
|
+
Future: Users will be able to configure favorite libraries in their BMAD config for automatic loading.
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
# JSON Validation Instructions
|
|
2
|
+
|
|
3
|
+
## Purpose
|
|
4
|
+
|
|
5
|
+
Validate Excalidraw JSON files after saving to catch syntax errors (missing commas, brackets, quotes).
|
|
6
|
+
|
|
7
|
+
## How to Validate
|
|
8
|
+
|
|
9
|
+
Use Node.js built-in JSON parsing to validate the file:
|
|
10
|
+
|
|
11
|
+
```bash
|
|
12
|
+
node -e "JSON.parse(require('fs').readFileSync('FILE_PATH', 'utf8')); console.log('✓ Valid JSON')"
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
Replace `FILE_PATH` with the actual file path.
|
|
16
|
+
|
|
17
|
+
## Exit Codes
|
|
18
|
+
|
|
19
|
+
- Exit code 0 = Valid JSON
|
|
20
|
+
- Exit code 1 = Invalid JSON (syntax error)
|
|
21
|
+
|
|
22
|
+
## Error Output
|
|
23
|
+
|
|
24
|
+
If invalid, Node.js will output:
|
|
25
|
+
|
|
26
|
+
- Error message with description
|
|
27
|
+
- Position in file where error occurred
|
|
28
|
+
- Line and column information (if available)
|
|
29
|
+
|
|
30
|
+
## Common Errors and Fixes
|
|
31
|
+
|
|
32
|
+
### Missing Comma
|
|
33
|
+
|
|
34
|
+
```
|
|
35
|
+
SyntaxError: Expected ',' or '}' after property value
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
**Fix:** Add comma after the property value
|
|
39
|
+
|
|
40
|
+
### Missing Bracket/Brace
|
|
41
|
+
|
|
42
|
+
```
|
|
43
|
+
SyntaxError: Unexpected end of JSON input
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
**Fix:** Add missing closing bracket `]` or brace `}`
|
|
47
|
+
|
|
48
|
+
### Extra Comma (Trailing)
|
|
49
|
+
|
|
50
|
+
```
|
|
51
|
+
SyntaxError: Unexpected token ,
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
**Fix:** Remove the trailing comma before `]` or `}`
|
|
55
|
+
|
|
56
|
+
### Missing Quote
|
|
57
|
+
|
|
58
|
+
```
|
|
59
|
+
SyntaxError: Unexpected token
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
**Fix:** Add missing quote around string value
|
|
63
|
+
|
|
64
|
+
## Workflow Integration
|
|
65
|
+
|
|
66
|
+
After saving an Excalidraw file, run validation:
|
|
67
|
+
|
|
68
|
+
1. Save the file
|
|
69
|
+
2. Run: `node -e "JSON.parse(require('fs').readFileSync('{{save_location}}', 'utf8')); console.log('✓ Valid JSON')"`
|
|
70
|
+
3. If validation fails:
|
|
71
|
+
- Read the error message for line/position
|
|
72
|
+
- Open the file at that location
|
|
73
|
+
- Fix the syntax error
|
|
74
|
+
- Save and re-validate
|
|
75
|
+
4. Repeat until validation passes
|
|
76
|
+
|
|
77
|
+
## Critical Rule
|
|
78
|
+
|
|
79
|
+
**NEVER delete the file due to validation errors - always fix the syntax error at the reported location.**
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: bmad-help
|
|
3
|
+
description: Get unstuck by showing what workflow steps come next or answering questions about what to do
|
|
4
|
+
standalone: true
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Task: BMAD Help
|
|
8
|
+
|
|
9
|
+
## KEY RULES
|
|
10
|
+
|
|
11
|
+
- **Empty `phase` = anytime** — Universal tools work regardless of workflow state
|
|
12
|
+
- **Numbered phases indicate sequence** — Phases like `1-discover` → `2-define` → `3-build` → `4-ship` flow in order (naming varies by module)
|
|
13
|
+
- **Stay in module** — Guide through the active module's workflow based on phase+sequence ordering
|
|
14
|
+
- **Descriptions contain routing** — Read for alternate paths (e.g., "back to previous if fixes needed")
|
|
15
|
+
- **`required=true` blocks progress** — Required workflows must complete before proceeding to later phases
|
|
16
|
+
- **Artifacts reveal completion** — Search resolved output paths for `outputs` patterns, fuzzy-match found files to workflow rows
|
|
17
|
+
|
|
18
|
+
## MODULE DETECTION
|
|
19
|
+
|
|
20
|
+
- **Empty `module` column** → universal tools (work across all modules)
|
|
21
|
+
- **Named `module`** → module-specific workflows
|
|
22
|
+
|
|
23
|
+
Detect the active module from conversation context, recent workflows, or user query keywords. If ambiguous, ask the user.
|
|
24
|
+
|
|
25
|
+
## INPUT ANALYSIS
|
|
26
|
+
|
|
27
|
+
Determine what was just completed:
|
|
28
|
+
- Did someone state they completed something? Proceed as if that was the input.
|
|
29
|
+
- Was a workflow just completed in this conversation? Proceed as if that was the input.
|
|
30
|
+
- Search resolved artifact locations for files; fuzzy-match to workflow `outputs` patterns.
|
|
31
|
+
- If an `index.md` exists, read it for additional context.
|
|
32
|
+
- If still unclear, ask: "What workflow did you most recently complete?"
|
|
33
|
+
|
|
34
|
+
## EXECUTION
|
|
35
|
+
|
|
36
|
+
1. **Load catalog** — Load `{project-root}/_bmad/_config/bmad-help.csv`
|
|
37
|
+
|
|
38
|
+
2. **Resolve output locations** — Scan each folder under `_bmad/` (except `_config`) for `config.yaml`. For each workflow row, resolve its `output-location` variables against that module's config so artifact paths can be searched.
|
|
39
|
+
|
|
40
|
+
3. **Analyze input** — Task may provide a workflow name/code, conversational phrase, or nothing. Infer what was just completed using INPUT ANALYSIS above.
|
|
41
|
+
|
|
42
|
+
4. **Detect active module** — Use MODULE DETECTION above to determine which module the user is working in.
|
|
43
|
+
|
|
44
|
+
5. **Present recommendations** — Show next steps based on completed workflows, phase/sequence ordering (KEY RULES), and artifact detection. Format per the following
|
|
45
|
+
|
|
46
|
+
## RECOMMENDED OUTPUT FORMAT
|
|
47
|
+
|
|
48
|
+
**Optional items first** — List optional workflows until a required step is reached
|
|
49
|
+
**Required items next** — List the next required workflow
|
|
50
|
+
For each item show:
|
|
51
|
+
- Workflow **name**
|
|
52
|
+
- **Command** (prefixed with `/`, e.g., `/bmad:example:build-prototype`)
|
|
53
|
+
- **Agent** title and display name from the CSV (e.g., "🎨 Alex (Designer)")
|
|
54
|
+
- Brief **description**
|
|
55
|
+
|
|
56
|
+
### Additional response output guidance to convey:
|
|
57
|
+
- Run each workflow in a **fresh context window**
|
|
58
|
+
- Load the agent using (`/` + `agent-command`), or run the workflow command directly
|
|
59
|
+
- For **validation workflows**: recommend using a different high-quality LLM if available
|
|
60
|
+
- For conversational requests: match the user's tone while presenting clearly
|
|
61
|
+
|
|
62
|
+
6. Return to the calling process after presenting recommendations.
|