2.4 KiB
2.4 KiB
Story 4.3: Konferenzzimmer — Live-Execution-UI
Status: done
Story
Als Nutzer, möchte ich im Konferenzzimmer-Tab den laufenden Council in Echtzeit sehen, so dass ich transparent nachvollziehen kann, was die KI gerade tut.
Acceptance Criteria
- Eingabebereich für Prompt-Text und Mode-Toggle (Auto-Pilot / God Mode)
- „Starten"-Button startet Blueprint-Run via
POST /api/councils/{id}/run - WS-Verbindung öffnet sich → aktiver Node pulsiert gelb im Live-Canvas
- Nach Abschluss: finales Dokument erscheint im Output-Bereich
- Bei Fehler: klare Fehlermeldung mit Fehlergrund
- God-Mode-Overlay erscheint bei
status=paused
Tasks / Subtasks
- Task 1:
konferenzzimmer/page.tsxHauptkomponente (AC: 1–6)- Subtask 1.1: Prompt-Eingabe + Blueprint-Auswahl-Dropdown
- Subtask 1.2: Mode-Toggle (Auto-Pilot / God Mode)
- Subtask 1.3:
useCouncilWebSocketHook-Integration - Subtask 1.4: Live-Canvas (read-only React Flow)
- Subtask 1.5: Output-Bereich mit
whitespace-pre-wrap
- Task 2: God-Mode-Overlay-Komponente (AC: 6)
- Subtask 2.1: Approve / Reject / Modify Buttons
- Subtask 2.2: Modify-Modus: Textarea für Draft-Bearbeitung
- Task 3: Blueprint-Run-Endpunkt
POST /api/councils/{id}/run(AC: 2) - Task 4:
GET /api/councils/für Blueprint-Liste im Dropdown
Dev Notes
- Live-Canvas ist schreibgeschützt:
nodesDraggable={false},nodesConnectable={false} markNodeActive(nodeName)sucht Node perdata.label-Übereinstimmung- God-Mode-Overlay:
fixed inset-0Backdrop mit zentriertem Modal
Project Structure Notes
frontend/app/konferenzzimmer/page.tsx- Wiederverwendung:
ArchitectCanvas,useCouncilWebSocket,council-store
References
- [Source: _bmad-output/planning-artifacts/ux-design.md#User-Journey-God-Mode]
- [Source: _bmad-output/planning-artifacts/architecture.md#Sequenzdiagramm-Council-Run]
Dev Agent Record
Agent Model Used
Amelia (💻 BMAD Dev Agent)
Completion Notes List
- Polling-Fallback für Blueprint-Liste:
councilApi.list()beim Mount einmalig aufgerufen. - God-Mode-Overlay nutzt
onPaused-Callback aususeCouncilWebSocket.
File List
frontend/app/konferenzzimmer/page.tsx