All checks were successful
Auto Tag Develop / tag (push) Successful in 6s
- Add dark mode toggle button in top nav - Add darkMode store with localStorage persistence - Enable Tailwind class-based dark mode - Import dark.css global overrides - Remove inline dark: Tailwind classes (handled by global CSS) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
58 lines
1.5 KiB
TypeScript
58 lines
1.5 KiB
TypeScript
export const useUiStore = defineStore('ui', () => {
|
|
const sidebarCollapsed = ref(false)
|
|
const sidebarOpen = ref(false)
|
|
const darkMode = ref(false)
|
|
|
|
if (import.meta.client) {
|
|
const saved = localStorage.getItem('ui-sidebar-collapsed')
|
|
if (saved !== null) {
|
|
sidebarCollapsed.value = saved === 'true'
|
|
}
|
|
|
|
const savedDark = localStorage.getItem('ui-dark-mode')
|
|
if (savedDark !== null) {
|
|
darkMode.value = savedDark === 'true'
|
|
}
|
|
applyDarkClass(darkMode.value)
|
|
}
|
|
|
|
watch(sidebarCollapsed, (val) => {
|
|
if (import.meta.client) {
|
|
localStorage.setItem('ui-sidebar-collapsed', String(val))
|
|
}
|
|
})
|
|
|
|
watch(darkMode, (val) => {
|
|
if (import.meta.client) {
|
|
localStorage.setItem('ui-dark-mode', String(val))
|
|
applyDarkClass(val)
|
|
}
|
|
})
|
|
|
|
function applyDarkClass(dark: boolean) {
|
|
if (dark) {
|
|
document.documentElement.classList.add('dark')
|
|
} else {
|
|
document.documentElement.classList.remove('dark')
|
|
}
|
|
}
|
|
|
|
function toggleDarkMode() {
|
|
darkMode.value = !darkMode.value
|
|
}
|
|
|
|
function toggleSidebar() {
|
|
sidebarCollapsed.value = !sidebarCollapsed.value
|
|
}
|
|
|
|
function openMobileSidebar() {
|
|
sidebarOpen.value = true
|
|
}
|
|
|
|
function closeMobileSidebar() {
|
|
sidebarOpen.value = false
|
|
}
|
|
|
|
return { sidebarCollapsed, sidebarOpen, darkMode, toggleSidebar, openMobileSidebar, closeMobileSidebar, toggleDarkMode }
|
|
})
|