Try to fix styles

This commit is contained in:
2025-09-02 22:35:24 +02:00
parent 28f6fad818
commit 6286c1e0c9
6 changed files with 31 additions and 13 deletions

View File

@@ -25,7 +25,7 @@ const toastStore = useToastStore()
<style> <style>
#app { #app {
height: 100vh; height: var(--vh-dynamic, 100vh);
width: 100vw; width: 100vw;
overflow: hidden; overflow: hidden;
} }

View File

@@ -138,6 +138,12 @@ const handleKeydown = (event: KeyboardEvent) => {
.base-button--ghost { .base-button--ghost {
background-color: transparent; background-color: transparent;
color: #646cff; color: #646cff;
/* Ensure ghost buttons always meet minimum touch targets */
min-height: 2.75rem;
min-width: 2.75rem;
display: flex;
align-items: center;
justify-content: center;
} }
.base-button--ghost:hover:not(:disabled) { .base-button--ghost:hover:not(:disabled) {

View File

@@ -77,7 +77,7 @@ defineEmits<{
border-right: 1px solid #e5e7eb; border-right: 1px solid #e5e7eb;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
height: 100vh; height: var(--vh-dynamic, 100vh);
} }
.sidebar__header { .sidebar__header {

View File

@@ -7,9 +7,18 @@
/* Dynamic viewport height that accounts for iOS Safari UI changes */ /* Dynamic viewport height that accounts for iOS Safari UI changes */
--vh-actual: 100vh; --vh-actual: 100vh;
--vh-small: 100vh; /* Fallback for browsers without svh support */
--vh-large: 100vh; /* Fallback for browsers without lvh support */
--vh-dynamic: 100vh; /* Fallback for browsers without dvh support */
/* Use newer viewport units where supported */
--vh-small: 100svh; /* Small viewport height - excludes browser UI */ --vh-small: 100svh; /* Small viewport height - excludes browser UI */
--vh-large: 100lvh; /* Large viewport height - includes browser UI */ --vh-large: 100lvh; /* Large viewport height - includes browser UI */
--vh-dynamic: 100dvh; /* Dynamic viewport height - changes with browser UI */ --vh-dynamic: 100dvh; /* Dynamic viewport height - changes with browser UI */
/* Header height calculations */
--header-base-height: 4rem; /* Base header height */
--header-total-height: calc(var(--header-base-height) + var(--safe-area-inset-top, 0px));
} }
/* Minimal reset styles only */ /* Minimal reset styles only */
@@ -45,23 +54,24 @@ body {
/* iOS-specific touch and interaction optimizations */ /* iOS-specific touch and interaction optimizations */
* { * {
/* Disable callouts and text selection on iOS for better touch interactions */ /* Disable callouts on iOS for better touch interactions */
-webkit-touch-callout: none; -webkit-touch-callout: none;
/* Enable momentum scrolling globally for iOS */
-webkit-overflow-scrolling: touch;
}
/* Disable text selection only on UI elements, not form elements */
button, [role="button"], .no-select {
-webkit-user-select: none; -webkit-user-select: none;
user-select: none; user-select: none;
} }
/* Allow text selection for content areas */ /* Ensure text selection works in content and form areas */
input, textarea, [contenteditable="true"], .allow-select { input, textarea, [contenteditable="true"], .allow-select, p, span, div:not([role]), article, section {
-webkit-user-select: text; -webkit-user-select: text;
user-select: text; user-select: text;
} }
/* Enable momentum scrolling globally for iOS */
* {
-webkit-overflow-scrolling: touch;
}
/* Accessibility helpers */ /* Accessibility helpers */
.sr-only { .sr-only {
position: absolute; position: absolute;

View File

@@ -99,7 +99,7 @@ onMounted(() => {
<style scoped> <style scoped>
.auth-view { .auth-view {
height: 100vh; height: var(--vh-dynamic, 100vh);
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;

View File

@@ -714,12 +714,14 @@ onMounted(async () => {
left: 0; left: 0;
height: var(--vh-dynamic, 100vh); height: var(--vh-dynamic, 100vh);
transform: translateX(-100%); transform: translateX(-100%);
transition: transform 0.3s ease; transition: transform 0.3s ease, visibility 0.3s ease;
z-index: 400; /* Lower than mobile header but higher than overlay */ z-index: 400; /* Lower than mobile header but higher than overlay */
visibility: hidden; /* Completely hide when closed */
} }
.sidebar.sidebar-open { .sidebar.sidebar-open {
transform: translateX(0); transform: translateX(0);
visibility: visible;
} }
.sidebar-overlay { .sidebar-overlay {
@@ -729,7 +731,7 @@ onMounted(async () => {
.main-content { .main-content {
flex: 1; flex: 1;
overflow: hidden; overflow: hidden;
padding-top: calc(4rem + var(--safe-area-inset-top)); /* Account for fixed header height */ padding-top: var(--header-total-height); /* Account for fixed header height with safe area */
} }
.chat-container { .chat-container {