aboutsummaryrefslogtreecommitdiffstats
path: root/renderer/src/components/SettingsPage.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'renderer/src/components/SettingsPage.tsx')
-rw-r--r--renderer/src/components/SettingsPage.tsx51
1 files changed, 51 insertions, 0 deletions
diff --git a/renderer/src/components/SettingsPage.tsx b/renderer/src/components/SettingsPage.tsx
new file mode 100644
index 0000000..5267665
--- /dev/null
+++ b/renderer/src/components/SettingsPage.tsx
@@ -0,0 +1,51 @@
1import React, { useState } from "react";
2import { SystemPromptsSettings } from "./settings/SystemPromptsSettings";
3
4type SettingsSection = "system-prompts";
5
6interface SettingsPageProps {
7 onClose: () => void;
8}
9
10export function SettingsPage({ onClose }: SettingsPageProps) {
11 const [activeSection, setActiveSection] =
12 useState<SettingsSection>("system-prompts");
13
14 return (
15 <div className="settings-overlay">
16 {/* Header — matches the main app header height/style */}
17 <div className="settings-header">
18 <div className="settings-header-left">
19 <span className="settings-title">\u2699 Settings</span>
20 </div>
21 <button
22 className="settings-close"
23 onClick={onClose}
24 title="Close settings"
25 >
26 \u00d7
27 </button>
28 </div>
29
30 <div className="settings-body">
31 {/* Side nav */}
32 <nav className="settings-nav">
33 <button
34 className={`settings-nav-item${
35 activeSection === "system-prompts" ? " active" : ""
36 }`}
37 onClick={() => setActiveSection("system-prompts")}
38 >
39 System Prompts
40 </button>
41 {/* Future sections added here */}
42 </nav>
43
44 {/* Content */}
45 <div className="settings-content">
46 {activeSection === "system-prompts" && <SystemPromptsSettings />}
47 </div>
48 </div>
49 </div>
50 );
51}