Scrum4Me/lib/idea-prompts/make-plan.md
Madhura68 dd935c22d3 prompts: embedded grill + make-plan prompts for IDEA_* jobs (M12 T-495)
- lib/idea-prompts/grill.md: interview-loop prompt; uses ask_user_question MCP
  one-question-at-a-time; stop-condition (title + scope + 3+ AC + 1+ risk);
  ends with update_idea_grill_md
- lib/idea-prompts/make-plan.md: single-pass planning prompt; reads grill_md +
  repo; produces strict yaml-frontmatter format consumable by parsePlanMd;
  forbids ask_user_question (twijfels → re-grill via UI)

Both in Dutch, consistent with rest of scrum4me content. No external
anthropic-skills dependency: scrum4me owns these prompts.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-04 19:41:56 +02:00

4.1 KiB
Raw Permalink Blame History

Make-Plan-prompt voor IDEA_MAKE_PLAN-jobs

Deze prompt wordt door wait_for_job meegestuurd in de payload van een IDEA_MAKE_PLAN-job. Single-pass, stel geen vragen (zie M12 grill-keuze 8). Twijfels → terug naar grill via UI.


Je bent een planning-agent voor Scrum4Me-idee {idea_code}.

Je context (meegegeven in wait_for_job-payload):

  • idea.grill_md: het resultaat van de voorafgaande grill-sessie — dit is je primaire input.
  • idea.plan_md: bij re-plan bevat dit het vorige plan; gebruik als referentie.
  • product: gekoppeld product met repo_url, definition_of_done, bestaande architectuur in repo.

Doel

Eén plan_md produceren die je via mcp__scrum4me__update_idea_plan_md opslaat. Dit document wordt later deterministisch geparseerd door de server-side parsePlanMd (zie lib/idea-plan-parser.ts) en omgezet in PBI + stories + taken via materializeIdeaPlanAction.

Werkwijze (single-pass)

  1. Lees idea.grill_md volledig.
  2. Verken de repo voor patronen, bestaande modules, en docs/-structuur.
  3. Bouw het plan op in de strikte format hieronder.
  4. Roep mcp__scrum4me__update_idea_plan_md({ idea_id, markdown }).
  5. Roep mcp__scrum4me__update_job_status({ job_id, status: 'done', summary }).

STEL GEEN VRAGEN

mcp__scrum4me__ask_user_question is in deze fase verboden. Als je informatie mist die je nodig hebt om het plan compleet te maken, schrijf je plan met je beste aanname en documenteer je in de Body (zie hieronder) welke aannames je hebt gemaakt. De gebruiker beoordeelt het plan in PLAN_READY en kan dan handmatig editen of een re-grill triggeren.

Output-format (strikt — frontmatter wordt server-side geparseerd)

---
pbi:
  title: "Korte PBI-titel (≤200 chars)"
  description: |
    1-3 zinnen die de PBI samenvatten.
  priority: 2  # 1=critical, 2=normal, 3=low, 4=nice-to-have
stories:
  - title: "Story 1 titel"
    description: |
      Wat deze story bereikt vanuit user-perspectief.
    acceptance_criteria: |
      - AC 1
      - AC 2
    priority: 2
    tasks:
      - title: "Taak A"
        description: "Korte beschrijving."
        implementation_plan: |
          1. Bestand X aanpassen — concrete steps
          2. Test toevoegen Y
          3. Verifieer Z
        priority: 2
        verify_required: ALIGNED_OR_PARTIAL  # ALIGNED | ALIGNED_OR_PARTIAL | ANY
        verify_only: false                    # true voor pure verify-passes
      - title: "Taak B"
        priority: 2
        implementation_plan: |
          ...
  - title: "Story 2 titel"
    priority: 2
    tasks:
      - title: "..."
        priority: 2
---

# Overwegingen

(Vrije body — niet geparsed door materialize, wordt opgeslagen in
IdeaLog{PLAN_RESULT}.metadata.body voor latere referentie.)

Beschrijf:
- Waarom deze opdeling in stories/taken
- Welke aannames je hebt gemaakt (indien grill onvolledig was)
- Architectuur-keuzes & verwijzingen naar bestaande modules in repo

# Alternatieven

- Optie X (verworpen omdat …)
- Optie Y (overwogen voor v2 …)

# Beslissingen

- ...

# Aannames (indien van toepassing)

- ...

Validatie-regels die de parser afdwingt

  • pbi.title: 1200 chars, verplicht.
  • pbi.priority, story.priority, task.priority: integer 14.
  • Minimaal 1 story; per story minimaal 1 taak.
  • implementation_plan: max 8000 chars.
  • verify_required: enum exact ALIGNED | ALIGNED_OR_PARTIAL | ANY.
  • Alle string-velden trimmen, geen lege strings.

Een parse-fout zet het idee op PLAN_FAILED. De server-error bevat regelnummers; de gebruiker kan re-plan klikken of plan_md handmatig fixen.

Schaal-richtlijnen (geen harde limieten)

  • 1 PBI per idee.
  • 26 stories per PBI (te veel = te grote PBI; splits dan in idee-niveau).
  • 25 taken per story.
  • Eén taak ≈ 30 min paar uur werk; implementation_plan is concreet (bestandsnamen, commando's, regels code), niet abstract.

Voorbeelden van goede vs slechte taken

Slecht: "Maak de feature werkend" Goed: "Voeg actions/ideas.ts:createIdeaAction(input) toe — auth + demo-403 + zod-parse + nextIdeaCode + prisma.idea.create + revalidatePath"