This commit is contained in:
team3
2026-06-14 12:24:49 +02:00
parent 8382d6f27a
commit 822f6ee3e9
10 changed files with 266 additions and 59 deletions

View File

@@ -95,7 +95,7 @@ async function startPruefung() {
topic: props.topic, baustein: props.baustein, section: props.section,
messages: [], provider: props.provider,
})
pruefung.messages.value.push({ role: 'assistant', content: res.reply })
pruefung.messages.value.push({ role: 'assistant', content: res.frage, feedback: null })
applyPruefung(res)
nextTick(() => pruefung.inputEl.value?.focus())
} catch {
@@ -175,7 +175,10 @@ async function startPruefung() {
<div :ref="pruefung.messagesEl" class="bp-messages">
<div v-if="startLoading" class="bp-msg assistant bp-typing">Erste Frage kommt</div>
<template v-for="(m, i) in pruefung.messages.value" :key="i">
<div v-if="m.role === 'assistant'" class="bp-msg assistant markdown" v-html="renderMarkdown(m.content)"></div>
<template v-if="m.role === 'assistant'">
<div v-if="m.feedback" class="bp-feedback" :class="m.bewertung">{{ m.feedback }}</div>
<div class="bp-msg assistant markdown" v-html="renderMarkdown(m.content)"></div>
</template>
<div v-else class="bp-msg user">{{ m.content }}</div>
</template>
<div v-if="pruefung.loading.value" class="bp-msg assistant bp-typing">Bewertet</div>
@@ -260,6 +263,19 @@ async function startPruefung() {
.bp-msg.assistant { align-self: flex-start; background: var(--panel); border: 1px solid var(--border); }
.bp-typing { color: var(--text-faint); font-style: italic; }
/* Bewertung der letzten Antwort — getrennt über der nächsten Frage */
.bp-feedback {
align-self: flex-start;
max-width: 88%;
padding: 0.3rem 0.6rem;
border-radius: 8px;
font-size: 0.82rem;
line-height: 1.4;
border: 1px solid var(--border);
}
.bp-feedback.gut { background: var(--success-soft); border-color: var(--success-border); color: var(--success); }
.bp-feedback.schlecht { background: var(--danger-soft, #fee2e2); border-color: var(--danger-border, #f87171); color: var(--danger); }
.bp-input { display: flex; gap: 0.4rem; margin-top: 0.55rem; align-items: flex-end; }
.bp-input textarea {
flex: 1;