- Aanpassing layout van de chat-input. Character counter is ook weg op desktop. Scrollbar enkel zichtbaar indien nodig. Meer beschikbare ruimte in mobiele client. kleinere radius in de hoeken.
- Gewijzigde logica voor hoogtebepaling chat-input en message history, zodat ook de mobiele client correct functioneert.
This commit is contained in:
@@ -42,6 +42,7 @@
|
||||
ref="messageInput"
|
||||
v-model="localMessage"
|
||||
@keydown="handleKeydown"
|
||||
@focus="autoResize"
|
||||
:placeholder="translatedPlaceholder"
|
||||
rows="1"
|
||||
:disabled="isLoading"
|
||||
@@ -50,10 +51,6 @@
|
||||
:class="{ 'over-limit': isOverLimit }"
|
||||
></textarea>
|
||||
|
||||
<!-- Character counter -->
|
||||
<div v-if="maxLength" class="character-counter" :class="{ 'over-limit': isOverLimit }">
|
||||
{{ characterCount }}/{{ maxLength }}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Input actions -->
|
||||
@@ -142,12 +139,8 @@ export default {
|
||||
};
|
||||
},
|
||||
computed: {
|
||||
characterCount() {
|
||||
return this.localMessage.length;
|
||||
},
|
||||
|
||||
isOverLimit() {
|
||||
return this.characterCount > this.maxLength;
|
||||
return this.localMessage.length > this.maxLength;
|
||||
},
|
||||
|
||||
hasFormData() {
|
||||
@@ -239,12 +232,15 @@ export default {
|
||||
if (this.formData) {
|
||||
console.log('FormData bij mount:', JSON.stringify(this.formData));
|
||||
}
|
||||
// Herbereken bij viewport-wijziging (bv. rotatie op mobiel)
|
||||
window.addEventListener('resize', this.autoResize, { passive: true });
|
||||
},
|
||||
beforeUnmount() {
|
||||
// Verwijder event listener bij unmount met de benoemde handler
|
||||
if (this.languageChangeHandler) {
|
||||
document.removeEventListener('language-changed', this.languageChangeHandler);
|
||||
}
|
||||
window.removeEventListener('resize', this.autoResize);
|
||||
},
|
||||
methods: {
|
||||
handleLanguageChange(event) {
|
||||
@@ -285,6 +281,8 @@ export default {
|
||||
} finally {
|
||||
// Reset de vertaling vlag
|
||||
this.isTranslating = false;
|
||||
// Herbereken hoogte na vertaling
|
||||
this.$nextTick(this.autoResize);
|
||||
}
|
||||
},
|
||||
|
||||
@@ -465,9 +463,9 @@ export default {
|
||||
.message-input {
|
||||
width: 100%;
|
||||
min-height: 40px;
|
||||
padding: 10px 60px 10px 15px; /* Meer rechter padding voor character counter */
|
||||
padding: 10px 15px 10px 15px; /* counter verwijderd -> rechter padding omlaag */
|
||||
border: 1px solid #ddd;
|
||||
border-radius: 20px;
|
||||
border-radius: 10px;
|
||||
resize: none;
|
||||
outline: none;
|
||||
transition: border-color 0.2s;
|
||||
@@ -478,35 +476,17 @@ export default {
|
||||
color: var(--human-message-text-color);
|
||||
/* Box-sizing om padding correct te berekenen */
|
||||
box-sizing: border-box;
|
||||
/* Laat intern scrollen toe bij >120px, maar verberg scrollbar visueel */
|
||||
overflow: auto;
|
||||
-webkit-overflow-scrolling: touch; /* soepel scrollen op iOS */
|
||||
scrollbar-width: none; /* Firefox: verberg scrollbar */
|
||||
}
|
||||
|
||||
/* Character counter */
|
||||
.character-counter {
|
||||
position: absolute;
|
||||
right: 15px;
|
||||
bottom: 12px;
|
||||
font-size: 12px;
|
||||
color: var(--human-message-text-color);
|
||||
opacity: 0.7;
|
||||
pointer-events: none; /* Voorkom dat deze de textarea verstoort */
|
||||
/* WebKit/Chromium: scrollbar verbergen */
|
||||
.message-input::-webkit-scrollbar {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* Character counter wordt rood bij overschrijding */
|
||||
.character-counter.over-limit {
|
||||
color: #ff4d4f;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
/* Verberg character counter op mobile */
|
||||
@media (max-width: 768px) {
|
||||
.character-counter {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.message-input {
|
||||
padding-right: 15px; /* Verminder van 60px naar 15px omdat counter weg is */
|
||||
}
|
||||
}
|
||||
|
||||
/* Input actions */
|
||||
.input-actions {
|
||||
|
||||
Reference in New Issue
Block a user