update
This commit is contained in:
@@ -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;
|
||||
|
||||
@@ -52,7 +52,13 @@ export function useChat(performRequest) {
|
||||
try {
|
||||
const res = await performRequest(messages.value)
|
||||
if (current !== run) return null
|
||||
messages.value.push({ role: 'assistant', content: res.reply || '…' })
|
||||
// Prüfung liefert `frage` (+ getrenntes `feedback`); andere Chats `reply`.
|
||||
messages.value.push({
|
||||
role: 'assistant',
|
||||
content: res.frage ?? res.reply ?? '…',
|
||||
feedback: res.feedback ?? null,
|
||||
bewertung: res.bewertung ?? null,
|
||||
})
|
||||
return res
|
||||
} catch {
|
||||
if (current !== run) return null
|
||||
|
||||
Reference in New Issue
Block a user