response.php

Code Hygiene Score: 100

Keine Issues gefunden.

Versionen 5

Code

<?php
/**
 * HTMX Response Partial - Renders both user question and assistant response
 * Uses same CSS classes as index.php for consistent styling
 *
 * @var string $question The user's question
 * @var array $result AI response with 'answer', 'sources', 'usage'
 * @var string $model The model used
 * @var string $formattedAnswer Pre-formatted answer HTML
 */

$answer = $formattedAnswer ?? htmlspecialchars($result['answer'] ?? '');
$sources = $result['sources'] ?? [];
$usage = $result['usage'] ?? null;
$isOllama = str_starts_with($model, 'ollama:');
$modelLabel = $isOllama ? substr($model, 7) : $model;

$inputTokens = (int) ($usage['input_tokens'] ?? 0);
$outputTokens = (int) ($usage['output_tokens'] ?? 0);
$cost = ($inputTokens * 0.000015) + ($outputTokens * 0.000075);

$qualityValidation = $result['quality_validation'] ?? null;
$uniqueId = uniqid('sources-');
?>
<!-- User Message -->
<div class="chat-msg chat-msg--user">
    <div class="chat-msg__content"><?= htmlspecialchars($question) ?></div>
</div>

<!-- Assistant Message -->
<div class="chat-msg chat-msg--assistant">
    <div class="chat-msg__content">
        <?= $answer ?>

        <?php if ($qualityValidation !== null): ?>
        <div class="chat-quality chat-quality--<?= $qualityValidation['passed'] ? 'passed' : 'failed' ?>"
             title="<?= htmlspecialchars($qualityValidation['details'] ?? '') ?>">
            <span class="chat-quality__icon"><?= $qualityValidation['passed'] ? '✓' : '⚠' ?></span>
            <span class="chat-quality__score"><?= round($qualityValidation['score'] ?? 0) ?>%</span>
            <?php if (!empty($qualityValidation['issues'])): ?>
            <div class="chat-quality__issues">
                <strong>Hinweise:</strong>
                <ul>
                <?php foreach ($qualityValidation['issues'] as $issue): ?>
                    <li><?= htmlspecialchars($issue) ?></li>
                <?php endforeach; ?>
                </ul>
            </div>
            <?php endif; ?>
        </div>
        <?php endif; ?>

        <?php if (!empty($sources)): ?>
        <div class="chat-sources" id="<?= $uniqueId ?>">
            <button type="button" class="chat-sources__toggle" onclick="this.parentElement.classList.toggle('chat-sources--open')">
                <?= count($sources) ?> Quelle<?= count($sources) > 1 ? 'n' : '' ?> &#9662;
            </button>
            <div class="chat-sources__list">
                <?php foreach ($sources as $source): ?>
                <div class="chat-source">
                    <div class="chat-source__header">
                        <?php if (!empty($source['collection'])): ?>
                        <span class="chat-source__collection">[<?= htmlspecialchars($source['collection']) ?>]</span>
                        <?php endif; ?>
                        <span class="chat-source__title"><?= htmlspecialchars($source['title'] ?? 'Unbekannt') ?></span>
                        <span class="chat-source__score"><?= round(($source['score'] ?? 0) * \Domain\Constants::PERCENT_FULL) ?>%</span>
                    </div>
                    <?php if (!empty($source['content'])): ?>
                    <div class="chat-source__content">"<?= htmlspecialchars(mb_substr($source['content'], 0, 200)) ?><?= mb_strlen($source['content']) > 200 ? '...' : '' ?>"</div>
                    <?php endif; ?>
                </div>
                <?php endforeach; ?>
            </div>
        </div>
        <?php endif; ?>

        <div class="chat-msg__meta">
            <span><?= htmlspecialchars($modelLabel) ?></span>
            <?php if (!$isOllama && ($inputTokens > 0 || $outputTokens > 0)): ?>
            <span class="chat-msg__tokens">&darr;<?= number_format($inputTokens) ?> &uarr;<?= number_format($outputTokens) ?></span>
            <span class="chat-msg__cost">~$<?= number_format($cost, 4) ?></span>
            <?php elseif ($isOllama): ?>
            <span class="chat-msg__local">lokal</span>
            <?php endif; ?>
        </div>

        <div class="chat-msg__actions">
            <form method="POST" action="/chat/promote" class="chat-promote-form">
                <input type="hidden" name="question" value="<?= htmlspecialchars($question) ?>">
                <input type="hidden" name="answer" value="<?= htmlspecialchars($result['answer'] ?? '') ?>">
                <input type="hidden" name="model" value="<?= htmlspecialchars($model) ?>">
                <input type="hidden" name="_csrf_token" value="<?= htmlspecialchars($_SESSION['_csrf_token'] ?? '') ?>">
                <button type="submit" class="chat-promote-btn" title="Als Content-Projekt weiterentwickeln">
                    <span class="chat-promote-btn__icon">&#8599;</span>
                    <span class="chat-promote-btn__text">Promote to Content</span>
                </button>
            </form>
        </div>
    </div>
</div>
← Übersicht