feat: tema ayarları Appwrite user prefs ile kalıcı hale getirildi

- saveThemePrefsAction: account.updatePrefs ile mevcut prefs'i merge eder
- Dashboard layout'ta account.getPrefs ile prefs server-side yüklenir
- PrefsInitializer: mount'ta dark/light, renk teması, radius, sidebar
  config'ini Appwrite'dan gelen initialPrefs ile uygular
- ThemeCustomizer: renk teması / tweakcn / radius / sidebar değişikliği
  anında Appwrite'a kaydedilir; dark/light toggle useEffect ile izlenir
- Sayfa yenileme ve farklı cihazda giriş sonrasında ayarlar korunur
This commit is contained in:
egecankomur
2026-05-05 20:57:30 +03:00
parent 9497cc72ce
commit 237ec92691
5 changed files with 155 additions and 39 deletions
+23
View File
@@ -0,0 +1,23 @@
"use server";
import { createSessionClient } from "@/lib/appwrite/server";
export interface ThemePrefs {
theme?: "dark" | "light" | "system";
colorTheme?: string;
tweakcnTheme?: string;
radius?: string;
sidebarVariant?: "sidebar" | "floating" | "inset";
sidebarCollapsible?: "offcanvas" | "icon" | "none";
sidebarSide?: "left" | "right";
}
export async function saveThemePrefsAction(update: Partial<ThemePrefs>): Promise<void> {
try {
const { account } = await createSessionClient();
const existing = await account.getPrefs<Record<string, unknown>>();
await account.updatePrefs({ ...existing, ...update });
} catch {
// best-effort — UI still works without persistence
}
}