|
|
@@ -14,6 +14,7 @@
|
|
|
import { goto } from '$app/navigation';
|
|
|
import { modelsStore } from '$lib/stores/models.svelte';
|
|
|
import { TOOLTIP_DELAY_DURATION } from '$lib/constants/tooltip-config';
|
|
|
+ import { IsMobile } from '$lib/hooks/is-mobile.svelte';
|
|
|
|
|
|
let { children } = $props();
|
|
|
|
|
|
@@ -21,6 +22,10 @@
|
|
|
let isHomeRoute = $derived(page.route.id === '/');
|
|
|
let isNewChatMode = $derived(page.url.searchParams.get('new_chat') === 'true');
|
|
|
let showSidebarByDefault = $derived(activeMessages().length > 0 || isLoading());
|
|
|
+ let alwaysShowSidebarOnDesktop = $derived(config().alwaysShowSidebarOnDesktop);
|
|
|
+ let autoShowSidebarOnNewChat = $derived(config().autoShowSidebarOnNewChat);
|
|
|
+ let isMobile = new IsMobile();
|
|
|
+ let isDesktop = $derived(!isMobile.current);
|
|
|
let sidebarOpen = $state(false);
|
|
|
let innerHeight = $state<number | undefined>();
|
|
|
let chatSidebar:
|
|
|
@@ -76,6 +81,11 @@
|
|
|
}
|
|
|
|
|
|
$effect(() => {
|
|
|
+ if (alwaysShowSidebarOnDesktop && isDesktop) {
|
|
|
+ sidebarOpen = true;
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
if (isHomeRoute && !isNewChatMode) {
|
|
|
// Auto-collapse sidebar when navigating to home route (but not in new chat mode)
|
|
|
sidebarOpen = false;
|
|
|
@@ -83,8 +93,11 @@
|
|
|
// Keep sidebar open in new chat mode
|
|
|
sidebarOpen = true;
|
|
|
} else if (isChatRoute) {
|
|
|
- // On chat routes, show sidebar by default
|
|
|
- sidebarOpen = true;
|
|
|
+ // On chat routes, only auto-show sidebar if setting is enabled
|
|
|
+ if (autoShowSidebarOnNewChat) {
|
|
|
+ sidebarOpen = true;
|
|
|
+ }
|
|
|
+ // If setting is disabled, don't change sidebar state - let user control it manually
|
|
|
} else {
|
|
|
// Other routes follow default behavior
|
|
|
sidebarOpen = showSidebarByDefault;
|
|
|
@@ -190,12 +203,14 @@
|
|
|
<ChatSidebar bind:this={chatSidebar} />
|
|
|
</Sidebar.Root>
|
|
|
|
|
|
- <Sidebar.Trigger
|
|
|
- class="transition-left absolute left-0 z-[900] h-8 w-8 duration-200 ease-linear {sidebarOpen
|
|
|
- ? 'md:left-[var(--sidebar-width)]'
|
|
|
- : ''}"
|
|
|
- style="translate: 1rem 1rem;"
|
|
|
- />
|
|
|
+ {#if !(alwaysShowSidebarOnDesktop && isDesktop)}
|
|
|
+ <Sidebar.Trigger
|
|
|
+ class="transition-left absolute left-0 z-[900] h-8 w-8 duration-200 ease-linear {sidebarOpen
|
|
|
+ ? 'md:left-[var(--sidebar-width)]'
|
|
|
+ : ''}"
|
|
|
+ style="translate: 1rem 1rem;"
|
|
|
+ />
|
|
|
+ {/if}
|
|
|
|
|
|
<Sidebar.Inset class="flex flex-1 flex-col overflow-hidden">
|
|
|
{@render children?.()}
|