embermarks/options/options.html

324 lines
9.4 KiB
HTML
Raw Normal View History

2026-01-04 19:28:14 +00:00
<!doctype html>
<html>
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Embermarks Settings</title>
<style>
:root {
--ember-orange: #ff6b35;
--ember-gold: #ffd700;
--ember-warm: #ff8c42;
--ember-dark: #2d2d2d;
--ember-gray: #888;
}
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
body {
font-family:
-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
sans-serif;
background: #1a1a1a;
color: #fff;
min-height: 100vh;
padding: 2rem;
}
.container {
max-width: 600px;
margin: 0 auto;
}
h1 {
font-size: 1.8rem;
margin-bottom: 0.5rem;
background: linear-gradient(
90deg,
var(--ember-gold),
var(--ember-orange)
);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.header-icon {
width: 32px;
height: 32px;
vertical-align: middle;
margin-right: 6px;
}
.subtitle {
color: var(--ember-gray);
margin-bottom: 2rem;
}
.section {
background: var(--ember-dark);
border-radius: 12px;
padding: 1.5rem;
margin-bottom: 1.5rem;
}
.section h2 {
font-size: 1rem;
color: var(--ember-warm);
margin-bottom: 1rem;
text-transform: uppercase;
letter-spacing: 1px;
}
.setting-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.75rem 0;
border-bottom: 1px solid #444;
}
.setting-row:last-child {
border-bottom: none;
}
.setting-label {
flex: 1;
}
.setting-label span {
display: block;
font-size: 0.85rem;
color: var(--ember-gray);
margin-top: 0.25rem;
}
input[type="number"] {
width: 80px;
padding: 0.5rem;
border: 1px solid #444;
border-radius: 6px;
background: #1a1a1a;
color: #fff;
font-size: 1rem;
text-align: center;
}
select {
padding: 0.5rem;
border: 1px solid #444;
border-radius: 6px;
background: #1a1a1a;
color: #fff;
font-size: 1rem;
}
2026-01-04 19:28:14 +00:00
input[type="checkbox"] {
width: 20px;
height: 20px;
accent-color: var(--ember-orange);
}
.folder-list {
max-height: 300px;
overflow-y: auto;
margin-top: 1rem;
}
.folder-item {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 0.5rem;
border-radius: 6px;
cursor: pointer;
}
.folder-item:hover {
background: rgba(255, 140, 66, 0.1);
}
.folder-item input {
flex-shrink: 0;
}
.folder-item label {
flex: 1;
cursor: pointer;
}
.folder-depth-1 {
padding-left: 1.5rem;
}
.folder-depth-2 {
padding-left: 3rem;
}
.folder-depth-3 {
padding-left: 4.5rem;
}
.btn-save {
display: block;
width: 100%;
padding: 1rem;
background: linear-gradient(
135deg,
var(--ember-orange),
var(--ember-warm)
);
color: white;
border: none;
border-radius: 8px;
font-size: 1rem;
font-weight: 600;
cursor: pointer;
transition: filter 0.2s;
}
.btn-save:hover {
filter: brightness(1.1);
}
.save-status {
text-align: center;
margin-top: 1rem;
color: var(--ember-warm);
opacity: 0;
transition: opacity 0.3s;
}
.save-status.visible {
opacity: 1;
}
</style>
</head>
<body>
<div class="container">
<h1>
<img
src="../icons/ember-48.svg"
alt=""
class="header-icon"
/>Embermarks Settings
</h1>
<p class="subtitle">
Configure how forgotten bookmarks are discovered
</p>
<div class="section">
<h2>Display</h2>
<div class="setting-row">
<div class="setting-label">
Number of bookmarks to show
<span
>How many forgotten bookmarks to display at
once</span
>
</div>
<input
type="number"
id="numBookmarks"
min="1"
max="20"
value="5"
/>
</div>
<div class="setting-row">
<div class="setting-label">
Refresh behavior
<span>When to show new bookmarks</span>
</div>
<select id="refreshBehavior">
<option value="always">Every time</option>
<option value="daily">Once a day</option>
<option value="manual">Manual only</option>
</select>
</div>
2026-01-04 19:28:14 +00:00
</div>
<div class="section">
<h2>Forgotten Criteria</h2>
<div class="setting-row">
<div class="setting-label">
Maximum visit count
<span
>Bookmarks with this many visits or fewer are
considered "forgotten"</span
>
</div>
<input
type="number"
id="maxVisitCount"
min="0"
max="100"
value="2"
/>
</div>
<div class="setting-row">
<div class="setting-label">
Minimum age (days)
<span
>Only show bookmarks older than this many days</span
>
</div>
<input
type="number"
id="minAgeDays"
min="0"
max="365"
value="7"
/>
</div>
<div class="setting-row">
<div class="setting-label">
Not visited in (days)
<span
>Also show bookmarks not visited in this many days,
even if visited before (0 = disabled)</span
>
</div>
<input
type="number"
id="notVisitedInDays"
min="0"
max="3650"
value="0"
/>
</div>
2026-01-04 19:28:14 +00:00
</div>
<div class="section">
<h2>Excluded Folders</h2>
<p
style="
color: var(--ember-gray);
font-size: 0.9rem;
margin-bottom: 0.5rem;
"
>
Check folders you want to exclude from suggestions
</p>
<div class="folder-list" id="folderList">
<div style="color: var(--ember-gray); padding: 1rem">
Loading folders...
</div>
</div>
</div>
<button class="btn-save" id="saveBtn">Save Settings</button>
<div class="save-status" id="saveStatus">✓ Settings saved!</div>
</div>
<script src="options.js"></script>
</body>
</html>