refactor(ui): ChatGPT-style visual overhaul for app shell and analytics pages

This commit is contained in:
Jason
2026-05-04 12:38:14 +08:00
parent becec65ee3
commit 7dc7888869
13 changed files with 756 additions and 1129 deletions

View File

@@ -4,28 +4,29 @@
align-items: center;
justify-content: space-between;
gap: 16px;
min-height: 28px;
min-height: 32px;
padding: 4px 0;
background: transparent;
border: none;
border-radius: 0;
flex-shrink: 0;
}
.chat-analysis-back {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 0;
gap: 4px;
padding: 4px 8px 4px 4px;
border: none;
border-radius: 6px;
background: transparent;
color: var(--text-secondary);
color: var(--text-tertiary);
cursor: pointer;
transition: color 0.2s ease;
transition: background 0.15s ease, color 0.15s ease;
font-size: 13px;
font-weight: 600;
font-weight: 500;
&:hover {
background: var(--bg-hover);
color: var(--text-primary);
}
}
@@ -33,12 +34,13 @@
.chat-analysis-breadcrumb {
display: flex;
align-items: center;
gap: 8px;
gap: 4px;
font-size: 13px;
color: var(--text-secondary);
color: var(--text-tertiary);
.chat-analysis-breadcrumb-separator {
opacity: 0.6;
opacity: 0.5;
font-size: 12px;
}
}
@@ -49,25 +51,27 @@
.chat-analysis-current-trigger {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 0;
gap: 4px;
padding: 4px 8px;
border: none;
border-radius: 6px;
background: transparent;
color: var(--text-secondary);
color: var(--text-tertiary);
cursor: pointer;
font-size: 13px;
font-weight: 600;
transition: color 0.2s ease;
transition: background 0.15s ease, color 0.15s ease;
.current {
color: var(--text-primary);
}
svg {
transition: transform 0.2s ease;
transition: transform 0.15s ease;
}
&:hover {
background: var(--bg-hover);
color: var(--text-primary);
}
@@ -78,34 +82,33 @@
.chat-analysis-menu {
position: absolute;
top: calc(100% + 10px);
top: calc(100% + 6px);
right: 0;
min-width: 120px;
padding: 6px;
background: var(--card-bg);
padding: 4px;
background: var(--bg-secondary-solid, var(--bg-secondary));
border: 1px solid var(--border-color);
border-radius: 12px;
box-shadow: 0 12px 28px rgba(0, 0, 0, 0.12);
border-radius: 10px;
box-shadow: var(--shadow-md);
z-index: 20;
}
.chat-analysis-menu-item {
width: 100%;
display: block;
padding: 9px 12px;
padding: 8px 12px;
border: none;
border-radius: 8px;
border-radius: 6px;
background: transparent;
color: var(--text-primary);
text-align: left;
cursor: pointer;
font-size: 13px;
font-weight: 500;
transition: background 0.2s ease, color 0.2s ease;
transition: background 0.15s ease;
&:hover {
background: var(--bg-hover);
color: var(--primary);
}
}

View File

@@ -1,14 +1,16 @@
// ChatGPT-style sidebar
.sidebar {
width: 220px;
background: var(--bg-secondary);
border-right: 1px solid var(--border-color);
width: var(--sidebar-width, 260px);
background: var(--bg-sidebar, var(--bg-secondary));
display: flex;
flex-direction: column;
padding: 16px 0;
transition: width 0.25s ease;
padding: 8px 0;
transition: width 0.2s ease;
flex-shrink: 0;
overflow: hidden;
&.collapsed {
width: 64px;
width: 68px;
.sidebar-user-card-wrap {
margin: 0 8px 8px;
@@ -40,156 +42,15 @@
}
}
.sidebar-user-card-wrap {
position: relative;
margin: 0 12px 10px;
--sidebar-user-menu-width: 172px;
}
.sidebar-user-menu {
position: absolute;
left: 0;
right: auto;
bottom: calc(100% + 8px);
width: max(100%, var(--sidebar-user-menu-width));
z-index: 12;
border: 1px solid var(--border-color);
border-radius: 12px;
background: var(--bg-secondary-solid, var(--bg-primary));
display: flex;
flex-direction: column;
gap: 4px;
padding: 6px;
box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
opacity: 0;
transform: translateY(8px) scale(0.95);
pointer-events: none;
transition: opacity 0.2s ease, transform 0.2s ease;
&.open {
opacity: 1;
transform: translateY(0) scale(1);
pointer-events: auto;
}
}
.sidebar-user-menu-item {
width: 100%;
border: none;
border-radius: 10px;
background: transparent;
color: var(--text-primary);
padding: 9px 10px;
display: flex;
align-items: center;
gap: 8px;
font-size: 13px;
font-weight: 500;
cursor: pointer;
text-align: left;
transition: background 0.2s ease, color 0.2s ease;
&:hover {
background: var(--bg-tertiary);
}
&.danger {
color: #d93025;
&:hover {
background: rgba(255, 59, 48, 0.08);
}
}
}
.sidebar-user-card {
width: 100%;
padding: 10px;
border: 1px solid var(--border-color);
border-radius: 12px;
background: var(--bg-secondary);
display: flex;
align-items: center;
gap: 10px;
min-height: 56px;
cursor: pointer;
transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
&:hover {
border-color: rgba(99, 102, 241, 0.32);
background: var(--bg-tertiary);
}
&.menu-open {
border-color: rgba(99, 102, 241, 0.44);
box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.12);
}
.user-avatar {
width: 36px;
height: 36px;
border-radius: 10px;
overflow: hidden;
background: linear-gradient(135deg, var(--primary), var(--primary-hover));
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
img {
width: 100%;
height: 100%;
object-fit: cover;
}
span {
color: var(--on-primary);
font-size: 14px;
font-weight: 600;
}
}
.user-meta {
min-width: 0;
flex: 1;
}
.user-name {
font-size: 13px;
color: var(--text-primary);
font-weight: 600;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.user-wxid {
margin-top: 2px;
font-size: 11px;
color: var(--text-tertiary);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.user-menu-caret {
color: var(--text-tertiary);
display: inline-flex;
transition: transform 0.2s ease, color 0.2s ease;
&.open {
transform: rotate(180deg);
color: var(--text-secondary);
}
}
}
// ---- Navigation ----
.nav-menu {
flex: 1;
display: flex;
flex-direction: column;
gap: 4px;
gap: 2px;
padding: 0 12px;
overflow-y: auto;
overflow-x: hidden;
}
.nav-item {
@@ -197,24 +58,26 @@
align-items: center;
gap: 12px;
padding: 10px 12px;
border-radius: 9999px;
border-radius: 8px;
color: var(--text-secondary);
text-decoration: none;
transition: all 0.2s ease;
transition: background 0.15s ease, color 0.15s ease;
white-space: nowrap;
border: none;
background: transparent;
cursor: pointer;
font-family: inherit;
font-size: 14px;
&:hover {
background: var(--bg-tertiary);
background: var(--bg-hover);
color: var(--text-primary);
}
&.active {
background: var(--primary);
color: var(--on-primary);
background: var(--bg-hover);
color: var(--text-primary);
font-weight: 600;
}
}
@@ -242,7 +105,7 @@
height: 20px;
border-radius: 999px;
padding: 0 6px;
background: #ff3b30;
background: #ef4444;
color: #ffffff;
font-size: 11px;
font-weight: 700;
@@ -250,7 +113,6 @@
align-items: center;
justify-content: center;
line-height: 1;
box-shadow: 0 0 0 2px rgba(255, 59, 48, 0.18);
}
.nav-badge.icon-badge {
@@ -262,42 +124,158 @@
height: 16px;
padding: 0 4px;
font-size: 10px;
box-shadow: 0 0 0 2px var(--bg-secondary);
box-shadow: 0 0 0 2px var(--bg-sidebar, var(--bg-secondary));
}
// ---- Footer ----
.sidebar-footer {
padding: 0 12px;
border-top: 1px solid var(--border-color);
padding-top: 12px;
margin-top: 8px;
padding-top: 8px;
margin-top: 4px;
display: flex;
flex-direction: column;
gap: 4px;
gap: 2px;
}
// 繁花如梦主题:侧边栏毛玻璃 + 激活项用主品牌色
[data-theme="blossom-dream"] .sidebar {
background: rgba(255, 255, 255, 0.6);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border-right: 1px solid rgba(255, 255, 255, 0.4);
// ---- User card ----
.sidebar-user-card-wrap {
position: relative;
margin: 0 12px 8px;
--sidebar-user-menu-width: 172px;
}
[data-theme="blossom-dream"][data-mode="dark"] .sidebar {
background: rgba(34, 30, 36, 0.75);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border-right: 1px solid rgba(255, 255, 255, 0.06);
.sidebar-user-menu {
position: absolute;
left: 0;
right: auto;
bottom: calc(100% + 8px);
width: max(100%, var(--sidebar-user-menu-width));
z-index: 12;
border: 1px solid var(--border-color);
border-radius: 10px;
background: var(--bg-secondary-solid, var(--bg-secondary));
display: flex;
flex-direction: column;
gap: 2px;
padding: 4px;
box-shadow: var(--shadow-md);
opacity: 0;
transform: translateY(6px) scale(0.97);
pointer-events: none;
transition: opacity 0.15s ease, transform 0.15s ease;
&.open {
opacity: 1;
transform: translateY(0) scale(1);
pointer-events: auto;
}
}
// 激活项:主品牌色纵向微渐变
[data-theme="blossom-dream"] .nav-item.active {
background: linear-gradient(180deg, #D4849A 0%, #C4748A 100%);
.sidebar-user-menu-item {
width: 100%;
border: none;
border-radius: 8px;
background: transparent;
color: var(--text-primary);
padding: 8px 10px;
display: flex;
align-items: center;
gap: 8px;
font-size: 13px;
font-weight: 500;
cursor: pointer;
text-align: left;
transition: background 0.15s ease;
&:hover {
background: var(--bg-hover);
}
&.danger {
color: #ef4444;
&:hover {
background: rgba(239, 68, 68, 0.08);
}
}
}
// 深色激活项:用藕粉色,背景深灰底 + 粉色文字/图标(高阶玩法)
[data-theme="blossom-dream"][data-mode="dark"] .nav-item.active {
background: rgba(209, 158, 187, 0.15);
color: #D19EBB;
border: 1px solid rgba(209, 158, 187, 0.2);
.sidebar-user-card {
width: 100%;
padding: 10px;
border-radius: 10px;
background: transparent;
display: flex;
align-items: center;
gap: 10px;
min-height: 52px;
cursor: pointer;
border: none;
transition: background 0.15s ease;
&:hover {
background: var(--bg-hover);
}
&.menu-open {
background: var(--bg-hover);
}
.user-avatar {
width: 32px;
height: 32px;
border-radius: 50%;
overflow: hidden;
background: var(--primary);
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
img {
width: 100%;
height: 100%;
object-fit: cover;
}
span {
color: var(--on-primary);
font-size: 13px;
font-weight: 600;
}
}
.user-meta {
min-width: 0;
flex: 1;
}
.user-name {
font-size: 13px;
color: var(--text-primary);
font-weight: 600;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.user-wxid {
margin-top: 1px;
font-size: 11px;
color: var(--text-tertiary);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.user-menu-caret {
color: var(--text-tertiary);
display: inline-flex;
transition: transform 0.15s ease;
&.open {
transform: rotate(180deg);
}
}
}

View File

@@ -1,12 +1,11 @@
.title-bar {
height: 41px;
background: var(--bg-secondary);
height: 48px;
background: transparent;
display: flex;
align-items: center;
justify-content: space-between;
padding-left: 16px;
padding-right: 16px;
border-bottom: 1px solid var(--border-color);
padding-right: 8px;
-webkit-app-region: drag;
flex-shrink: 0;
gap: 8px;
@@ -14,12 +13,6 @@
z-index: 2101;
}
// 繁花如梦:标题栏毛玻璃
[data-theme="blossom-dream"] .title-bar {
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
}
.title-brand {
display: inline-flex;
align-items: center;
@@ -33,16 +26,15 @@
}
.titles {
font-size: 15px;
font-weight: 500;
font-size: 14px;
font-weight: 600;
color: var(--text-secondary);
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
letter-spacing: -0.01em;
}
.title-sidebar-toggle {
width: 28px;
height: 28px;
width: 32px;
height: 32px;
padding: 0;
border: none;
border-radius: 8px;
@@ -52,11 +44,11 @@
align-items: center;
justify-content: center;
cursor: pointer;
transition: background 0.2s ease, color 0.2s ease;
transition: background 0.15s ease, color 0.15s ease;
-webkit-app-region: no-drag;
&:hover {
background: var(--bg-tertiary);
background: var(--bg-hover);
color: var(--text-primary);
}
}
@@ -64,26 +56,26 @@
.title-window-controls {
display: inline-flex;
align-items: center;
gap: 6px;
gap: 2px;
-webkit-app-region: no-drag;
}
.title-window-control-btn {
width: 28px;
width: 36px;
height: 28px;
padding: 0;
border: none;
border-radius: 8px;
border-radius: 6px;
background: transparent;
color: var(--text-tertiary);
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: background 0.2s ease, color 0.2s ease;
transition: background 0.15s ease, color 0.15s ease;
&:hover {
background: var(--bg-tertiary);
background: var(--bg-hover);
color: var(--text-primary);
}
@@ -107,14 +99,14 @@
color: var(--text-secondary);
cursor: pointer;
padding: 6px;
border-radius: 4px;
border-radius: 6px;
display: flex;
align-items: center;
justify-content: center;
transition: all 0.2s;
transition: all 0.15s;
&:hover {
background: var(--bg-tertiary);
background: var(--bg-hover);
color: var(--text-primary);
}
@@ -124,8 +116,8 @@
}
&.live-play-btn.active {
background: rgba(var(--primary-rgb, 76, 132, 255), 0.16);
color: var(--primary, #4c84ff);
background: var(--primary-light);
color: var(--primary);
}
}