op sidebar ui

This commit is contained in:
Julian Freeman
2026-04-16 16:46:44 -04:00
parent 1131712d4d
commit 8dd06fa64d
2 changed files with 76 additions and 34 deletions

View File

@@ -23,8 +23,11 @@ const emit = defineEmits<{
<div class="sidebar-toolbar"> <div class="sidebar-toolbar">
<div class="sidebar-title-group"> <div class="sidebar-title-group">
<h1>Browser Assistant</h1> <h1>Browser Assistant</h1>
<p>Local Chromium profile manager</p>
</div> </div>
<button class="refresh-icon-button" type="button" @click="emit('refresh')">
<span class="refresh-icon" aria-hidden="true"></span>
<span class="sr-only">{{ loading || configsLoading ? "Refreshing..." : "Refresh" }}</span>
</button>
</div> </div>
<div v-if="browsers.length" class="browser-nav"> <div v-if="browsers.length" class="browser-nav">
@@ -46,7 +49,6 @@ const emit = defineEmits<{
</div> </div>
<div class="browser-nav-body"> <div class="browser-nav-body">
<strong>{{ browser.browserName }}</strong> <strong>{{ browser.browserName }}</strong>
<span>{{ browser.dataRoot }}</span>
</div> </div>
</button> </button>
</div> </div>
@@ -66,12 +68,7 @@ const emit = defineEmits<{
</div> </div>
<div class="browser-nav-body"> <div class="browser-nav-body">
<strong>Configuration</strong> <strong>Configuration</strong>
<span>Manage custom scan sources and paths</span>
</div> </div>
</button> </button>
<button class="refresh-button sidebar-refresh" type="button" @click="emit('refresh')">
{{ loading || configsLoading ? "Refreshing..." : "Refresh" }}
</button>
</aside> </aside>
</template> </template>

View File

@@ -16,8 +16,8 @@
.sidebar { .sidebar {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 12px; gap: 10px;
padding: 20px 16px; padding: 16px 14px;
min-height: 0; min-height: 0;
border: 1px solid var(--panel-border); border: 1px solid var(--panel-border);
border-radius: 22px; border-radius: 22px;
@@ -37,7 +37,7 @@
.sidebar-toolbar { .sidebar-toolbar {
display: flex; display: flex;
align-items: flex-start; align-items: center;
justify-content: space-between; justify-content: space-between;
gap: 12px; gap: 12px;
padding: 2px 2px 8px; padding: 2px 2px 8px;
@@ -48,18 +48,11 @@
} }
.sidebar-toolbar h1 { .sidebar-toolbar h1 {
font-size: 1.52rem; font-size: 1.34rem;
line-height: 1.02; line-height: 1.04;
letter-spacing: -0.04em; letter-spacing: -0.04em;
} }
.sidebar-title-group p {
margin: 6px 0 0;
color: var(--muted);
font-size: 0.84rem;
line-height: 1.35;
}
.state-panel p, .state-panel p,
.meta-line, .meta-line,
.profile-email, .profile-email,
@@ -90,22 +83,77 @@
transform: translateY(-1px); transform: translateY(-1px);
} }
.refresh-icon-button {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border: 1px solid rgba(148, 163, 184, 0.24);
border-radius: 12px;
background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(241, 245, 249, 0.92));
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
cursor: pointer;
transition:
transform 160ms ease,
border-color 160ms ease,
box-shadow 160ms ease;
}
.refresh-icon-button:hover {
transform: translateY(-1px);
border-color: rgba(100, 116, 139, 0.36);
}
.refresh-icon {
width: 13px;
height: 13px;
border: 1.8px solid #334155;
border-right-color: transparent;
border-radius: 50%;
position: relative;
}
.refresh-icon::after {
content: "";
position: absolute;
top: -2px;
right: -3px;
width: 6px;
height: 6px;
border-top: 1.8px solid #334155;
border-right: 1.8px solid #334155;
transform: rotate(18deg);
}
.sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
.browser-nav { .browser-nav {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 8px; gap: 6px;
min-height: 0; min-height: 0;
overflow: auto; overflow: auto;
padding-right: 2px; padding: 2px 2px 0 0;
} }
.browser-nav-item { .browser-nav-item {
display: flex; display: flex;
align-items: center; align-items: center;
gap: 14px; gap: 12px;
width: 100%; width: 100%;
padding: 11px; padding: 9px 10px;
border-radius: 16px; border-radius: 14px;
text-align: left; text-align: left;
cursor: pointer; cursor: pointer;
background: rgba(255, 255, 255, 0.54); background: rgba(255, 255, 255, 0.54);
@@ -153,12 +201,12 @@
} }
.browser-nav-icon { .browser-nav-icon {
width: 42px; width: 34px;
height: 42px; height: 34px;
border-radius: 0; border-radius: 0;
color: #fff; color: #fff;
font-weight: 700; font-weight: 700;
font-size: 0.86rem; font-size: 0.78rem;
letter-spacing: 0.08em; letter-spacing: 0.08em;
background: transparent; background: transparent;
overflow: visible; overflow: visible;
@@ -173,8 +221,8 @@
} }
.browser-nav-icon img { .browser-nav-icon img {
max-width: 38px; max-width: 30px;
max-height: 38px; max-height: 30px;
} }
.config-icon img { .config-icon img {
@@ -197,6 +245,8 @@
.browser-nav-body strong { .browser-nav-body strong {
display: block; display: block;
color: var(--text); color: var(--text);
font-size: 0.94rem;
line-height: 1.25;
} }
.browser-nav-body span { .browser-nav-body span {
@@ -837,11 +887,6 @@
padding: 28px; padding: 28px;
} }
.sidebar-refresh {
margin-top: 10px;
align-self: stretch;
}
.browser-nav, .browser-nav,
.content-scroll-area { .content-scroll-area {
scrollbar-width: thin; scrollbar-width: thin;