Revert "feat(frontend): unify ui with slate control center"

This reverts commit 91aa6e83ca.
This commit is contained in:
yinjianm
2026-03-25 05:21:34 +08:00
parent b9a4917467
commit d8a99e55b8
20 changed files with 1638 additions and 2733 deletions
+155 -292
View File
@@ -1,24 +1,23 @@
@import "tailwindcss";
/* Tailwind Theme Variables Mapping */
@theme inline {
--color-background: var(--app-bg-color);
--color-foreground: var(--text-color);
--color-app: var(--app-bg-color);
--color-card: var(--card-bg-color);
--color-card-foreground: var(--card-foreground-color);
--color-muted: var(--muted-bg-color);
--color-muted-foreground: var(--muted-foreground-color);
--color-text-default: var(--text-color);
/* Base Colors */
--color-background: var(--app-bg-color); /* More generic name */
--color-foreground: var(--text-color); /* More generic name */
--color-app: var(--app-bg-color); /* Keep specific if needed */
--color-text-default: var(--text-color); /* Keep specific if needed */
--color-text-secondary: var(--text-color-secondary);
--color-text-alt: var(--text-color-tertiary);
--color-border: var(--border-color);
--color-border: var(--border-color); /* Simplified name */
--color-border-default: var(--border-color); /* Keep specific if needed */
--color-link: var(--link-color);
--color-link-hover: var(--link-hover-color);
--color-link-active: var(--link-active-color);
--color-primary: var(--primary-color);
--color-primary-dark: var(--primary-dark-color);
--color-link-active-bg: var(--link-active-bg-color);
--color-nav-active-bg: var(--nav-item-active-bg-color);
--color-link-active: var(--link-active-color); /* Also used as primary/theme color */
--color-primary: var(--link-active-color); /* Map primary to active link color */
--color-link-active-bg: var(--link-active-bg-color); /* Map active link background */
--color-nav-active-bg: var(--nav-item-active-bg-color); /* Map specific nav active background */
/* Component Colors */
--color-header: var(--header-bg-color);
--color-footer: var(--footer-bg-color);
--color-button: var(--button-bg-color);
@@ -28,336 +27,200 @@
--color-icon-hover: var(--icon-hover-color);
--color-split-line: var(--split-line-color);
--color-split-line-hover: var(--split-line-hover-color);
--color-input: var(--input-bg-color);
--color-input-focus-border: var(--input-focus-border-color);
--color-overlay: var(--overlay-bg-color);
--color-success: var(--success-color);
--color-warning: var(--warning-color);
--color-error: var(--error-color);
--color-success: var(--color-success);
--color-warning: var(--color-warning);
--color-error: var(--color-error);
--color-success-text: var(--color-success-text);
--color-warning-text: var(--color-warning-text);
--color-error-text: var(--color-error-text);
}
/* 全局样式和 CSS 变量定义 */
:root {
--app-bg-color: #edf2f8;
--app-bg-gradient: radial-gradient(circle at top left, rgba(84, 125, 255, 0.18), transparent 34%),
radial-gradient(circle at right 16%, rgba(0, 170, 170, 0.14), transparent 26%),
linear-gradient(180deg, #f6f8fc 0%, #ecf1f7 52%, #e7edf6 100%);
--shell-surface-color: rgba(255, 255, 255, 0.56);
--card-bg-color: rgba(255, 255, 255, 0.84);
--card-foreground-color: #142033;
--muted-bg-color: #e9eef6;
--muted-foreground-color: #5a6b84;
--text-color: #152338;
--text-color-secondary: #607089;
--text-color-tertiary: #7f8da3;
--border-color: rgba(103, 124, 155, 0.24);
--border-strong-color: rgba(103, 124, 155, 0.36);
--link-color: #355fa8;
--link-hover-color: #214d90;
--link-active-color: #3c69e7;
--primary-color: #3c69e7;
--primary-dark-color: #2746b8;
--primary-soft-color: rgba(60, 105, 231, 0.12);
--link-active-bg-color: rgba(60, 105, 231, 0.12);
--nav-item-active-bg-color: rgba(60, 105, 231, 0.12);
--header-bg-color: rgba(255, 255, 255, 0.74);
--footer-bg-color: rgba(255, 255, 255, 0.78);
--button-bg-color: #3c69e7;
--button-text-color: #ffffff;
--button-hover-bg-color: #2746b8;
--icon-color: #62748e;
--icon-hover-color: #1d4f91;
--split-line-color: rgba(126, 143, 168, 0.22);
--split-line-hover-color: rgba(60, 105, 231, 0.42);
--input-bg-color: rgba(245, 248, 252, 0.9);
--input-focus-border-color: #3c69e7;
--input-focus-glow-rgb: 60, 105, 231;
--overlay-bg-color: rgba(12, 20, 32, 0.58);
--success-color: #22a06b;
--warning-color: #d99b24;
--error-color: #d04b4b;
--success-text-color: #ffffff;
--warning-text-color: #1d1d1d;
--error-text-color: #ffffff;
--shadow-soft: 0 24px 60px rgba(31, 48, 84, 0.14);
--shadow-card: 0 18px 40px rgba(24, 38, 67, 0.1);
--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.72);
--grid-line-color: rgba(116, 136, 167, 0.08);
--font-family-sans-serif: "IBM Plex Sans", "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
--font-family-display: "Space Grotesk", "IBM Plex Sans", "Noto Sans SC", "PingFang SC", sans-serif;
--font-family-mono: "IBM Plex Mono", "JetBrains Mono", "Cascadia Code", monospace;
--base-padding: 1rem;
--base-margin: 0.5rem;
--el-font-family: var(--font-family-sans-serif);
--el-color-primary: var(--primary-color);
--el-color-primary-light-3: #6789f0;
--el-color-primary-light-5: #8ca5f5;
--el-color-primary-light-7: #b3c3fa;
--el-color-primary-light-8: #cad8fc;
--el-color-primary-light-9: #e3ebff;
--el-color-primary-dark-2: var(--primary-dark-color);
--el-bg-color: rgba(255, 255, 255, 0.9);
--el-bg-color-page: transparent;
--el-bg-color-overlay: rgba(255, 255, 255, 0.96);
--el-text-color-primary: var(--text-color);
--el-text-color-regular: var(--text-color-secondary);
--el-text-color-secondary: var(--text-color-tertiary);
--el-border-color: rgba(103, 124, 155, 0.24);
--el-border-color-light: rgba(103, 124, 155, 0.16);
--el-border-color-lighter: rgba(103, 124, 155, 0.12);
--el-border-radius-base: 16px;
--el-border-radius-small: 12px;
--el-box-shadow-light: var(--shadow-card);
}
html,
body,
#app {
min-height: 100%;
/* 基础颜色 */
--app-bg-color: #ffffff; /* 应用背景色 */
--text-color: #333333; /* 主要文字颜色 */
--text-color-secondary: #666666; /* 次要文字颜色 */
--border-color: #cccccc; /* 边框颜色 */
--link-color: #333; /* 链接颜色 */
--link-hover-color: #0056b3; /* 链接悬停颜色 */
--link-active-color: #007bff; /* 激活链接/主题色 */
--link-active-bg-color: #e0e0ff; /* 激活链接背景色 (类似 indigo-50) */
--nav-item-active-bg-color: var(--link-active-bg-color); /* 导航选中项背景色, 默认同激活链接背景 */
/* 组件颜色 */
--header-bg-color: #f0f0f0; /* 头部背景色 */
--footer-bg-color: #f0f0f0; /* 底部背景色 */
--button-bg-color: #007bff; /* 按钮背景色 */
--button-text-color: #ffffff; /* 按钮文字颜色 */
--button-hover-bg-color: #0056b3;/* 按钮悬停背景色 */
--icon-color: var(--text-color-secondary); /* 图标颜色 */
--icon-hover-color: var(--link-hover-color); /* 图标悬停颜色 */
--split-line-color: var(--border-color); /* 分割线颜色 */
--split-line-hover-color: var(--border-color); /* 分割线悬停颜色 */
--input-focus-border-color: var(--link-active-color); /* 输入框聚焦边框颜色 */
--input-focus-glow: var(--link-active-color); /* 输入框聚焦光晕值 */
--overlay-bg-color: rgba(0, 0, 0, 0.6); /* Added Overlay Background Color */
/* Status Colors */
--color-success: #28a745; /* Green */
--color-warning: #ffc107; /* Yellow */
--color-error: #dc3545; /* Red */
--color-success-text: #ffffff; /* White text for green bg */
--color-warning-text: #212529; /* Dark text for yellow bg */
--color-error-text: #ffffff; /* White text for red bg */
/* 字体 */
--font-family-sans-serif: sans-serif; /* 默认字体 */
/* 其他 */
--base-padding: 1rem; /* 基础内边距 */
--base-margin: 0.5rem; /* 基础外边距 */
}
/* 应用基础样式 */
body {
margin: 0;
margin: 0; /* 移除默认 body margin */
font-family: var(--font-family-sans-serif);
background-color: var(--app-bg-color);
color: var(--text-color);
background: var(--app-bg-gradient);
background-attachment: fixed;
line-height: 1.6;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
body::before {
content: "";
position: fixed;
inset: 0;
pointer-events: none;
background-image:
linear-gradient(var(--grid-line-color) 1px, transparent 1px),
linear-gradient(90deg, var(--grid-line-color) 1px, transparent 1px);
background-size: 28px 28px;
mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.36), transparent 82%);
line-height: 1.6; /* 改善可读性 */
}
/* 全局链接样式 */
a {
color: inherit;
text-decoration: none;
/* color: var(--link-color); */ /* 注释掉全局 a 标签的颜色设置,让 Tailwind 类生效 */
text-decoration: none; /* 移除下划线 */
}
i,
.fas,
.far,
.fab {
color: inherit;
/* Removed global a:hover underline rule to avoid conflicts with Tailwind utilities */
/* 全局图标样式 */
i, .fas, .far, .fab { /* 根据你使用的图标库调整选择器 */
color: var(--icon-color);
transition: color 0.2s ease;
}
button,
input,
textarea,
select {
font: inherit;
a:hover i, a:hover .fas, a:hover .far, a:hover .fab, /* 链接内的图标 */
button:hover i, button:hover .fas, button:hover .far, button:hover .fab, /* 按钮内的图标 */
.icon-interactive:hover i, .icon-interactive:hover .fas, .icon-interactive:hover .far, .icon-interactive:hover .fab { /* 可交互图标容器 */
color: var(--icon-hover-color);
}
button:hover {
cursor: pointer;
}
input:focus,
textarea:focus,
select:focus {
border-color: var(--input-focus-border-color) !important;
outline: 0;
box-shadow: 0 0 0 3px rgba(var(--input-focus-glow-rgb), 0.18) !important;
}
button:focus,
button:focus-visible {
outline: none !important;
}
/* 全局分割线样式 */
hr {
border: none;
border-top: 1px solid rgba(103, 124, 155, 0.18);
border-top: 1px solid var(--divider-color);
margin: var(--base-margin) 0;
}
.xterm {
padding: 10px;
}
.control-panel {
border: 1px solid rgba(103, 124, 155, 0.18);
border-radius: 24px;
background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(246, 249, 253, 0.8));
box-shadow: var(--shadow-card);
backdrop-filter: blur(20px);
}
.control-panel--muted {
background: linear-gradient(180deg, rgba(243, 247, 252, 0.82), rgba(236, 242, 248, 0.74));
}
.control-toolbar {
border: 1px solid rgba(103, 124, 155, 0.14);
border-radius: 18px;
background: rgba(247, 250, 253, 0.78);
box-shadow: var(--shadow-inset);
}
.control-stat-grid {
display: grid;
gap: 1rem;
grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}
.control-stat-card {
position: relative;
overflow: hidden;
border: 1px solid rgba(103, 124, 155, 0.14);
border-radius: 20px;
background: linear-gradient(180deg, rgba(250, 252, 255, 0.9), rgba(241, 246, 252, 0.78));
box-shadow: var(--shadow-inset);
padding: 1rem 1.1rem;
}
.control-stat-card::after {
content: "";
position: absolute;
inset: 0 auto auto 0;
width: 100%;
height: 3px;
background: linear-gradient(90deg, rgba(60, 105, 231, 0.72), rgba(16, 185, 129, 0.48));
}
.control-stat-card__label {
display: block;
color: var(--text-color-tertiary);
font-size: 0.75rem;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.control-stat-card__value {
margin-top: 0.65rem;
display: block;
color: var(--text-color);
font-family: var(--font-family-display);
font-size: 1.6rem;
font-weight: 700;
line-height: 1.1;
}
.control-stat-card__meta {
margin-top: 0.45rem;
color: var(--text-color-secondary);
font-size: 0.85rem;
}
.control-empty {
padding: 2.6rem 1.4rem;
border: 1px dashed rgba(103, 124, 155, 0.3);
border-radius: 20px;
background: rgba(246, 249, 253, 0.8);
/* 可以添加更多全局样式规则 */
/* 为 xterm 终端添加内边距 */
.xterm{
padding: 10px 10px 10px 10px;
}
/* 为历史记录和快捷命令列表设置字体 */
/* 注意:这里的选择器可能需要根据实际组件结构调整 */
.command-history-item,
.quick-command-item,
.quick-command-item { /* 假设这些是列表项的类名 */
font-family: var(--font-family-sans-serif);
}
/* 如果是 Element Plus 的 Table 组件 */
.el-table .cell {
font-family: var(--font-family-sans-serif);
}
.el-card {
border-color: rgba(103, 124, 155, 0.18);
box-shadow: var(--shadow-card);
}
.el-card__body {
padding: 1.15rem 1.25rem;
}
.el-input__wrapper,
.el-select__wrapper,
.el-textarea__inner {
background: rgba(245, 248, 252, 0.92);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}
.el-button {
font-weight: 600;
}
.el-button--primary {
box-shadow: 0 12px 24px rgba(60, 105, 231, 0.2);
}
.el-button.is-plain {
background: rgba(255, 255, 255, 0.6);
}
.el-tabs__nav-wrap::after {
background-color: rgba(103, 124, 155, 0.14);
}
.el-tabs__item {
font-weight: 600;
}
.el-table {
--el-table-border-color: rgba(103, 124, 155, 0.14);
--el-table-header-bg-color: rgba(243, 247, 252, 0.88);
--el-table-tr-bg-color: transparent;
--el-table-row-hover-bg-color: rgba(60, 105, 231, 0.05);
border-radius: 18px;
overflow: hidden;
}
/* Override splitpanes default theme pane background */
.splitpanes.default-theme .splitpanes__pane {
background-color: transparent !important;
background-color: var(--app-bg-color) !important;
}
/* Style the splitpane splitter */
.splitpanes.default-theme .splitpanes__splitter {
background-color: transparent !important;
border-left: 1px solid rgba(103, 124, 155, 0.18);
border-right: 1px solid rgba(103, 124, 155, 0.18);
background-color: var(--app-bg-color) !important; /* Use important to ensure override */
border-left: 1px solid var(--border-color); /* Add a subtle border */
border-right: 1px solid var(--border-color);
box-sizing: border-box;
transition: background-color 0.2s ease;
transition: background-color 0.2s ease; /* Add transition for hover effect */
}
.splitpanes.default-theme .splitpanes__splitter:hover {
background-color: rgba(60, 105, 231, 0.16) !important;
background-color: var(--link-active-color) !important; /* Highlight on hover, keep important */
}
.splitpanes--vertical > .splitpanes__splitter {
width: 8px;
width: 7px; /* Adjust width as needed */
border-top: none;
border-bottom: none;
}
.splitpanes--horizontal > .splitpanes__splitter {
height: 8px;
border-top: 1px solid rgba(103, 124, 155, 0.18);
border-bottom: 1px solid rgba(103, 124, 155, 0.18);
height: 7px; /* Adjust height as needed */
border-left: none;
border-right: none;
border-top: 1px solid var(--border-color);
border-bottom: 1px solid var(--border-color);
}
/* Style scrollbars */
::-webkit-scrollbar {
width: 10px;
height: 10px;
width: 8px; /* Width of vertical scrollbar */
height: 8px; /* Height of horizontal scrollbar */
}
::-webkit-scrollbar-track {
background: rgba(255, 255, 255, 0.28);
border-radius: 999px;
background: var(--app-bg-color); /* Scrollbar track background */
border-radius: 4px;
}
::-webkit-scrollbar-thumb {
background-color: rgba(104, 123, 152, 0.5);
border-radius: 999px;
border: 2px solid transparent;
background-clip: padding-box;
background-color: var(--border-color); /* Scrollbar handle color */
border-radius: 4px;
border: 2px solid var(--app-bg-color); /* Creates padding around thumb */
}
::-webkit-scrollbar-thumb:hover {
background-color: rgba(61, 84, 118, 0.66);
background-color: var(--text-color-secondary); /* Scrollbar handle hover color */
}
::v-deep(.el-progress-bar__outer) {
background-color: rgba(226, 233, 244, 0.86) !important;
/* Input focus styles */
input:focus, textarea:focus, select:focus {
border-color: var(--input-focus-border-color) !important; /* Use new variable, !important might be needed depending on specificity */
outline: 0;
box-shadow: 0 0 0 3px rgba(var(--input-focus-glow-rgb), 0.2) !important; /* Use new variable, !important might be needed */
}
/* Ensure icons inside primary buttons are white */
button.bg-primary i,
button.bg-primary .fas,
button.bg-primary .far,
button.bg-primary .fab {
color: white !important; /* Force white color */
}
/* Optional: Keep icon white even on hover for primary buttons */
button.bg-primary:hover i,
button.bg-primary:hover .fas,
button.bg-primary:hover .far,
button.bg-primary:hover .fab {
color: white !important; /* Keep white on hover */
}
/* 移除按钮的聚焦光圈 */
button:focus {
outline: none !important;
box-shadow: none !important; /* 同时移除 box-shadow 以防其被用于聚焦指示 */
}
/* 针对使用 :focus-visible 的浏览器 */
button:focus-visible {
outline: none !important;
box-shadow: none !important;
}
/* 当鼠标悬停在按钮上时,鼠标指针变为手型 */
button:hover {
cursor: pointer;
}