Merge branch 'release/v3.1.2-beta'

This commit is contained in:
Josako
2025-09-23 10:14:09 +02:00
13 changed files with 310 additions and 189 deletions

View File

@@ -5,6 +5,11 @@ All notable changes to EveAI will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [3.1.2-beta]
### Changed
- Several improvements to the mobile version of the chat client
## [3.1.1-alfa] ## [3.1.1-alfa]
### Fixed ### Fixed

View File

@@ -155,18 +155,7 @@
} }
/* Zorg dat de progress tracker goed wordt weergegeven in een lege message bubble */ /* Zorg dat de progress tracker goed wordt weergegeven in een lege message bubble */
.message-content:has(.message-text:empty) .message-progress { /* moved to ChatMessage.vue scoped styles */
margin-bottom: 0;
}
/* Verberg de message content container als er geen inhoud is en de verwerking bezig is */
.message-content:has(.message-text:empty):not(:has(.message-progress.completed)):not(:has(.message-progress.error)) {
background: transparent;
box-shadow: none;
border: none;
padding: 0;
margin: 0;
}
/* Focus binnen ChatInput voor toegankelijkheid */ /* Focus binnen ChatInput voor toegankelijkheid */
.chat-input:focus-within { .chat-input:focus-within {
@@ -208,33 +197,7 @@
justify-content: flex-start; justify-content: flex-start;
} }
/* Message content wrapper - dit wordt de bubble */ /* moved to ChatMessage.vue scoped styles */
.message-content {
max-width: 70%;
padding: 12px 16px;
border-radius: 18px;
word-wrap: break-word;
position: relative;
box-shadow: 0 2px 8px rgba(0,0,0,0.1);
transition: all 0.2s ease;
display: inline-block;
}
/* User message bubble styling */
.message.user .message-content {
background: var(--human-message-background);
color: var(--human-message-text-color);
border-bottom-right-radius: 4px;
}
/* AI/Bot message bubble styling */
.message.ai .message-content,
.message.bot .message-content {
background: var(--ai-message-background);
color: var(--ai-message-text-color);
border-bottom-left-radius: 4px;
margin-right: 60px;
}
/* Message text content */ /* Message text content */
.message-text { .message-text {
@@ -435,10 +398,7 @@
} }
/* Hover effects voor message bubbles */ /* Hover effects voor message bubbles */
.message-content:hover { /* moved to ChatMessage.vue scoped styles */
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
/* Bestaande animation en date-separator blijven hetzelfde */ /* Bestaande animation en date-separator blijven hetzelfde */
@keyframes messageSlideIn { @keyframes messageSlideIn {
@@ -483,11 +443,7 @@
padding: 0 15px; padding: 0 15px;
} }
.message-content { /* moved to ChatMessage.vue scoped styles */
max-width: 85%;
padding: 10px 14px;
font-size: 14px;
}
.message.user .message-content { .message.user .message-content {
margin-left: 40px; margin-left: 40px;
@@ -504,11 +460,7 @@
padding: 0 10px; padding: 0 10px;
} }
.message-content { /* moved to ChatMessage.vue scoped styles */
max-width: 90%;
margin-left: 20px !important;
margin-right: 20px !important;
}
} }
/* Progress Tracker Styling */ /* Progress Tracker Styling */

View File

@@ -15,11 +15,7 @@
margin-right: auto; margin-right: auto;
} }
.message-content { /* moved to ChatMessage.vue scoped styles */
width: 100%;
font-family: Arial, sans-serif;
font-size: 14px;
}
/* Tabel styling voor formulieren */ /* Tabel styling voor formulieren */
.form-result-table { .form-result-table {

View File

@@ -14,7 +14,8 @@
/* App container layout */ /* App container layout */
.app-container { .app-container {
display: flex; display: flex;
height: 100vh; height: 100vh; /* fallback */
height: 100dvh; /* prefer dynamic viewport unit */
width: 100%; width: 100%;
} }
@@ -80,9 +81,23 @@
.content-area { .content-area {
flex: 1; flex: 1;
background: linear-gradient(135deg, var(--gradient-start-color), var(--gradient-end-color)); background: linear-gradient(135deg, var(--gradient-start-color), var(--gradient-end-color));
overflow-y: auto; overflow-y: hidden;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
min-height: 0;
height: 100vh; /* fallback for desktop */
height: 100dvh; /* prefer dynamic viewport on desktop */
}
.chat-container {
display: flex;
flex-direction: column;
flex: 1;
min-height: 0; /* laat kinderen (ChatApp) krimpen */
}
html, body {
height: 100%;
} }
body { body {
@@ -203,15 +218,7 @@ body {
/* .message-content wordt nu gedefinieerd in chat-components.css */ /* .message-content wordt nu gedefinieerd in chat-components.css */
.user-message .message-content { /* moved to ChatMessage.vue scoped styles */
background-color: var(--message-user-bg);
color: var(--text-color);
}
.bot-message .message-content {
background-color: var(--message-bot-bg);
color: var(--text-color);
}
/* .chat-input-container wordt nu gedefinieerd in chat-components.css */ /* .chat-input-container wordt nu gedefinieerd in chat-components.css */
@@ -273,10 +280,14 @@ body {
width: 100%; width: 100%;
} }
:root { --mobile-header-height: 60px; } /* default/minimum */
/* Content area takes remaining space */ /* Content area takes remaining space */
.content-area { .content-area {
flex: 1; flex: 1;
height: calc(100vh - 60px); /* Subtract mobile header height */ height: calc(100vh - var(--mobile-header-height)); /* fallback */
height: calc(100dvh - var(--mobile-header-height)); /* prefer dynamic viewport */
min-height: 0;
} }
} }

View File

@@ -54,6 +54,4 @@
word-break: break-word; word-break: break-word;
} }
.message-content { /* moved to ChatMessage.vue scoped styles */
max-width: 100%;
}

View File

@@ -553,7 +553,8 @@ export default {
.chat-app-container { .chat-app-container {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
height: 100vh; flex: 1;
/* height: 100%; avoided to let flex sizing control height */
width: 100%; width: 100%;
min-height: 0; min-height: 0;
max-width: 1000px; max-width: 1000px;
@@ -561,10 +562,12 @@ export default {
margin-right: auto; margin-right: auto;
padding: 20px; padding: 20px;
box-sizing: border-box; box-sizing: border-box;
overflow: hidden;
} }
.chat-messages-area { .chat-messages-area {
flex: 1; flex: 1;
min-height: 0; /* ensure child can scroll */
overflow: hidden; overflow: hidden;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@@ -585,10 +588,4 @@ export default {
flex: 0 0 auto; flex: 0 0 auto;
} }
/* Responsive adjustments */
@media (max-width: 768px) {
.chat-app-container {
height: 100vh;
}
}
</style> </style>

View File

@@ -42,6 +42,7 @@
ref="messageInput" ref="messageInput"
v-model="localMessage" v-model="localMessage"
@keydown="handleKeydown" @keydown="handleKeydown"
@focus="autoResize"
:placeholder="translatedPlaceholder" :placeholder="translatedPlaceholder"
rows="1" rows="1"
:disabled="isLoading" :disabled="isLoading"
@@ -50,10 +51,6 @@
:class="{ 'over-limit': isOverLimit }" :class="{ 'over-limit': isOverLimit }"
></textarea> ></textarea>
<!-- Character counter -->
<div v-if="maxLength" class="character-counter" :class="{ 'over-limit': isOverLimit }">
{{ characterCount }}/{{ maxLength }}
</div>
</div> </div>
<!-- Input actions --> <!-- Input actions -->
@@ -142,12 +139,8 @@ export default {
}; };
}, },
computed: { computed: {
characterCount() {
return this.localMessage.length;
},
isOverLimit() { isOverLimit() {
return this.characterCount > this.maxLength; return this.localMessage.length > this.maxLength;
}, },
hasFormData() { hasFormData() {
@@ -239,12 +232,15 @@ export default {
if (this.formData) { if (this.formData) {
console.log('FormData bij mount:', JSON.stringify(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() { beforeUnmount() {
// Verwijder event listener bij unmount met de benoemde handler // Verwijder event listener bij unmount met de benoemde handler
if (this.languageChangeHandler) { if (this.languageChangeHandler) {
document.removeEventListener('language-changed', this.languageChangeHandler); document.removeEventListener('language-changed', this.languageChangeHandler);
} }
window.removeEventListener('resize', this.autoResize);
}, },
methods: { methods: {
handleLanguageChange(event) { handleLanguageChange(event) {
@@ -285,6 +281,8 @@ export default {
} finally { } finally {
// Reset de vertaling vlag // Reset de vertaling vlag
this.isTranslating = false; this.isTranslating = false;
// Herbereken hoogte na vertaling
this.$nextTick(this.autoResize);
} }
}, },
@@ -465,9 +463,9 @@ export default {
.message-input { .message-input {
width: 100%; width: 100%;
min-height: 40px; 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: 1px solid #ddd;
border-radius: 20px; border-radius: 10px;
resize: none; resize: none;
outline: none; outline: none;
transition: border-color 0.2s; transition: border-color 0.2s;
@@ -478,35 +476,17 @@ export default {
color: var(--human-message-text-color); color: var(--human-message-text-color);
/* Box-sizing om padding correct te berekenen */ /* Box-sizing om padding correct te berekenen */
box-sizing: border-box; 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 */ /* WebKit/Chromium: scrollbar verbergen */
.character-counter { .message-input::-webkit-scrollbar {
position: absolute; display: none;
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 */
} }
/* 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 */
.input-actions { .input-actions {

View File

@@ -1,15 +1,15 @@
<template> <template>
<div :class="getMessageClass()" :data-message-id="message.id"> <div :class="getMessageClass()" :data-message-id="message.id">
<!-- EveAI Logo buiten de scroller, vast aan de bubble -->
<img
v-if="message.sender === 'ai'"
:src="staticUrl('/assets/img/eveai_logo.svg')"
alt="EveAI"
class="ai-message-logo"
/>
<!-- Normal text messages --> <!-- Normal text messages -->
<template v-if="message.type === 'text'"> <template v-if="message.type === 'text'">
<div class="message-content" style="width: 100%;"> <div class="message-content" style="width: 100%;" ref="messageContent">
<!-- EveAI Logo voor AI berichten - links boven, half buiten de bubbel -->
<img
v-if="message.sender === 'ai'"
:src="staticUrl('/assets/img/eveai_logo.svg')"
alt="EveAI"
class="ai-message-logo"
/>
<!-- Voortgangstracker voor AI berichten met task_id - ALLEEN VOOR LAATSTE AI MESSAGE --> <!-- Voortgangstracker voor AI berichten met task_id - ALLEEN VOOR LAATSTE AI MESSAGE -->
<progress-tracker <progress-tracker
v-if="message.sender === 'ai' && message.taskId && isLatestAiMessage" v-if="message.sender === 'ai' && message.taskId && isLatestAiMessage"
@@ -102,13 +102,6 @@
<!-- Error messages --> <!-- Error messages -->
<template v-else-if="message.type === 'error'"> <template v-else-if="message.type === 'error'">
<div class="message-content error-content"> <div class="message-content error-content">
<!-- EveAI Logo voor AI berichten - links boven, half buiten de bubbel -->
<img
v-if="message.sender === 'ai'"
:src="staticUrl('/assets/img/eveai_logo.svg')"
alt="EveAI"
class="ai-message-logo"
/>
<div class="form-error"> <div class="form-error">
{{ message.content }} {{ message.content }}
</div> </div>
@@ -120,14 +113,7 @@
<!-- Other message types --> <!-- Other message types -->
<template v-else> <template v-else>
<div class="message-content"> <div class="message-content" ref="messageContent">
<!-- EveAI Logo voor AI berichten - links boven, half buiten de bubbel -->
<img
v-if="message.sender === 'ai'"
:src="staticUrl('/assets/img/eveai_logo.svg')"
alt="EveAI"
class="ai-message-logo"
/>
<div class="message-text" v-html="formatMessage(message.content)"></div> <div class="message-text" v-html="formatMessage(message.content)"></div>
</div> </div>
</template> </template>
@@ -225,12 +211,35 @@ export default {
} }
}, },
mounted() { mounted() {
// Component initialization if needed // Reset initial scroll position to top for the inner bubble
this.$nextTick(() => {
const el = this.$refs.messageContent;
if (el && typeof el.scrollTop !== 'undefined') {
el.scrollTop = 0;
}
});
}, },
beforeUnmount() { watch: {
isActiveContext(newVal, oldVal) {
// When moving from active (input/sticky) to history, reset scroll to top
if (oldVal === true && newVal === false) {
this.$nextTick(() => {
const el = this.$refs.messageContent;
if (el && typeof el.scrollTop !== 'undefined') {
el.scrollTop = 0;
}
});
}
}
},
beforeUnmount() {
// Component cleanup if needed // Component cleanup if needed
}, },
computed: { computed: {
isActiveContext() {
// active if in input area or sticky area
return !!(this.isInInputArea || this.isInStickyArea);
},
hasFormData() { hasFormData() {
return this.message.formData && return this.message.formData &&
((Array.isArray(this.message.formData.fields) && this.message.formData.fields.length > 0) || ((Array.isArray(this.message.formData.fields) && this.message.formData.fields.length > 0) ||
@@ -383,8 +392,8 @@ export default {
/* User messages with forms get fixed width of 90% */ /* User messages with forms get fixed width of 90% */
.message.user.has-form { .message.user.has-form {
width: 90%; width: auto; /* niet breder maken dan standaard */
max-width: none; max-width: 100%;
} }
/* Styling for temporarily positioned AI messages */ /* Styling for temporarily positioned AI messages */
@@ -421,39 +430,60 @@ export default {
padding: 12px; padding: 12px;
} }
.message-content { .message-content {
width: 100%;
font-family: Arial, sans-serif; font-family: Arial, sans-serif;
font-size: 14px; font-size: 12px;
max-width: 90%;
padding: 8px;
border-radius: 10px;
word-wrap: break-word;
position: relative;
box-shadow: 0 2px 8px rgba(0,0,0,0.1);
transition: all 0.2s ease;
display: inline-block;
width: 100%;
box-sizing: border-box;
} }
/* EveAI Logo styling voor AI berichten */ /* EveAI Logo styling voor AI berichten */
/* Position relative on the message container to anchor the logo (sibling of .message-content) */
.message.ai {
position: relative;
}
.ai-message-logo { .ai-message-logo {
position: absolute; position: absolute;
top: -20px; top: -20px;
left: -20px; left: -5px;
width: 36px; width: 36px;
height: 36px; height: 36px;
border-radius: 50%; border-radius: 50%;
background-color: var(--ai-message-background); background-color: var(--ai-message-background);
padding: 2px;
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15); box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
z-index: 10; z-index: 10;
pointer-events: none; pointer-events: none;
} }
/* Ensure message-content has relative positioning for logo positioning */
.message.ai .message-content {
position: relative;
}
/* Formulier styling */ /* Formulier styling */
.form-display { .form-display {
margin: 15px 0;
color: var(--human-message-text-color); color: var(--human-message-text-color);
padding: 15px;
font-family: inherit; font-family: inherit;
} }
/* Neutraliseer dynamic-form look binnen message bubble voor user-form-values */
.user-form-values .message-form .dynamic-form {
background: transparent;
box-shadow: none;
padding: 0;
max-width: 100%;
box-sizing: border-box;
}
.user-form-values .message-form .form-readonly,
.user-form-values .message-form .form-field-readonly,
.user-form-values .message-form .field-label,
.user-form-values .message-form .field-value {
max-width: 90%;
box-sizing: border-box;
}
/* Tabel styling voor formulieren */ /* Tabel styling voor formulieren */
.form-result-table { .form-result-table {
width: 100%; width: 100%;
@@ -612,13 +642,100 @@ export default {
max-width: 95%; max-width: 95%;
} }
/* User messages with forms get fixed width of 95% on mobile */ /* User messages with forms: hou zelfde breedte als gewone tekst */
.message.user.has-form { .message.user.has-form {
width: 95%; width: auto;
max-width: 100%;
} }
.form-result-table td:first-child { .form-result-table td:first-child {
width: 40%; width: 40%;
} }
} }
/* migrated from global css: message-content visuals */
.message.user .message-content {
background: var(--human-message-background);
color: var(--human-message-text-color);
border-bottom-right-radius: 4px;
}
.message.ai .message-content,
.message.bot .message-content {
background: var(--ai-message-background);
color: var(--ai-message-text-color);
border-bottom-left-radius: 4px;
margin-right: 60px;
}
/* Hover effects for message bubbles */
.message-content:hover {
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
/* Handle empty message content during processing */
.message-content:has(.message-text:empty) .message-progress {
margin-bottom: 0;
}
.message-content:has(.message-text:empty):not(:has(.message-progress.completed)):not(:has(.message-progress.error)) {
background: transparent;
box-shadow: none;
border: none;
padding: 0;
margin: 0;
}
/* Mobile responsiveness moved from global */
@media (max-width: 768px) {
.message.user .message-content {
margin-left: 40px;
}
.message.ai .message-content,
.message.bot .message-content {
margin-right: 40px;
}
/* Mobile: place logo inside bubble and prevent overlap with text */
.message.ai .ai-message-logo {
top: -12px;
left: 8px;
width: 24px;
height: 24px;
}
.message.ai .message-content {
/* Reserve space for the in-bubble logo */
padding-top: 1px; /* 24px logo + margins */
padding-left: 1px;
}
}
@media (max-width: 480px) {
.message-content {
max-width: 90%;
margin-left: 20px !important;
margin-right: 20px !important;
}
}
/* Mobile bubble height constraints and inner scroll containment */
@media (max-width: 768px) {
/* Default/history: apply to all message bubbles */
.message .message-content {
max-height: 33vh; /* fallback */
overflow-y: auto;
overscroll-behavior: contain; /* prevent scroll chaining to parent */
-webkit-overflow-scrolling: touch; /* iOS smooth inertia */
}
/* Active contexts (input area or sticky area): allow up to half viewport */
.message.input-area .message-content,
.message.sticky-area .message-content {
max-height: 50vh; /* fallback */
}
}
@supports (max-height: 1svh) {
@media (max-width: 768px) {
.message .message-content { max-height: 33svh; }
.message.input-area .message-content,
.message.sticky-area .message-content { max-height: 50svh; }
}
}
</style> </style>

View File

@@ -547,6 +547,8 @@ export default {
border-radius: 8px; border-radius: 8px;
padding: 15px; padding: 15px;
box-shadow: 0 2px 15px rgba(0,0,0,0.1); box-shadow: 0 2px 15px rgba(0,0,0,0.1);
box-sizing: border-box;
max-width: 100%;
} }
.form-header { .form-header {
@@ -558,7 +560,9 @@ export default {
} }
.dynamic-form.readonly .form-header { .dynamic-form.readonly .form-header {
border-bottom: 1px solid #777; border-bottom: none; /* alle borders weg in readonly */
padding-bottom: 0;
margin-bottom: 8px;
} }
.form-icon { .form-icon {
@@ -722,34 +726,86 @@ export default {
/* Read-only form styling */ /* Read-only form styling */
.form-readonly { .form-readonly {
padding: 10px 0; padding: 8px 0; /* compacter binnen bubble */
box-sizing: border-box;
max-width: 100%;
} }
.form-field-readonly { .form-field-readonly {
display: flex; display: flex;
margin-bottom: 8px; align-items: flex-start;
padding-bottom: 8px; gap: 8px;
margin-bottom: 6px; /* compacter */
padding-bottom: 6px;
line-height: 1.3; /* iets compacter */
box-sizing: border-box;
max-width: 100%;
} }
.dynamic-form.readonly .form-field-readonly { .dynamic-form.readonly .form-field-readonly {
border-bottom: 1px solid #777; border-bottom: none; /* alle borders weg in readonly */
} }
.field-label { .field-label {
flex: 0 0 30%; flex: 0 0 30%;
font-weight: 500; font-weight: 500;
padding-right: 10px; padding-right: 8px;
box-sizing: border-box;
max-width: 100%;
} }
.field-value { .field-value {
flex: 1; flex: 1;
word-break: break-word; overflow-wrap: anywhere; /* desktop: meerregelig zonder overflow */
box-sizing: border-box;
max-width: 100%;
} }
.text-value { .text-value {
white-space: pre-wrap; white-space: pre-wrap;
} }
/* Responsive aanpassingen voor read-only binnen message bubbles */
@media (min-width: 768px) {
/* Desktop en groter: geen ellipsis, laat tekst wrappen */
.dynamic-form.readonly .field-label,
.dynamic-form.readonly .field-value {
white-space: normal;
overflow: visible;
text-overflow: clip;
}
}
@media (max-width: 767.98px) {
/* Mobiel: label boven waarde, vet label, ellipsis op één regel */
.dynamic-form.readonly .form-field-readonly {
display: block;
border-bottom: none; /* alle borders weg in readonly */
}
.dynamic-form.readonly .field-label {
display: block;
font-weight: 600;
margin-bottom: 3px; /* kleine afstand tussen label en waarde */
padding-right: 0;
flex: none;
}
.dynamic-form.readonly .field-value {
display: block;
}
.dynamic-form.readonly .field-label,
.dynamic-form.readonly .field-value {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* Specifieke override voor text-value die anders pre-wrap afdwingt */
.dynamic-form.readonly .field-value.text-value {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
}
/* Boolean icon styling */ /* Boolean icon styling */
.boolean-icon { .boolean-icon {
font-size: 20px; font-size: 20px;

View File

@@ -220,7 +220,7 @@ export default {
} }
.message-content { .message-content {
max-width: 100%; max-width: 90%;
} }
/* Responsive adjustments */ /* Responsive adjustments */
@@ -294,4 +294,13 @@ export default {
border-bottom: 2px solid #000; border-bottom: 2px solid #000;
} }
} }
/* migrated from global css: message-content within form-message */
.form-message .message-content {
max-width: 90%;
background: white;
border: 1px solid #e9ecef;
border-radius: 12px;
padding: 20px;
box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
</style> </style>

View File

@@ -331,9 +331,9 @@ export default {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
flex: 1; flex: 1;
height: 100%; /* height: 100%; avoid forcing parent height */
min-height: 0; /* Laat kinderen scrollen */ min-height: 0; /* Laat kinderen scrollen */
padding: 20px; padding: 16px; /* iets minder padding om ruimte te besparen */
box-sizing: border-box; box-sizing: border-box;
width: 100%; width: 100%;
max-width: 1000px; max-width: 1000px;

View File

@@ -161,19 +161,37 @@ function initializeMobileHeader() {
const mountedApp = app.mount(container); const mountedApp = app.mount(container);
// Dynamisch de headerhoogte doorgeven aan CSS
const updateHeaderHeightVar = () => {
const isMobile = window.matchMedia('(max-width: 768px)').matches;
if (!isMobile) {
document.documentElement.style.removeProperty('--mobile-header-height');
return;
}
const h = container.offsetHeight || 60; // fallback
document.documentElement.style.setProperty('--mobile-header-height', `${h}px`);
};
// Initieel instellen en bij gebeurtenissen herberekenen
requestAnimationFrame(updateHeaderHeightVar);
window.addEventListener('resize', updateHeaderHeightVar);
// Listen to language change events and update the mobile header's language provider // Listen to language change events and update the mobile header's language provider
const languageChangeHandler = (event) => { const languageChangeHandler = (event) => {
if (event.detail && event.detail.language) { if (event.detail && event.detail.language) {
console.log('MobileHeader: Received language change event:', event.detail.language); console.log('MobileHeader: Received language change event:', event.detail.language);
languageProvider.setLanguage(event.detail.language); languageProvider.setLanguage(event.detail.language);
// taalwissel kan headerhoogte veranderen
requestAnimationFrame(updateHeaderHeightVar);
} }
}; };
document.addEventListener('language-changed', languageChangeHandler); document.addEventListener('language-changed', languageChangeHandler);
// Store the handler for cleanup if needed // Store the handler for cleanup if needed
mountedApp._languageChangeHandler = languageChangeHandler; mountedApp._languageChangeHandler = languageChangeHandler;
mountedApp._updateHeaderHeightVar = updateHeaderHeightVar;
console.log('✅ MobileHeader component successfully mounted with LanguageProvider'); console.log('✅ MobileHeader component successfully mounted with LanguageProvider en dynamische headerhoogte');
return mountedApp; return mountedApp;
} catch (error) { } catch (error) {
console.error('🚨 [CRITICAL ERROR] Bij initialiseren mobile header:', error); console.error('🚨 [CRITICAL ERROR] Bij initialiseren mobile header:', error);

View File

@@ -143,16 +143,6 @@ fi
echo "🔍 Services to process: ${SERVICE_ARRAY[*]}" echo "🔍 Services to process: ${SERVICE_ARRAY[*]}"
# Function to check if image exists locally
check_local_image_exists() {
local image_name="$1"
if podman image exists "$image_name" 2>/dev/null; then
return 0
else
return 1
fi
}
# Function to authenticate with Scaleway registry # Function to authenticate with Scaleway registry
authenticate_scaleway() { authenticate_scaleway() {
echo "🔐 Authenticating with Scaleway registry..." echo "🔐 Authenticating with Scaleway registry..."
@@ -213,18 +203,10 @@ for SERVICE in "${SERVICE_ARRAY[@]}"; do
continue continue
fi fi
# Check if local version image exists echo " 📥 Ensuring image is available (pulling from local registry)..."
if ! check_local_image_exists "$LOCAL_VERSION_IMAGE"; then
echo " ❌ Local version image not found: $LOCAL_VERSION_IMAGE"
echo " 💡 Run tag_registry_version.sh first to create version tags"
FAILED_SERVICES+=("$SERVICE")
continue
fi
# Pull local version image to ensure we have it
echo " 📥 Pulling local version image..."
if ! podman pull "$LOCAL_VERSION_IMAGE"; then if ! podman pull "$LOCAL_VERSION_IMAGE"; then
echo "Failed to pull $LOCAL_VERSION_IMAGE" echo "Image not found or not accessible in local registry: $LOCAL_VERSION_IMAGE"
echo " 💡 Controleer of de tag bestaat en of je bent ingelogd: podman login $LOCAL_REGISTRY"
FAILED_SERVICES+=("$SERVICE") FAILED_SERVICES+=("$SERVICE")
continue continue
fi fi