- Task-ID:
--
+
+
-
-
+
+
+ Warteschlange:
+ 0
+ Anfrage(n)
+
+
+ Geschätzte Zeit:
+ --
+
+
+
+
@@ -258,29 +268,31 @@ document.addEventListener('DOMContentLoaded', () => {
}
}
- // Smart Prompting Functions - Simplified
function showPromptingStatus(state) {
if (!smartPromptingContainer || !promptingStatus || !promptingSpinner) return;
+ const statusText = promptingStatus.querySelector('.status-text');
+ if (!statusText) return;
+
switch (state) {
case 'analyzing':
smartPromptingContainer.style.display = 'block';
- promptingStatus.textContent = '💡 KI analysiert Ihre Eingabe...';
+ statusText.textContent = 'Analysiere Eingabe...';
promptingSpinner.style.display = 'inline-block';
suggestedQuestions.style.display = 'none';
break;
case 'suggestions':
- promptingStatus.textContent = '✅ Verbesserungsvorschläge verfügbar';
+ statusText.textContent = 'Verbesserungsvorschläge verfügbar';
promptingSpinner.style.display = 'none';
suggestedQuestions.style.display = 'block';
break;
case 'rate-limited':
- promptingStatus.textContent = '⏸️ Verbesserungen nach Hauptabfrage verfügbar';
+ statusText.textContent = 'Nach Hauptabfrage verfügbar';
promptingSpinner.style.display = 'none';
suggestedQuestions.style.display = 'none';
break;
case 'error':
- smartPromptingContainer.style.display = 'none'; // Just hide on error
+ smartPromptingContainer.style.display = 'none';
break;
case 'hidden':
smartPromptingContainer.style.display = 'none';
@@ -293,15 +305,10 @@ document.addEventListener('DOMContentLoaded', () => {
questionsList.innerHTML = '';
- suggestions.forEach((question, index) => {
+ suggestions.forEach((question) => {
const questionElement = document.createElement('div');
questionElement.className = 'suggestion-item';
-
- questionElement.innerHTML = `
-
${index + 1}.
- ${question}
- `;
-
+ questionElement.textContent = question;
questionsList.appendChild(questionElement);
});
diff --git a/src/styles/global.css b/src/styles/global.css
index 976fce0..6383ef9 100644
--- a/src/styles/global.css
+++ b/src/styles/global.css
@@ -967,6 +967,23 @@ input[type="checkbox"] {
transition: var(--transition-fast);
}
+.ai-input-layout {
+ display: flex;
+ gap: 1.5rem;
+ align-items: flex-start;
+ margin-bottom: 1rem;
+}
+
+.ai-textarea-section {
+ flex: 1;
+ min-width: 0;
+}
+
+.ai-suggestions-section {
+ flex: 0 0 320px;
+ min-height: 120px;
+}
+
.ai-input-container textarea:focus {
outline: none;
border-color: var(--color-primary);
@@ -1922,46 +1939,139 @@ footer {
.kb-entry .flex.gap-2 {
gap: 0.5rem;
}
+ .ai-input-layout {
+ gap: 0.75rem;
+ }
+
+ .prompting-card {
+ padding: 0.75rem;
+ }
+
+ .suggestion-item {
+ padding: 0.375rem 0.5rem;
+ font-size: 0.75rem;
+ }
+
+ .position-badge {
+ width: 28px;
+ height: 28px;
+ font-size: 0.875rem;
+ }
+
+ .queue-status-card {
+ padding: 1rem;
+ }
}
/* Smart Prompting Styles - Simplified */
.smart-prompting-container {
- margin-top: 1rem;
+ height: 100%;
animation: smartPromptSlideIn 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
+.prompting-card {
+ background-color: var(--color-bg-tertiary);
+ border: 1px solid var(--color-border);
+ border-radius: 0.5rem;
+ padding: 1rem;
+ height: 100%;
+ min-height: 120px;
+ display: flex;
+ flex-direction: column;
+ opacity: 0.85;
+ transition: var(--transition-fast);
+}
+
+.prompting-card:hover {
+ opacity: 1;
+ border-color: var(--color-accent);
+}
+
.prompting-status {
display: flex;
align-items: center;
gap: 0.5rem;
margin-bottom: 0.75rem;
+ padding-bottom: 0.75rem;
+ border-bottom: 1px solid var(--color-border);
+}
+
+.status-icon {
+ font-size: 1rem;
+ flex-shrink: 0;
+}
+
+.status-text {
+ font-size: 0.8125rem;
font-weight: 500;
color: var(--color-text);
+ flex: 1;
}
.prompting-spinner {
- display: inline-block;
+ flex-shrink: 0;
animation: spin 1s linear infinite;
}
.suggested-questions {
+ flex: 1;
+ display: flex;
+ flex-direction: column;
+}
+
+.suggestions-header {
+ margin-bottom: 0.75rem;
+}
+
+.suggestions-label {
+ font-size: 0.75rem;
+ color: var(--color-text-secondary);
+ font-weight: 500;
+ text-transform: uppercase;
+ letter-spacing: 0.025em;
+}
+
+.questions-list {
+ flex: 1;
display: flex;
flex-direction: column;
gap: 0.5rem;
+ margin-bottom: 0.75rem;
}
.suggestion-item {
- background-color: var(--color-bg-secondary);
- border: 1px solid var(--color-border);
+ background-color: var(--color-bg);
+ border: 1px solid transparent;
border-radius: 0.375rem;
- padding: 0.75rem;
- font-size: 0.875rem;
- line-height: 1.5;
- color: var(--color-text);
- border-left: 3px solid var(--color-accent);
+ padding: 0.5rem 0.75rem;
+ font-size: 0.8125rem;
+ line-height: 1.4;
+ color: var(--color-text-secondary);
+ border-left: 2px solid var(--color-accent);
transition: var(--transition-fast);
+ position: relative;
}
+.suggestion-item::before {
+ content: counter(suggestion-counter);
+ counter-increment: suggestion-counter;
+ position: absolute;
+ left: -8px;
+ top: -6px;
+ background-color: var(--color-accent);
+ color: white;
+ width: 16px;
+ height: 16px;
+ border-radius: 50%;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ font-size: 0.625rem;
+ font-weight: 600;
+}
+.questions-list {
+ counter-reset: suggestion-counter;
+}
.suggestion-number {
color: var(--color-accent);
@@ -1969,17 +2079,161 @@ footer {
margin-right: 0.5rem;
}
-/* Improved animation - smoother and simpler */
+.dismiss-button {
+ align-self: flex-end;
+ background: none;
+ border: none;
+ color: var(--color-text-secondary);
+ cursor: pointer;
+ padding: 0.25rem;
+ border-radius: 0.25rem;
+ transition: var(--transition-fast);
+ opacity: 0.7;
+}
+
+.dismiss-button:hover {
+ background-color: var(--color-bg-secondary);
+ color: var(--color-text);
+ opacity: 1;
+}
+
+/* Queue Status - Improved Design */
+.queue-status-card {
+ max-width: 400px;
+ margin: 1.5rem auto 0;
+ background: linear-gradient(135deg, var(--color-bg-secondary) 0%, var(--color-bg-tertiary) 100%);
+ border: 1px solid var(--color-border);
+ border-radius: 0.75rem;
+ padding: 1.25rem;
+ box-shadow: var(--shadow-sm);
+}
+
+.queue-header {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ margin-bottom: 1rem;
+}
+
+.queue-position-display {
+ display: flex;
+ align-items: center;
+ gap: 0.75rem;
+}
+
+.position-badge {
+ width: 32px;
+ height: 32px;
+ background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);
+ color: white;
+ border-radius: 50%;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ font-weight: 700;
+ font-size: 1rem;
+ box-shadow: var(--shadow-sm);
+}
+
+.position-label {
+ font-weight: 600;
+ color: var(--color-text);
+ font-size: 0.9375rem;
+}
+
+.queue-details {
+ display: grid;
+ grid-template-columns: 1fr 1fr;
+ gap: 1rem;
+ margin-bottom: 1.25rem;
+}
+
+.queue-stat {
+ text-align: center;
+ padding: 0.75rem;
+ background-color: var(--color-bg);
+ border-radius: 0.5rem;
+ border: 1px solid var(--color-border);
+}
+
+.stat-label {
+ display: block;
+ font-size: 0.75rem;
+ color: var(--color-text-secondary);
+ margin-bottom: 0.25rem;
+ font-weight: 500;
+}
+
+.stat-value {
+ font-size: 1.125rem;
+ font-weight: 700;
+ color: var(--color-primary);
+}
+
+.stat-unit {
+ font-size: 0.75rem;
+ color: var(--color-text-secondary);
+ margin-left: 0.25rem;
+}
+
+.queue-progress-container {
+ position: relative;
+}
+
+.queue-progress-track {
+ background-color: var(--color-bg);
+ border-radius: 8px;
+ height: 6px;
+ overflow: hidden;
+ border: 1px solid var(--color-border);
+ margin-bottom: 0.75rem;
+}
+
+.queue-progress-fill {
+ height: 100%;
+ background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
+ width: 0%;
+ transition: width 0.3s ease;
+ border-radius: 8px;
+}
+
+.task-id-display {
+ text-align: center;
+ padding: 0.5rem;
+ background-color: var(--color-bg);
+ border-radius: 0.375rem;
+ border: 1px solid var(--color-border);
+}
+
+.task-label {
+ font-size: 0.6875rem;
+ color: var(--color-text-secondary);
+ margin-right: 0.5rem;
+ text-transform: uppercase;
+ letter-spacing: 0.025em;
+ font-weight: 500;
+}
+
+.task-id {
+ font-family: 'SF Mono', 'Monaco', 'Menlo', 'Consolas', monospace;
+ font-size: 0.6875rem;
+ color: var(--color-text);
+ background-color: var(--color-bg-secondary);
+ padding: 0.125rem 0.375rem;
+ border-radius: 0.25rem;
+ border: 1px solid var(--color-border);
+}
+
@keyframes smartPromptSlideIn {
from {
opacity: 0;
- transform: translateY(-10px);
+ transform: translateX(20px);
max-height: 0;
}
to {
- opacity: 1;
- transform: translateY(0);
- max-height: 200px;
+ opacity: 0.85;
+ transform: translateX(0);
+ max-height: 300px;
}
}