mirror of
https://github.com/MODSetter/SurfSense.git
synced 2025-09-01 18:19:08 +00:00
60 lines
No EOL
2.4 KiB
TypeScript
60 lines
No EOL
2.4 KiB
TypeScript
"use client";
|
|
|
|
import React from 'react';
|
|
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs';
|
|
import { Separator } from '@/components/ui/separator';
|
|
import { Bot, Settings, Brain } from 'lucide-react';
|
|
import { ModelConfigManager } from '@/components/settings/model-config-manager';
|
|
import { LLMRoleManager } from '@/components/settings/llm-role-manager';
|
|
|
|
export default function SettingsPage() {
|
|
return (
|
|
<div className="min-h-screen bg-background">
|
|
<div className="container max-w-7xl mx-auto p-6 lg:p-8">
|
|
<div className="space-y-8">
|
|
{/* Header Section */}
|
|
<div className="space-y-4">
|
|
<div className="flex items-center space-x-4">
|
|
<div className="flex h-12 w-12 items-center justify-center rounded-lg bg-primary/10">
|
|
<Settings className="h-6 w-6 text-primary" />
|
|
</div>
|
|
<div className="space-y-1">
|
|
<h1 className="text-3xl font-bold tracking-tight">Settings</h1>
|
|
<p className="text-lg text-muted-foreground">
|
|
Manage your LLM configurations and role assignments.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<Separator className="my-6" />
|
|
</div>
|
|
|
|
{/* Settings Content */}
|
|
<Tabs defaultValue="models" className="space-y-8">
|
|
<div className="overflow-x-auto">
|
|
<TabsList className="grid w-full min-w-fit grid-cols-2 lg:w-auto lg:inline-grid">
|
|
<TabsTrigger value="models" className="flex items-center gap-2 text-sm">
|
|
<Bot className="h-4 w-4" />
|
|
<span className="hidden sm:inline">Model Configs</span>
|
|
<span className="sm:hidden">Models</span>
|
|
</TabsTrigger>
|
|
<TabsTrigger value="roles" className="flex items-center gap-2 text-sm">
|
|
<Brain className="h-4 w-4" />
|
|
<span className="hidden sm:inline">LLM Roles</span>
|
|
<span className="sm:hidden">Roles</span>
|
|
</TabsTrigger>
|
|
</TabsList>
|
|
</div>
|
|
|
|
<TabsContent value="models" className="space-y-6">
|
|
<ModelConfigManager />
|
|
</TabsContent>
|
|
|
|
<TabsContent value="roles" className="space-y-6">
|
|
<LLMRoleManager />
|
|
</TabsContent>
|
|
</Tabs>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|