Wrap title + filters in a sticky container (top-8 sm:top-12, z-20, bg-white) on all pages for consistent scroll behavior. Also fix SidebarTimer icon visibility when sidebar is collapsed. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
32 lines
836 B
TypeScript
32 lines
836 B
TypeScript
export const useUiStore = defineStore('ui', () => {
|
|
const sidebarCollapsed = ref(false)
|
|
const sidebarOpen = ref(false)
|
|
|
|
if (import.meta.client) {
|
|
const saved = localStorage.getItem('ui-sidebar-collapsed')
|
|
if (saved !== null) {
|
|
sidebarCollapsed.value = saved === 'true'
|
|
}
|
|
}
|
|
|
|
watch(sidebarCollapsed, (val) => {
|
|
if (import.meta.client) {
|
|
localStorage.setItem('ui-sidebar-collapsed', String(val))
|
|
}
|
|
})
|
|
|
|
function toggleSidebar() {
|
|
sidebarCollapsed.value = !sidebarCollapsed.value
|
|
}
|
|
|
|
function openMobileSidebar() {
|
|
sidebarOpen.value = true
|
|
}
|
|
|
|
function closeMobileSidebar() {
|
|
sidebarOpen.value = false
|
|
}
|
|
|
|
return { sidebarCollapsed, sidebarOpen, toggleSidebar, openMobileSidebar, closeMobileSidebar }
|
|
})
|