tango-ui-cw
Version:
A lightweight ui library with ClayW
375 lines (332 loc) • 15.5 kB
CSS
@import "./style.css";
@import "./utilities.css";
@import "./theme.css";
/*
* 这个文件定义了全局的CSS变量,主要用于主题颜色和一些常用的样式变量。
* 通过使用CSS变量,可以方便地在整个应用中统一管理和修改主题颜色。
* 其中,:root选择器定义了默认的颜色变量,而[data-theme="dark"]选择器则定义了暗色模式下的颜色变量。
* 这样可以通过切换data-theme属性来实现主题的切换。
* 另外,还定义了一些透明色、表格背景、工具提示等相关的颜色变量,以便在不同组件中使用。
* 这些变量可以根据需要进行调整,以适应不同的设计需求和用户偏好.
* added by clayw on 20260210
*/
:root {
--radius: 0.625rem;
/* 用于页面整体背景、大容器背景 */
--background: oklch(1 0 0);
--foreground: oklch(0.145 0 0);
/* ****** */
--card: oklch(1 0 0);
--card-foreground: oklch(0.145 0 0);
--popover: oklch(1 0 0);
--popover-foreground: oklch(0.145 0 0);
/* 按钮背景、品牌强调色、小区域 */
--primary: oklch(0.985 0 0);
--primary-foreground: oklch(0.205 0 0);
--success: oklch(0.72 0.19 149);
--success-foreground: oklch(0.985 0 0);
--destructive-foreground: oklch(0.985 0 0);
--input-accent: oklch(0.205 0 0);
--modal-bg: oklch(0.985 0 0);
--modal-ok-bg: oklch(0.205 0 0);
--modal-ok-fg: oklch(0.985 0 0);
--modal-cancel-bg: oklch(0.985 0 0);
--modal-cancel-fg: oklch(0.205 0 0);
--modal-shadow: 0 2px 10px color-mix(in oklch, var(--foreground) 10%, transparent);
--drawer-bg: oklch(0.985 0 0);
--drawer-ok-bg: oklch(0.205 0 0);
--drawer-ok-fg: oklch(0.985 0 0);
--drawer-cancel-bg: oklch(0.985 0 0);
--drawer-cancel-fg: oklch(0.205 0 0);
--datepicker-confirm-bg: oklch(0.205 0 0);
--datepicker-confirm-fg: oklch(0.985 0 0);
--datepicker-cancel-bg: oklch(0.985 0 0);
--datepicker-cancel-fg: oklch(0.205 0 0);
/* ****** */
--input-bg: oklch(0.985 0 0);
--input-shadow: 0 1px 3px color-mix(in oklch, var(--foreground) 8%, transparent);
--input-focus-shadow: 0 0 0 3px color-mix(in oklch, var(--input-accent) 25%, transparent);
--input-error-border: oklch(0.577 0.245 27.325);
--input-error-bg: oklch(0.97 0.014 27.325);
--input-error-fg: oklch(0.577 0.245 27.325);
--input-error-focus-shadow: 0 0 0 3px color-mix(in oklch, var(--input-error-border) 25%, transparent);
--secondary: oklch(0.97 0 0);
--secondary-foreground: oklch(0.205 0 0);
--muted: oklch(0.97 0 0);
--muted-foreground: oklch(0.556 0 0);
--accent: oklch(0.97 0 0);
--accent-foreground: oklch(0.205 0 0);
--destructive: oklch(0.577 0.245 27.325);
--border: oklch(0.922 0 0);
--input: oklch(0.922 0 0);
--sidebar: oklch(0.985 0 0);
--sidebar-foreground: oklch(0.145 0 0);
--sidebar-primary: oklch(0.205 0 0);
--sidebar-primary-foreground: oklch(0.985 0 0);
--sidebar-accent: oklch(0.97 0 0);
--sidebar-accent-foreground: oklch(0.205 0 0);
--sidebar-border: oklch(0.922 0 0);
--sidebar-ring: oklch(0.708 0 0);
/* 透明色 */
--transparent: rgba(0, 0, 0, 0);
/* Button 主题 token,组件源码只消费变量,不直接写死颜色 */
--button-outline-foreground: var(--foreground);
--button-transparent-border: color-mix(in oklch, var(--foreground) 35%, transparent);
--button-shadow-default: color-mix(in oklch, var(--foreground) 20%, transparent);
--button-enu-bg: color-mix(in oklch, var(--background) 86%, var(--foreground) 6%);
--button-enu-fg: var(--foreground);
--button-enu-shadow: 4px 4px 8px color-mix(in oklch, var(--foreground) 16%, transparent), -4px -4px 8px color-mix(in oklch, var(--background) 92%, white);
--button-enu-hover-shadow: inset 3px 3px 6px color-mix(in oklch, var(--foreground) 16%, transparent), inset -3px -3px 6px color-mix(in oklch, var(--background) 92%, white), 3px 3px 6px color-mix(in oklch, var(--foreground) 16%, transparent), -3px -3px 6px color-mix(in oklch, var(--background) 92%, white);
--button-enu-active-shadow: inset 4px 4px 8px color-mix(in oklch, var(--foreground) 22%, transparent), inset -4px -4px 8px color-mix(in oklch, var(--background) 92%, white);
--button-loading-light: var(--background);
--button-loading-dark: var(--foreground);
/* 用于Drawer组件亮色确认按钮颜色 */
--primary-drawer: oklch(0.205 0 0);
--primary-foreground-drawer: oklch(0.922 0 0);
--table-background: var(--card);
--table-hover: var(--muted-foreground);
--tooltip-background: oklch(0.205 0 0);
--tooltip-foreground: oklch(0.922 0 0);
--tooltip-border: oklch(0.205 0 0);
--tooltip-radius: var(--radius);
--tooltip-shadow: 0 2px 8px color-mix(in oklch, var(--foreground) 12%, transparent);
--ripple-color: oklch(0.205 0 0 / 20%);
/* MaterialButton 主题 token */
--material-button-ripple: color-mix(in oklch, var(--primary-foreground) 60%, transparent);
/* Space 主题 token */
--space-triangle-size: 50px;
--space-triangle-color: var(--primary);
--space-half-circle-w: 100px;
--space-half-circle-h: 50px;
--space-half-circle-color: var(--primary);
/* Layout 主题 token */
--layout-header-bg: oklch(0.88 0 0);
--layout-header-color: oklch(0.25 0 0);
--layout-header-height: 64px;
--layout-footer-bg: oklch(0.88 0 0);
--layout-footer-color: oklch(0.25 0 0);
--layout-footer-height: 48px;
--layout-sider-bg: oklch(0.82 0 0);
--layout-sider-color: oklch(0.25 0 0);
--layout-sider-width: 200px;
--layout-toc-bg: oklch(0.92 0 0);
--layout-toc-color: oklch(0.25 0 0);
--layout-toc-width: 180px;
--layout-content-bg: var(--background);
--layout-content-color: var(--foreground);
--layout-border: var(--border);
/* Line 主题 token */
--line-color: var(--border);
/* Mark 主题 token */
--mark-default-bg: oklch(0.92 0.07 90);
--mark-primary-bg: oklch(0.90 0.10 250);
--mark-success-bg: oklch(0.90 0.10 150);
--mark-warning-bg: oklch(0.92 0.12 80);
--mark-danger-bg: oklch(0.90 0.12 25);
/* Notice 主题 token */
--notice-bg: oklch(1 0 0 / 92%);
--notice-foreground: oklch(0.205 0 0);
--notice-radius: var(--radius);
--notice-shadow: 0 6px 16px color-mix(in oklch, var(--foreground) 8%, transparent), 0 3px 6px -4px color-mix(in oklch, var(--foreground) 12%, transparent), 0 9px 28px 8px color-mix(in oklch, var(--foreground) 5%, transparent);
--notice-success-text: oklch(0.52 0.17 149);
--notice-fail-text: oklch(0.58 0.24 27);
--notice-caution-text: oklch(0.68 0.16 60);
/* Upload 主题 token */
--upload-border: var(--border);
--upload-radius: var(--radius);
--upload-list-bg: var(--background);
--upload-item-text: var(--foreground);
--upload-item-hover-bg: var(--muted);
--upload-icon-color: var(--muted-foreground);
--upload-del-color: var(--muted-foreground);
--upload-del-hover-bg: var(--accent);
/* Banner 主题 token — 亮色(同色系:背景淡、边框中、图标深、文字暗) */
--banner-info-bg: oklch(0.95 0.04 250);
--banner-info-border: oklch(0.62 0.17 250);
--banner-info-icon: oklch(0.52 0.17 250);
--banner-info-text: oklch(0.30 0.09 250);
--banner-success-bg: oklch(0.94 0.05 149);
--banner-success-border: oklch(0.62 0.18 149);
--banner-success-icon: oklch(0.52 0.18 149);
--banner-success-text: oklch(0.30 0.11 149);
--banner-warning-bg: oklch(0.96 0.06 80);
--banner-warning-border: oklch(0.78 0.15 80);
--banner-warning-icon: oklch(0.68 0.16 60);
--banner-warning-text: oklch(0.38 0.11 60);
--banner-error-bg: oklch(0.94 0.04 25);
--banner-error-border: oklch(0.63 0.21 25);
--banner-error-icon: oklch(0.55 0.22 25);
--banner-error-text: oklch(0.32 0.13 25);
--banner-close-icon: oklch(0.45 0 0);
--banner-btn-text: oklch(0.35 0 0);
--banner-btn-border: color-mix(in oklch, var(--foreground) 30%, transparent);
}
[data-theme="dark"] {
--background: oklch(0.145 0 0);
--foreground: oklch(0.985 0 0);
--card: oklch(0.205 0 0);
--card-foreground: oklch(0.985 0 0);
--popover: oklch(0.205 0 0);
--popover-foreground: oklch(0.985 0 0);
--primary: oklch(0.205 0 0);
--primary-foreground: oklch(0.922 0 0);
--success: oklch(0.62 0.19 149);
--success-foreground: oklch(0.985 0 0);
--destructive-foreground: oklch(0.985 0 0);
--input-accent: oklch(0.985 0 0);
--modal-bg: oklch(0.205 0 0);
--modal-ok-bg: oklch(0.985 0 0);
--modal-ok-fg: oklch(0.205 0 0);
--modal-cancel-bg: oklch(0.205 0 0);
--modal-cancel-fg: oklch(0.985 0 0);
--modal-shadow: 0 2px 10px color-mix(in oklch, black 40%, transparent);
--drawer-bg: oklch(0.205 0 0);
--drawer-ok-bg: oklch(0.985 0 0);
--drawer-ok-fg: oklch(0.205 0 0);
--drawer-cancel-bg: oklch(0.205 0 0);
--drawer-cancel-fg: oklch(0.985 0 0);
--datepicker-confirm-bg: oklch(0.985 0 0);
--datepicker-confirm-fg: oklch(0.205 0 0);
--datepicker-cancel-bg: oklch(0.205 0 0);
--datepicker-cancel-fg: oklch(0.985 0 0);
--secondary: oklch(0.269 0 0);
--secondary-foreground: oklch(0.985 0 0);
--muted: oklch(0.269 0 0);
--muted-foreground: oklch(0.708 0 0);
--accent: oklch(0.269 0 0);
--accent-foreground: oklch(0.985 0 0);
--destructive: oklch(0.704 0.191 22.216);
--border: oklch(1 0 0 / 10%);
--input: oklch(1 0 0 / 15%);
--sidebar: oklch(0.205 0 0);
--sidebar-foreground: oklch(0.985 0 0);
--sidebar-primary: oklch(0.488 0.243 264.376);
--sidebar-primary-foreground: oklch(0.985 0 0);
--sidebar-accent: oklch(0.269 0 0);
--sidebar-accent-foreground: oklch(0.985 0 0);
--sidebar-border: oklch(1 0 0 / 10%);
--sidebar-ring: oklch(0.556 0 0);
/* 用于Drawer组件暗色确认按钮颜色 */
--primary-drawer: oklch(0.985 0 0);
--primary-foreground-drawer: oklch(0.205 0 0);
--button-outline-foreground: var(--foreground);
--button-transparent-border: color-mix(in oklch, var(--foreground) 45%, transparent);
--button-shadow-default: color-mix(in oklch, var(--foreground) 35%, transparent);
--button-enu-bg: color-mix(in oklch, var(--background) 78%, var(--foreground) 20%);
--button-enu-fg: var(--foreground);
--button-enu-shadow: 4px 4px 8px color-mix(in oklch, black 40%, transparent), -4px -4px 8px color-mix(in oklch, white 14%, transparent);
--button-enu-hover-shadow: inset 3px 3px 6px color-mix(in oklch, black 45%, transparent), inset -3px -3px 6px color-mix(in oklch, white 16%, transparent), 3px 3px 6px color-mix(in oklch, black 45%, transparent), -3px -3px 6px color-mix(in oklch, white 16%, transparent);
--button-enu-active-shadow: inset 4px 4px 8px color-mix(in oklch, black 52%, transparent), inset -4px -4px 8px color-mix(in oklch, white 20%, transparent);
--button-loading-light: var(--background);
--button-loading-dark: var(--foreground);
--table-background: var(--card);
--table-hover: var(--muted-foreground);
--tooltip-background: oklch(0.922 0 0);
--tooltip-foreground: oklch(0.205 0 0);
--tooltip-border: oklch(0.922 0 0);
--tooltip-radius: var(--radius);
--tooltip-shadow: 0 2px 8px color-mix(in oklch, black 30%, transparent);
--input-bg: oklch(0.205 0 0);
--input-shadow: 0 1px 3px color-mix(in oklch, black 30%, transparent);
--input-focus-shadow: 0 0 0 3px color-mix(in oklch, var(--input-accent) 25%, transparent);
--input-error-border: oklch(0.704 0.191 22.216);
--input-error-bg: oklch(0.24 0.04 25);
--input-error-fg: oklch(0.704 0.191 22.216);
--input-error-focus-shadow: 0 0 0 3px color-mix(in oklch, var(--input-error-border) 25%, transparent);
/* Banner 主题 token — 暗色(同色系:背景深、边框中暗、图标亮、文字亮) */
--banner-info-bg: oklch(0.24 0.06 250);
--banner-info-border: oklch(0.45 0.15 250);
--banner-info-icon: oklch(0.65 0.18 250);
--banner-info-text: oklch(0.83 0.07 250);
--banner-success-bg: oklch(0.24 0.06 149);
--banner-success-border: oklch(0.45 0.15 149);
--banner-success-icon: oklch(0.65 0.19 149);
--banner-success-text: oklch(0.83 0.08 149);
--banner-warning-bg: oklch(0.27 0.06 80);
--banner-warning-border: oklch(0.50 0.13 80);
--banner-warning-icon: oklch(0.72 0.15 60);
--banner-warning-text: oklch(0.83 0.08 60);
--banner-error-bg: oklch(0.24 0.05 25);
--banner-error-border: oklch(0.45 0.16 25);
--banner-error-icon: oklch(0.65 0.22 25);
--banner-error-text: oklch(0.83 0.08 25);
--banner-close-icon: oklch(0.7 0 0);
--banner-btn-text: oklch(0.8 0 0);
--banner-btn-border: color-mix(in oklch, var(--foreground) 40%, transparent);
--material-button-ripple: color-mix(in oklch, var(--primary-foreground) 60%, transparent);
/* Space 主题 token */
--space-triangle-size: 50px;
--space-triangle-color: var(--primary);
--space-half-circle-w: 100px;
--space-half-circle-h: 50px;
--space-half-circle-color: var(--primary);
/* Layout 主题 token */
--layout-header-bg: oklch(0.28 0 0);
--layout-header-color: oklch(0.85 0 0);
--layout-header-height: 64px;
--layout-footer-bg: oklch(0.28 0 0);
--layout-footer-color: oklch(0.85 0 0);
--layout-footer-height: 48px;
--layout-sider-bg: oklch(0.22 0 0);
--layout-sider-color: oklch(0.85 0 0);
--layout-sider-width: 200px;
--layout-toc-bg: oklch(0.26 0 0);
--layout-toc-color: oklch(0.85 0 0);
--layout-toc-width: 180px;
--layout-content-bg: var(--background);
--layout-content-color: var(--foreground);
--layout-border: var(--border);
/* Line 主题 token */
--line-color: var(--border);
/* Mark 主题 token(暗色:饱和度更高、亮度更低) */
--mark-default-bg: oklch(0.50 0.10 90);
--mark-primary-bg: oklch(0.45 0.15 250);
--mark-success-bg: oklch(0.45 0.15 150);
--mark-warning-bg: oklch(0.50 0.15 80);
--mark-danger-bg: oklch(0.45 0.15 25);
/* Notice 主题 token */
--notice-bg: oklch(0.205 0 0 / 92%);
--notice-foreground: oklch(0.985 0 0);
--notice-radius: var(--radius);
--notice-shadow: 0 6px 16px color-mix(in oklch, black 40%, transparent), 0 3px 6px -4px color-mix(in oklch, black 30%, transparent), 0 9px 28px 8px color-mix(in oklch, black 20%, transparent);
--notice-success-text: oklch(0.72 0.19 149);
--notice-fail-text: oklch(0.70 0.19 22);
--notice-caution-text: oklch(0.78 0.15 60);
/* Upload 主题 token */
--upload-border: var(--border);
--upload-radius: var(--radius);
--upload-list-bg: var(--background);
--upload-item-text: var(--foreground);
--upload-item-hover-bg: var(--muted);
--upload-icon-color: var(--muted-foreground);
--upload-del-color: var(--muted-foreground);
--upload-del-hover-bg: var(--accent);
}
/* Layout 响应式:窄屏下 Sider/Toc 变全宽 */
@media (max-width: 768px) {
:root,
[data-theme="dark"] {
--layout-sider-width: 100%;
--layout-toc-width: 100%;
--layout-header-height: 48px;
--layout-footer-height: 40px;
}
}
/* Notice 动画 */
@keyframes noticeSlideDown {
0% { transform: translateX(-50%) translateY(-50px); opacity: 0; }
80% { transform: translateX(-50%) translateY(4px); opacity: 1; }
100% { transform: translateX(-50%) translateY(0); opacity: 1; }
}
@keyframes noticeSlideUpFade {
from { transform: translateX(-50%) translateY(0); opacity: 1; }
to { transform: translateX(-50%) translateY(-20px); opacity: 0; }
}
@keyframes noticeSlideFromBottom {
from { transform: translateX(0); opacity: 0; }
to { transform: translateX(2%); opacity: 1; }
}
@keyframes noticeSlideToBottom {
from { transform: translateX(2%); opacity: 1; }
to { transform: translateX(0); opacity: 0; }
}