Files
nexus-terminal/packages/frontend/src/style.css
T
yinjianm 96d9950c6b feat(frontend): 重构本地调试代理配置
将 `packages/frontend` 的 Vite 开发代理改为可通过环境变量
切换目标地址,并补充本地联调所需的默认主题与样式更新。
同时同步更新前后端默认 UI 主题定义,便于在本地直接验证
远端接口、WebSocket 与视觉效果。
2026-04-21 05:15:18 +08:00

246 lines
8.2 KiB
CSS

@import "tailwindcss";
/* Tailwind Theme Variables Mapping — NVIDIA Design System */
@theme inline {
/* Base Colors */
--color-background: var(--app-bg-color);
--color-foreground: var(--text-color);
--color-app: var(--app-bg-color);
--color-text-default: var(--text-color);
--color-text-secondary: var(--text-color-secondary);
--color-text-tertiary: var(--text-color-tertiary);
--color-border: var(--border-color);
--color-border-default: var(--border-color);
--color-link: var(--link-color);
--color-link-hover: var(--link-hover-color);
--color-link-active: var(--link-active-color);
--color-primary: var(--link-active-color);
--color-link-active-bg: var(--link-active-bg-color);
--color-nav-active-bg: var(--nav-item-active-bg-color);
/* Component Colors */
--color-header: var(--header-bg-color);
--color-footer: var(--footer-bg-color);
--color-card: var(--card-bg-color);
--color-button: var(--button-bg-color);
--color-button-text: var(--button-text-color);
--color-button-hover: var(--button-hover-bg-color);
--color-button-secondary: var(--button-secondary-bg-color);
--color-icon: var(--icon-color);
--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-focus-border: var(--input-focus-border-color);
--color-overlay: var(--overlay-bg-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);
/* Radius Scale (Apple) */
--radius-micro: 5px;
--radius-standard: 8px;
--radius-comfortable: 11px;
--radius-large: 12px;
--radius-pill: 980px;
/* Shadow (NVIDIA) */
--shadow-card: rgba(0, 0, 0, 0.3) 0px 0px 5px 0px;
--shadow-subtle: rgba(0, 0, 0, 0.2) 0px 1px 3px 0px;
}
/* ─────────────────────────────────────────────
NVIDIA Design System — Dark Theme (Default)
───────────────────────────────────────────── */
:root {
/* Base Colors (NVIDIA Dark) */
--app-bg-color: #000000; /* True Black */
--text-color: #ffffff; /* White on dark */
--text-color-secondary: #a7a7a7; /* Gray 300 */
--text-color-tertiary: #757575; /* Gray 500 */
--border-color: #5e5e5e; /* Gray Border */
--link-color: #ffffff; /* White links on dark */
--link-hover-color: #3860be; /* Blue hover */
--link-active-color: #76b900; /* NVIDIA Green */
--link-active-bg-color: rgba(118, 185, 0, 0.12); /* Green 12% */
--nav-item-active-bg-color: var(--link-active-bg-color);
/* Component Colors (NVIDIA Dark) */
--header-bg-color: #000000;
--footer-bg-color: #000000;
--card-bg-color: #1a1a1a; /* Near Black cards */
--button-bg-color: #76b900; /* NVIDIA Green CTA */
--button-text-color: #000000; /* Black on green */
--button-hover-bg-color: #1eaedb; /* Teal hover */
--button-secondary-bg-color: #1a1a1a;
--icon-color: #757575; /* Gray 500 */
--icon-hover-color: #76b900; /* NVIDIA Green */
--split-line-color: #5e5e5e;
--split-line-hover-color: #76b900;
--input-focus-border-color: #76b900; /* Green focus ring */
--input-focus-glow: #76b900;
--overlay-bg-color: rgba(0, 0, 0, 0.85);
/* Status Colors (NVIDIA) */
--color-success: #3f8500;
--color-warning: #ef9100;
--color-error: #e52020;
--color-success-text: #ffffff;
--color-warning-text: #1a1a1a;
--color-error-text: #ffffff;
/* Typography */
--font-family-sans-serif: Arial, Helvetica, sans-serif;
/* Spacing */
--base-padding: 1rem;
--base-margin: 0.5rem;
}
/* 应用基础样式 */
body {
margin: 0;
font-family: var(--font-family-sans-serif);
background-color: var(--app-bg-color);
color: var(--text-color);
line-height: 1.5;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
/* 全局链接样式 */
a {
/* color: var(--link-color); */ /* 注释掉全局 a 标签的颜色设置,让 Tailwind 类生效 */
text-decoration: none; /* 移除下划线 */
}
/* 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;
}
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);
}
/* 全局分割线样式 */
hr {
border: none;
border-top: 1px solid var(--divider-color);
margin: var(--base-margin) 0;
}
/* 可以添加更多全局样式规则 */
/* 为 xterm 终端添加内边距 */
.xterm{
padding: 10px 10px 10px 10px;
}
/* 为历史记录和快捷命令列表设置字体 */
/* 注意:这里的选择器可能需要根据实际组件结构调整 */
.command-history-item,
.quick-command-item { /* 假设这些是列表项的类名 */
font-family: var(--font-family-sans-serif);
}
/* 如果是 Element Plus 的 Table 组件 */
.el-table .cell {
font-family: var(--font-family-sans-serif);
}
/* Override splitpanes default theme pane background */
.splitpanes.default-theme .splitpanes__pane {
background-color: var(--app-bg-color) !important;
}
/* Style the splitpane splitter */
.splitpanes.default-theme .splitpanes__splitter {
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; /* Add transition for hover effect */
}
.splitpanes.default-theme .splitpanes__splitter:hover {
background-color: var(--link-active-color) !important; /* Highlight on hover, keep important */
}
.splitpanes--vertical > .splitpanes__splitter {
width: 7px; /* Adjust width as needed */
border-top: none;
border-bottom: none;
}
.splitpanes--horizontal > .splitpanes__splitter {
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 — dark theme */
::-webkit-scrollbar {
width: 6px;
height: 6px;
}
::-webkit-scrollbar-track {
background: #1a1a1a;
border-radius: 3px;
}
::-webkit-scrollbar-thumb {
background-color: #5e5e5e;
border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
background-color: #76b900;
}
/* Input focus styles — NVIDIA Green ring */
input:focus, textarea:focus, select:focus {
border-color: var(--input-focus-border-color) !important;
outline: 0;
box-shadow: 0 0 0 2px rgba(118, 185, 0, 0.25) !important;
}
/* 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;
}