feat: add tabbed interface for ClientSettings with display, connection, and cache options
This commit is contained in:
@@ -6,6 +6,8 @@ import { DisplaySettings } from "./DisplaySettings";
|
|||||||
import { KomgaSettings } from "./KomgaSettings";
|
import { KomgaSettings } from "./KomgaSettings";
|
||||||
import { CacheSettings } from "./CacheSettings";
|
import { CacheSettings } from "./CacheSettings";
|
||||||
import { BackgroundSettings } from "./BackgroundSettings";
|
import { BackgroundSettings } from "./BackgroundSettings";
|
||||||
|
import { Tabs, TabsList, TabsTrigger, TabsContent } from "@/components/ui/tabs";
|
||||||
|
import { Monitor, Network, HardDrive } from "lucide-react";
|
||||||
|
|
||||||
interface ClientSettingsProps {
|
interface ClientSettingsProps {
|
||||||
initialConfig: KomgaConfig | null;
|
initialConfig: KomgaConfig | null;
|
||||||
@@ -16,14 +18,38 @@ export function ClientSettings({ initialConfig, initialTTLConfig }: ClientSettin
|
|||||||
const { t } = useTranslate();
|
const { t } = useTranslate();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="container mx-auto px-4 py-8 space-y-8">
|
<div className="container mx-auto px-4 py-8 space-y-6">
|
||||||
<h1 className="text-3xl font-bold">{t("settings.title")}</h1>
|
<h1 className="text-3xl font-bold">{t("settings.title")}</h1>
|
||||||
<div className="space-y-8">
|
|
||||||
|
<Tabs defaultValue="display" className="w-full">
|
||||||
|
<TabsList className="grid w-full grid-cols-3">
|
||||||
|
<TabsTrigger value="display" className="flex items-center gap-2">
|
||||||
|
<Monitor className="h-4 w-4" />
|
||||||
|
{t("settings.tabs.display")}
|
||||||
|
</TabsTrigger>
|
||||||
|
<TabsTrigger value="connection" className="flex items-center gap-2">
|
||||||
|
<Network className="h-4 w-4" />
|
||||||
|
{t("settings.tabs.connection")}
|
||||||
|
</TabsTrigger>
|
||||||
|
<TabsTrigger value="cache" className="flex items-center gap-2">
|
||||||
|
<HardDrive className="h-4 w-4" />
|
||||||
|
{t("settings.tabs.cache")}
|
||||||
|
</TabsTrigger>
|
||||||
|
</TabsList>
|
||||||
|
|
||||||
|
<TabsContent value="display" className="mt-6 space-y-6">
|
||||||
<DisplaySettings />
|
<DisplaySettings />
|
||||||
<BackgroundSettings />
|
<BackgroundSettings />
|
||||||
|
</TabsContent>
|
||||||
|
|
||||||
|
<TabsContent value="connection" className="mt-6 space-y-6">
|
||||||
<KomgaSettings initialConfig={initialConfig} />
|
<KomgaSettings initialConfig={initialConfig} />
|
||||||
|
</TabsContent>
|
||||||
|
|
||||||
|
<TabsContent value="cache" className="mt-6 space-y-6">
|
||||||
<CacheSettings initialTTLConfig={initialTTLConfig} />
|
<CacheSettings initialTTLConfig={initialTTLConfig} />
|
||||||
</div>
|
</TabsContent>
|
||||||
|
</Tabs>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -67,6 +67,11 @@
|
|||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"title": "Preferences",
|
"title": "Preferences",
|
||||||
|
"tabs": {
|
||||||
|
"display": "Display",
|
||||||
|
"connection": "Connection",
|
||||||
|
"cache": "Cache"
|
||||||
|
},
|
||||||
"display": {
|
"display": {
|
||||||
"title": "Display Preferences",
|
"title": "Display Preferences",
|
||||||
"description": "Customize your library display.",
|
"description": "Customize your library display.",
|
||||||
|
|||||||
@@ -67,6 +67,11 @@
|
|||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"title": "Préférences",
|
"title": "Préférences",
|
||||||
|
"tabs": {
|
||||||
|
"display": "Affichage",
|
||||||
|
"connection": "Connexion",
|
||||||
|
"cache": "Cache"
|
||||||
|
},
|
||||||
"display": {
|
"display": {
|
||||||
"title": "Préférences d'affichage",
|
"title": "Préférences d'affichage",
|
||||||
"description": "Personnalisez l'affichage de votre bibliothèque.",
|
"description": "Personnalisez l'affichage de votre bibliothèque.",
|
||||||
|
|||||||
Reference in New Issue
Block a user