add system prompt and chunks index views and edit

This commit is contained in:
team2
2026-02-15 21:33:31 +01:00
parent 59e48242b5
commit 3416678cf4
12 changed files with 743 additions and 7 deletions

View File

@@ -33,7 +33,17 @@
</li>
<li class="nav-item">
<a class="nav-link text-light" href="{{ path('admin_jobs') }}">
Ingest Jobs
Indexierung Jobs (Ingest)
</a>
</li>
<li class="nav-item">
<a class="nav-link text-light" href="{{ path('admin_system_agent') }}">
Wissen (Chunk-Index)
</a>
</li>
<li class="nav-item">
<a class="nav-link text-light" href="{{ path('admin_system_prompt') }}">
System Prompt Settings
</a>
</li>
</ul>

View File

@@ -0,0 +1,135 @@
{% extends 'admin/base.html.twig' %}
{% block title %}Agent System Overview{% endblock %}
{% block body %}
<a href="{{ path('admin_dashboard') }}"
class="btn btn-sm btn-outline-light mb-3">
← Zurück
</a>
<h1 class="h4 mb-4">Agent System Overview</h1>
{# ============================= #}
{# Index Meta Section #}
{# ============================= #}
<div class="card bg-black text-info border-secondary mb-4"{#>
<div class="card-body">
<h5 class="mb-3">Index Meta (index_meta.json)</h5>
{% if meta.error is defined %}
<div class="alert alert-danger">
<strong>Fehler:</strong><br>
{{ meta.error }}<br>
<small>{{ meta.path }}</small>
</div>
{% else %}
<table class="table table-dark table-sm table-bordered align-middle mb-0">
<tbody>
{% for key, value in meta %}
<tr>
<th style="width:280px;">{{ key }}</th>
<td>
{% if value is iterable %}
<pre class="mb-0 text-info">
{{ value|json_encode(constant('JSON_PRETTY_PRINT')) }}
</pre>
{% else %}
{{ value }}
{% endif %}
</td>
</tr>
{% endfor %}
</tbody>
</table>
{% endif %}
</div>
</div>#}
{# ============================= #}
{# NDJSON Section #}
{# ============================= #}
{% set currentPage = ndjson.page|default(1) %}
{% set currentLimit = ndjson.limit|default(50) %}
<div class="card bg-black text-info border-secondary mb-4">
<div class="card-body">
<div class="d-flex justify-content-between align-items-center mb-3">
<h5 class="mb-0">NdJson Index Übersicht Chunks (index.ndjson)</h5>
<div>
<a href="{{ path('admin_system_agent', {page: (currentPage - 1 < 1 ? 1 : currentPage - 1), limit: currentLimit}) }}"
class="btn btn-sm btn-outline-light">
← Zurück
</a>
<a href="{{ path('admin_system_agent', {page: currentPage + 1, limit: currentLimit}) }}"
class="btn btn-sm btn-outline-light">
Weiter →
</a>
</div>
</div>
{% if ndjson.error %}
<div class="alert alert-danger">
<strong>Fehler:</strong><br>
{{ ndjson.error }}<br>
<small>{{ ndjson.path|default('-') }}</small>
</div>
{% endif %}
<div class="mb-2 text-secondary">
Datei vorhanden: {{ ndjson.path ? 'JA' : 'NEIN' }} |
Geladene Einträge: {{ debugCount|default(0) }} |
Seite {{ currentPage }} • Limit {{ currentLimit }}
</div>
<div class="table-responsive">
<table class="table table-dark table-sm table-bordered align-middle">
<thead>
<tr>
<th style="width:220px;">chunk_id</th>
<th style="width:180px;">document_id</th>
<th>text (gekürzt)</th>
</tr>
</thead>
<tbody>
{% for item in ndjson.items|default([]) %}
<tr>
<td>{{ item.chunk_id ?? '-' }}</td>
<td>{{ item.document_id ?? '-' }}</td>
<td>
{% set text = item.text ?? '' %}
{{ text|slice(0, 240) }}{% if text|length > 240 %}{% endif %}
<details class="mt-2">
<summary class="text-secondary" style="cursor:pointer;">
JSON anzeigen
</summary>
<pre class="bg-dark text-info p-2 border border-secondary rounded mt-2">
{{ item|json_encode(constant('JSON_PRETTY_PRINT')) }}
</pre>
</details>
</td>
</tr>
{% else %}
<tr>
<td colspan="3" class="text-secondary">
Keine Einträge gefunden.
</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
</div>
</div>
{% endblock %}

View File

@@ -0,0 +1,104 @@
{% extends 'admin/base.html.twig' %}
{% block title %}System Prompt{% endblock %}
{% block body %}
<h1 class="h4 mb-4">System Prompt</h1>
{% for message in app.flashes('success') %}
<div class="alert alert-success">{{ message }}</div>
{% endfor %}
{% for message in app.flashes('danger') %}
<div class="alert alert-danger">{{ message }}</div>
{% endfor %}
<div class="card bg-black text-info border-secondary mb-4">
<div class="card-body">
<form method="post">
<div class="mb-3">
<label class="form-label">Kommentar (optional)</label>
<input type="text"
name="comment"
class="form-control bg-dark text-info border-secondary"
placeholder="Warum wurde der Prompt geändert?">
</div>
<div class="mb-3">
<label class="form-label">Prompt Inhalt</label>
<textarea name="content"
rows="16"
class="form-control bg-dark text-info border-secondary"
>{{ active ? active.content : '' }}</textarea>
</div>
<button class="btn btn-outline-light">
Neue Version speichern
</button>
</form>
</div>
</div>
<div class="card bg-black text-info border-secondary">
<div class="card-body">
<h5>Versionen</h5>
<table class="table table-dark table-sm table-bordered align-middle">
<thead>
<tr>
<th>Version</th>
<th>Aktiv</th>
<th>Kommentar</th>
<th>Erstellt</th>
<th>Aktionen</th>
</tr>
</thead>
<tbody>
{% for p in all %}
<tr>
<td>{{ p.version }}</td>
<td>
{% if p.active %}
<span class="badge bg-success">ACTIVE</span>
{% endif %}
</td>
<td>{{ p.comment ?? '-' }}</td>
<td>{{ p.createdAt|date('d.m.Y H:i:s') }}</td>
<td>
{% if not p.active %}
<form method="post"
action="{{ path('admin_system_prompt_activate', {id: p.id}) }}"
style="display:inline-block;">
<button class="btn btn-sm btn-outline-light">
Aktivieren
</button>
</form>
<form method="post"
action="{{ path('admin_system_prompt_delete', {id: p.id}) }}"
style="display:inline-block;"
onsubmit="return confirm('Version wirklich löschen?');">
<button class="btn btn-sm btn-outline-danger">
Löschen
</button>
</form>
{% else %}
-
{% endif %}
</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
</div>
{% endblock %}