Files
wecom_it_smart_desk/frontend-admin/src/styles/global.css
T

623 lines
13 KiB
CSS
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/* =============================================================================
企微IT智能服务台 — 管理后台全局样式(深色科技风)
=============================================================================
说明:定义深色主题 CSS 变量 + Element Plus 深色覆盖 + 全局基础样式
参考:PRD-admin.md §10.2 视觉风格 + ARCHITECTURE-admin.md §8.5 CSS 变量
============================================================================= */
/* --------------------------------------------------------------------------
Tailwind CSS 指令
-------------------------------------------------------------------------- */
@tailwind base;
@tailwind components;
@tailwind utilities;
/* --------------------------------------------------------------------------
全局 CSS 变量(深色科技风)
-------------------------------------------------------------------------- */
:root {
/* 背景色 */
--bg-primary: #0f172a;
--bg-secondary: #1e293b;
--bg-tertiary: #334155;
/* 语义色 */
--accent: #3b82f6;
--accent-hover: #2563eb;
--accent-light: rgba(59, 130, 246, 0.15);
--success: #10b981;
--success-bg: rgba(16, 185, 129, 0.12);
--warning: #f59e0b;
--warning-bg: rgba(245, 158, 11, 0.12);
--danger: #ef4444;
--danger-bg: rgba(239, 68, 68, 0.12);
/* 文本色 */
--text-primary: #f1f5f9;
--text-secondary: #94a3b8;
--text-muted: #64748b;
/* 边框 */
--border: rgba(148, 163, 184, 0.12);
--border-hover: rgba(148, 163, 184, 0.25);
/* 圆角 */
--radius: 8px;
--radius-lg: 12px;
/* 阴影 */
--shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}
/* --------------------------------------------------------------------------
全局基础样式
-------------------------------------------------------------------------- */
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html, body {
height: 100%;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Microsoft YaHei", sans-serif;
background: var(--bg-primary);
color: var(--text-primary);
overflow: hidden;
}
#app {
height: 100%;
}
/* 滚动条样式 */
::-webkit-scrollbar {
width: 6px;
height: 6px;
}
::-webkit-scrollbar-track {
background: transparent;
}
::-webkit-scrollbar-thumb {
background: var(--bg-tertiary);
border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
background: var(--text-muted);
}
/* 链接样式 */
a {
color: var(--accent);
text-decoration: none;
}
a:hover {
text-decoration: underline;
}
/* 代码样式 */
code {
background: var(--bg-tertiary);
color: var(--accent);
padding: 1px 6px;
border-radius: 4px;
font-size: 12px;
}
/* --------------------------------------------------------------------------
Element Plus 深色主题覆盖
-------------------------------------------------------------------------- */
/* --- el-table 深色覆盖 --- */
.el-table {
--el-table-bg-color: var(--bg-secondary);
--el-table-tr-bg-color: var(--bg-secondary);
--el-table-header-bg-color: var(--bg-tertiary);
--el-table-text-color: var(--text-primary);
--el-table-border-color: var(--border);
--el-table-row-hover-bg-color: var(--bg-tertiary);
--el-table-header-text-color: var(--text-secondary);
--el-table-current-row-bg-color: var(--accent-light);
}
.el-table th.el-table__cell {
background-color: var(--bg-tertiary);
}
.el-table tr {
background-color: var(--bg-secondary);
}
/* --- el-dialog 深色覆盖 --- */
.el-dialog {
--el-dialog-bg-color: var(--bg-secondary);
--el-dialog-title-font-size: 18px;
}
.el-dialog__header {
border-bottom: 1px solid var(--border);
}
.el-dialog__title {
color: var(--text-primary);
}
.el-dialog__body {
color: var(--text-secondary);
}
/* --- el-form 深色覆盖 --- */
.el-form {
--el-form-label-color: var(--text-secondary);
}
.el-form-item__label {
color: var(--text-secondary);
}
/* --- el-input 深色覆盖 --- */
.el-input__wrapper {
background-color: var(--bg-primary);
border-color: var(--border);
box-shadow: none;
}
.el-input__inner {
color: var(--text-primary);
}
.el-input__wrapper:hover {
border-color: var(--border-hover);
}
.el-input__wrapper.is-focus {
border-color: var(--accent);
box-shadow: 0 0 0 1px var(--accent) inset;
}
.el-input.is-disabled .el-input__wrapper {
background-color: var(--bg-tertiary);
}
/* --- el-select 深色覆盖 --- */
.el-select .el-input__wrapper {
background-color: var(--bg-primary);
}
.el-select-dropdown {
background-color: var(--bg-secondary);
border: 1px solid var(--border);
}
.el-select-dropdown__item {
color: var(--text-secondary);
}
.el-select-dropdown__item.hover,
.el-select-dropdown__item:hover {
background-color: var(--bg-tertiary);
}
.el-select-dropdown__item.selected {
color: var(--accent);
}
/* --- el-switch 深色覆盖 --- */
.el-switch.is-checked .el-switch__core {
background-color: var(--success);
border-color: var(--success);
}
.el-switch__core {
background-color: var(--bg-tertiary);
border-color: var(--border);
}
/* --- el-card 深色覆盖 --- */
.el-card {
background-color: var(--bg-secondary);
border-color: var(--border);
}
.el-card__header {
border-bottom-color: var(--border);
color: var(--text-primary);
}
.el-card__body {
color: var(--text-primary);
}
/* --- el-button 深色覆盖 --- */
.el-button--primary {
--el-button-bg-color: var(--accent);
--el-button-border-color: var(--accent);
--el-button-hover-bg-color: var(--accent-hover);
--el-button-hover-border-color: var(--accent-hover);
}
.el-button--default {
--el-button-bg-color: var(--bg-tertiary);
--el-button-border-color: var(--border);
--el-button-text-color: var(--text-secondary);
--el-button-hover-bg-color: var(--bg-tertiary);
--el-button-hover-border-color: var(--border-hover);
--el-button-hover-text-color: var(--text-primary);
}
.el-button--danger {
--el-button-bg-color: var(--danger);
--el-button-border-color: var(--danger);
}
.el-button--success {
--el-button-bg-color: var(--success);
--el-button-border-color: var(--success);
}
/* --- el-tag 深色覆盖 --- */
.el-tag {
--el-tag-bg-color: var(--accent-light);
--el-tag-border-color: var(--accent);
--el-tag-text-color: var(--accent);
}
.el-tag--success {
--el-tag-bg-color: var(--success-bg);
--el-tag-border-color: var(--success);
--el-tag-text-color: var(--success);
}
.el-tag--warning {
--el-tag-bg-color: var(--warning-bg);
--el-tag-border-color: var(--warning);
--el-tag-text-color: var(--warning);
}
.el-tag--danger {
--el-tag-bg-color: var(--danger-bg);
--el-tag-border-color: var(--danger);
--el-tag-text-color: var(--danger);
}
.el-tag--info {
--el-tag-bg-color: var(--bg-tertiary);
--el-tag-border-color: var(--text-muted);
--el-tag-text-color: var(--text-muted);
}
/* --- el-pagination 深色覆盖 --- */
.el-pagination {
color: var(--text-secondary);
}
.el-pagination .btn-prev,
.el-pagination .btn-next {
background-color: var(--bg-tertiary);
color: var(--text-secondary);
}
.el-pagination .el-pager li {
background-color: var(--bg-tertiary);
color: var(--text-secondary);
}
.el-pagination .el-pager li.is-active {
background-color: var(--accent);
color: #fff;
}
.el-pagination .el-pager li:hover {
color: var(--accent);
}
/* --- el-menu 深色覆盖(侧边栏用) --- */
.el-menu {
border-right: none;
}
.el-menu--vertical {
background-color: var(--bg-secondary);
}
.el-menu-item {
color: var(--text-secondary);
}
.el-menu-item:hover {
background-color: var(--bg-tertiary);
color: var(--text-primary);
}
.el-menu-item.is-active {
background-color: var(--accent-light);
color: var(--accent);
}
/* --- el-divider 深色覆盖 --- */
.el-divider {
border-top-color: var(--border);
}
/* --- el-checkbox 深色覆盖 --- */
.el-checkbox__label {
color: var(--text-secondary);
}
/* --- el-radio 深色覆盖 --- */
.el-radio__label {
color: var(--text-secondary);
}
/* --- el-popover / el-tooltip 深色覆盖 --- */
.el-popper.is-dark {
background-color: var(--bg-secondary);
color: var(--text-primary);
}
/* --- el-message-box 深色覆盖 --- */
.el-message-box {
background-color: var(--bg-secondary);
border: 1px solid var(--border);
}
.el-message-box__title {
color: var(--text-primary);
}
.el-message-box__message {
color: var(--text-secondary);
}
/* --- el-empty 深色覆盖 --- */
.el-empty__description p {
color: var(--text-muted);
}
/* --- el-tabs 深色覆盖 --- */
.el-tabs__item {
color: var(--text-secondary);
}
.el-tabs__item.is-active {
color: var(--accent);
}
.el-tabs__nav-wrap::after {
background-color: var(--border);
}
/* --- el-breadcrumb 深色覆盖 --- */
.el-breadcrumb__item span {
color: var(--text-muted);
}
.el-breadcrumb__item:last-child span {
color: var(--text-primary);
}
.el-breadcrumb__inner {
color: var(--text-muted);
}
.el-breadcrumb__inner.is-link:hover {
color: var(--accent);
}
/* --- el-input-number 深色覆盖 --- */
.el-input-number__decrease,
.el-input-number__increase {
background-color: var(--bg-tertiary);
color: var(--text-secondary);
}
.el-input-number__decrease:hover,
.el-input-number__increase:hover {
color: var(--accent);
}
/* --- el-textarea 深色覆盖 --- */
.el-textarea__inner {
background-color: var(--bg-primary);
border-color: var(--border);
color: var(--text-primary);
}
.el-textarea__inner:hover {
border-color: var(--border-hover);
}
.el-textarea__inner:focus {
border-color: var(--accent);
box-shadow: 0 0 0 1px var(--accent) inset;
}
/* --------------------------------------------------------------------------
自定义工具类
-------------------------------------------------------------------------- */
/* 页面标题 */
.page-title {
font-size: 20px;
font-weight: 600;
margin-bottom: 4px;
color: var(--text-primary);
}
/* 页面描述 */
.page-desc {
font-size: 13px;
color: var(--text-secondary);
margin-bottom: 24px;
}
/* 统计卡片网格 */
.stats-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 16px;
margin-bottom: 24px;
}
@media (max-width: 1200px) {
.stats-grid {
grid-template-columns: repeat(2, 1fr);
}
}
/* 双栏布局 */
.two-column {
display: grid;
grid-template-columns: 2fr 1fr;
gap: 16px;
}
/* 功能卡片网格 */
.feature-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 16px;
}
@media (max-width: 1200px) {
.feature-grid {
grid-template-columns: 1fr;
}
}
/* 集成卡片网格 */
.integration-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 16px;
}
@media (max-width: 1400px) {
.integration-grid {
grid-template-columns: repeat(2, 1fr);
}
}
/* 表格容器 */
.table-wrapper {
background: var(--bg-secondary);
border: 1px solid var(--border);
border-radius: var(--radius-lg);
overflow: hidden;
}
/* 表格标题行 */
.table-header-row {
display: flex;
align-items: center;
justify-content: space-between;
padding: 16px 20px;
border-bottom: 1px solid var(--border);
}
.table-header-row .table-title {
font-size: 15px;
font-weight: 600;
}
/* 分类标签 */
.category-tabs {
display: flex;
gap: 8px;
flex-wrap: wrap;
}
/* 弹性标签容器 */
.tag-group {
display: flex;
flex-wrap: wrap;
gap: 4px;
}
/* 布局容器 */
.admin-layout {
display: flex;
height: 100vh;
}
/* 主内容区容器 */
.main-content {
flex: 1;
display: flex;
flex-direction: column;
overflow: hidden;
}
/* 内容滚动区 */
.content-scroll {
flex: 1;
overflow-y: auto;
padding: 24px;
}
/* 顶部栏 */
.top-bar {
height: 56px;
background: var(--bg-secondary);
border-bottom: 1px solid var(--border);
display: flex;
align-items: center;
justify-content: space-between;
padding: 0 24px;
flex-shrink: 0;
}
/* 顶部栏左右区域 */
.top-bar-left {
display: flex;
align-items: center;
gap: 16px;
}
.top-bar-right {
display: flex;
align-items: center;
gap: 16px;
}
/* 用户头像 */
.user-avatar {
width: 32px;
height: 32px;
border-radius: 50%;
background: var(--accent);
display: flex;
align-items: center;
justify-content: center;
font-size: 13px;
font-weight: 600;
color: white;
}
/* 锁定的导航项/卡片 */
.locked-item {
opacity: 0.5;
pointer-events: none;
}
.locked-text {
font-size: 11px;
color: var(--text-muted);
font-style: italic;
}
/* 优先级标签 */
.priority-tag {
font-size: 9px;
padding: 1px 5px;
border-radius: 3px;
font-weight: 600;
}
.priority-p0 {
background: var(--danger-bg);
color: #f87171;
}
.priority-p1 {
background: var(--warning-bg);
color: #fbbf24;
}
.priority-p2 {
background: var(--success-bg);
color: #34d399;
}
/* 空状态占位 */
.placeholder-center {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
height: 100%;
color: var(--text-muted);
}
.placeholder-icon {
font-size: 64px;
margin-bottom: 16px;
opacity: 0.3;
}
.placeholder-title {
font-size: 18px;
margin-bottom: 8px;
color: var(--text-secondary);
}
.placeholder-desc {
font-size: 13px;
color: var(--text-muted);
margin-bottom: 24px;
}
/* 开关按钮样式(自定义覆盖 Element Plus */
.toggle-switch {
cursor: pointer;
}
/* 审核操作按钮组 */
.review-actions {
display: flex;
gap: 8px;
}