149 lines
4.6 KiB
HTML
149 lines
4.6 KiB
HTML
<!doctype html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
<title>WWCompanion Settings</title>
|
|
<link rel="stylesheet" href="settings.css" />
|
|
</head>
|
|
<body>
|
|
<header class="title-block">
|
|
<div class="title">WWCompanion Settings</div>
|
|
<div class="subtitle">Configure prompts, resume, and API access</div>
|
|
</header>
|
|
<div class="page-bar">
|
|
<div id="status" class="status"></div>
|
|
<button id="saveBtn" class="accent">Save Settings</button>
|
|
</div>
|
|
|
|
<details class="panel">
|
|
<summary class="panel-summary">
|
|
<span class="panel-caret" aria-hidden="true">
|
|
<span class="caret-closed">▸</span>
|
|
<span class="caret-open">▾</span>
|
|
</span>
|
|
<h2>API</h2>
|
|
</summary>
|
|
<div class="panel-body">
|
|
<div class="row">
|
|
<div></div>
|
|
<button id="resetApiBtn" class="ghost" type="button">Reset to OpenAI</button>
|
|
</div>
|
|
<div class="field">
|
|
<label for="activeApiKeySelect">Active key</label>
|
|
<select id="activeApiKeySelect"></select>
|
|
</div>
|
|
<div class="field">
|
|
<label for="apiBaseUrl">API Base URL</label>
|
|
<input
|
|
id="apiBaseUrl"
|
|
type="text"
|
|
placeholder="https://api.openai.com/v1"
|
|
/>
|
|
</div>
|
|
<div class="field">
|
|
<label for="apiKeyHeader">API Key Header</label>
|
|
<input id="apiKeyHeader" type="text" placeholder="Authorization" />
|
|
</div>
|
|
<div class="field">
|
|
<label for="apiKeyPrefix">API Key Prefix</label>
|
|
<input id="apiKeyPrefix" type="text" placeholder="Bearer " />
|
|
</div>
|
|
<div class="field">
|
|
<label for="model">Model name</label>
|
|
<input id="model" type="text" placeholder="gpt-4o-mini" />
|
|
</div>
|
|
</div>
|
|
</details>
|
|
|
|
<details class="panel">
|
|
<summary class="panel-summary">
|
|
<span class="panel-caret" aria-hidden="true">
|
|
<span class="caret-closed">▸</span>
|
|
<span class="caret-open">▾</span>
|
|
</span>
|
|
<h2>API Keys</h2>
|
|
</summary>
|
|
<div class="panel-body">
|
|
<div class="row">
|
|
<div></div>
|
|
<button id="addApiKeyBtn" class="ghost" type="button">Add Key</button>
|
|
</div>
|
|
<div id="apiKeys" class="api-keys"></div>
|
|
</div>
|
|
</details>
|
|
|
|
<details class="panel">
|
|
<summary class="panel-summary">
|
|
<span class="panel-caret" aria-hidden="true">
|
|
<span class="caret-closed">▸</span>
|
|
<span class="caret-open">▾</span>
|
|
</span>
|
|
<h2>Appearance</h2>
|
|
</summary>
|
|
<div class="panel-body">
|
|
<div class="field">
|
|
<label for="themeSelect">Theme</label>
|
|
<select id="themeSelect">
|
|
<option value="system">System</option>
|
|
<option value="light">Light</option>
|
|
<option value="dark">Dark</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</details>
|
|
|
|
<details class="panel">
|
|
<summary class="panel-summary">
|
|
<span class="panel-caret" aria-hidden="true">
|
|
<span class="caret-closed">▸</span>
|
|
<span class="caret-open">▾</span>
|
|
</span>
|
|
<h2>System Prompt</h2>
|
|
</summary>
|
|
<div class="panel-body">
|
|
<textarea
|
|
id="systemPrompt"
|
|
rows="8"
|
|
placeholder="Define tone and standards..."
|
|
></textarea>
|
|
</div>
|
|
</details>
|
|
|
|
<details class="panel">
|
|
<summary class="panel-summary">
|
|
<span class="panel-caret" aria-hidden="true">
|
|
<span class="caret-closed">▸</span>
|
|
<span class="caret-open">▾</span>
|
|
</span>
|
|
<h2>Resume</h2>
|
|
</summary>
|
|
<div class="panel-body">
|
|
<textarea id="resume" rows="10" placeholder="Paste your resume text..."></textarea>
|
|
</div>
|
|
</details>
|
|
|
|
<details class="panel">
|
|
<summary class="panel-summary">
|
|
<span class="panel-caret" aria-hidden="true">
|
|
<span class="caret-closed">▸</span>
|
|
<span class="caret-open">▾</span>
|
|
</span>
|
|
<div class="row-title">
|
|
<h2>Task Presets</h2>
|
|
<span class="hint hint-accent">Top task is the default</span>
|
|
</div>
|
|
</summary>
|
|
<div class="panel-body">
|
|
<div class="row">
|
|
<div></div>
|
|
<button id="addTaskBtn" class="ghost" type="button">Add Task</button>
|
|
</div>
|
|
<div id="tasks" class="tasks"></div>
|
|
</div>
|
|
</details>
|
|
|
|
<script src="settings.js"></script>
|
|
</body>
|
|
</html>
|