初始化拉取,原文件名:admin-plus-webpack5
Some checks failed
Call HTTPS API / build (push) Has been cancelled

This commit is contained in:
2025-12-26 20:43:10 +08:00
parent 7c68ec3a42
commit 3e2da1115e
420 changed files with 75413 additions and 2 deletions

View File

@@ -0,0 +1,251 @@
/**
* @description 黑
*/
body.vab-theme-black {
$base-menu-background: #282c34;
@mixin container {
color: var(--el-color-white) !important;
background: $base-menu-background !important;
}
@mixin active {
&:hover {
color: var(--el-color-white) !important;
background-color: var(--el-color-primary) !important;
}
&.is-active {
color: var(--el-color-white) !important;
background-color: var(--el-color-primary) !important;
}
}
.logo-container-vertical,
.logo-container-horizontal,
.logo-container-comprehensive,
.logo-container-float {
@include container;
}
.logo-container-column {
.logo {
@include container;
}
}
.vab-column-bar-container.el-scrollbar {
.el-tabs {
.el-tabs__nav-wrap.is-left {
@include container;
}
.el-tabs__nav {
@include container;
}
.el-tabs__item.is-active {
background: var(--el-color-primary) !important;
}
}
.el-menu {
.el-menu-item.is-active,
.el-sub-menu__title.is-active,
.el-menu-item:hover,
.el-sub-menu__title:hover {
i {
color: var(--el-color-primary) !important;
}
color: var(--el-color-primary) !important;
background-color: var(--el-color-primary-light-9) !important;
}
}
}
.vab-column-bar-container-card.el-scrollbar {
.el-tabs {
.el-tabs__item.is-active {
background: transparent !important;
.vab-column-grid {
background: var(--el-color-primary) !important;
}
}
}
}
.vab-column-bar-container-arrow.el-scrollbar {
.el-tabs {
.el-tabs__item.is-active {
background: transparent !important;
.vab-column-grid {
background: transparent !important;
}
}
}
}
.vab-layout-float,
.vab-layout-common,
.vab-layout-vertical,
.vab-layout-horizontal,
.vab-layout-comprehensive {
.el-menu {
@include container;
.el-sub-menu .el-sub-menu__title,
.el-menu-item {
@include container;
}
}
.vab-side-bar,
.comprehensive-bar-container {
@include container;
.el-menu-item {
@include active;
}
}
}
.vab-layout-float {
.el-scrollbar__view
.el-menu--collapse.el-menu
li.el-sub-menu.is-active {
.el-sub-menu__title {
background-color: transparent !important;
}
> .el-sub-menu__title {
background-color: var(--el-color-primary) !important;
}
}
}
.vab-header {
@include container;
.vab-main {
@include container;
.right-panel {
.el-menu {
&--horizontal {
.el-sub-menu .el-sub-menu__title,
.el-menu-item {
@include active;
}
}
}
[role='menubar'].el-menu--horizontal {
> .el-sub-menu.is-active[tabindex='0'] {
> .el-sub-menu__title {
color: var(--el-color-white) !important;
background-color: var(
--el-color-primary
) !important;
}
}
}
}
}
}
.vab-tabs {
&-more {
&-active,
&:hover {
.vab-tabs-more-icon {
.box:before,
.box:after {
background: var(--el-color-primary) !important;
}
}
}
}
.vab-tabs-content-card {
.el-tabs__header {
.el-tabs__item {
&.is-active {
color: var(--el-color-primary) !important;
background: var(--el-color-primary-light-9) !important;
border: 1px solid var(--el-color-primary) !important;
}
&:hover {
border: 1px solid var(--el-color-primary) !important;
}
}
}
}
.vab-tabs-content-smart {
.el-tabs__header {
.el-tabs__item {
&.is-active {
background: var(--el-color-primary-light-9) !important;
}
&:after {
background-color: var(--el-color-primary) !important;
}
&:hover {
background: var(--el-color-primary-light-9) !important;
}
}
}
}
.vab-tabs-content-smooth {
.el-tabs__header {
.el-tabs__item {
&.is-active {
color: var(--el-color-primary) !important;
background: var(--el-color-primary-light-9) !important;
&:hover {
color: var(--el-color-primary) !important;
background: var(
--el-color-primary-light-9
) !important;
}
}
&:hover {
color: var(--el-color-black) !important;
}
}
}
}
}
.vab-nav {
.el-tabs__item.is-active,
.el-tabs__item:hover {
color: var(--el-color-primary) !important;
}
.el-tabs__active-bar {
background-color: var(--el-color-primary) !important;
}
}
#nprogress {
.bar {
background: var(--el-color-primary) !important;
}
.peg {
box-shadow:
0 0 10px var(--el-color-primary),
0 0 5px var(--el-color-primary) !important;
}
}
}

View File

@@ -0,0 +1,108 @@
/**
* @description 菜单背景
*/
body.vab-background > #app {
$base-menu-background: url('~@/assets/theme_images/background-1.png')
no-repeat;
@mixin container {
color: $base-color-white !important;
background: $base-menu-background !important;
background-size: auto 100% !important;
}
@mixin transparent {
color: $base-color-white !important;
background: transparent !important;
}
@mixin active {
span {
color: $base-color-white !important;
}
&:hover {
color: $base-color-white !important;
background-color: rgba(0, 0, 0, 0.3) !important;
}
&.is-active {
color: $base-color-white !important;
background-color: rgba(0, 0, 0, 0.3) !important;
}
}
.vab-side-bar:not(.is-collapse),
.comprehensive-bar-container {
@include container;
.el-menu {
@include transparent;
.el-menu-item,
.el-sub-menu__title {
@include transparent;
@include active;
i,
svg {
@include transparent;
}
}
}
.logo-container-vertical,
.logo-container-comprehensive,
.logo-container-float {
@include transparent;
.logo .vab-icon,
.title {
@include transparent;
}
}
}
.vab-column-bar-container {
&.el-scrollbar {
.logo-container-column {
.logo {
@include container;
background: #034291 !important;
.vab-icon {
@include transparent;
}
}
}
.el-tabs {
.el-tabs__nav-wrap.is-left {
@include container;
}
.el-tabs__nav,
.el-tabs__item {
@include transparent;
&.is-active {
color: $base-color-white !important;
background-color: rgba(0, 0, 0, 0.3) !important;
}
}
}
&.vab-column-bar-container-card {
.el-tabs {
.el-tabs__item {
&.is-active {
background: transparent !important;
.vab-column-grid {
background-color: rgba(0, 0, 0, 0.3) !important;
}
}
}
}
}
}
}
}

View File

@@ -0,0 +1,181 @@
/**
* @description 渐变
*/
body.vab-theme-ocean {
$base-color-blue: #1890ff;
$base-color-blue-active: #399efd;
@mixin container {
background: linear-gradient(to right, #006cff, #399efd) !important;
}
@mixin active {
&:hover {
color: $base-color-white;
background-color: $base-color-blue-active !important;
}
&.is-active {
color: $base-color-white;
background-color: $base-color-blue-active !important;
}
}
.logo-container-horizontal {
background: var(--el-color-primary) !important;
}
.logo-container-vertical,
.logo-container-comprehensive,
.logo-container-float {
@include container;
}
.logo-container-column {
.logo {
@include container;
}
}
.vab-column-bar-container {
.el-tabs {
.el-tabs__nav-wrap.is-left {
@include container;
}
.el-tabs__nav {
@include container;
}
}
.el-menu {
.el-menu-item.is-active,
.el-sub-menu__title.is-active,
.el-menu-item:hover,
.el-sub-menu__title:hover {
i {
color: var(--el-color-primary) !important;
}
color: var(--el-color-primary) !important;
background-color: var(--el-color-primary-light-9) !important;
}
}
&-card {
.el-tabs {
.el-tabs__item {
&.is-active {
background: transparent !important;
}
}
}
}
}
.vab-layout-horizontal {
.vab-header {
background: var(--el-color-primary) !important;
}
.el-menu {
background: var(--el-color-primary) !important;
.el-sub-menu__title {
background: var(--el-color-primary) !important;
}
.el-menu-item {
background: var(--el-color-primary) !important;
}
}
.vab-side-bar,
.comprehensive-bar-container {
background: var(--el-color-primary) !important;
.el-menu-item {
@include active;
}
}
}
.vab-layout-vertical,
.vab-layout-comprehensive,
.vab-layout-common,
.vab-layout-float {
.vab-side-bar,
.comprehensive-bar-container {
@include container;
.el-menu {
@include container;
@include active;
.el-sub-menu__title,
.el-menu-item {
background-color: transparent !important;
@include active;
&.is-active {
background-color: $base-color-blue-active !important;
}
}
}
}
}
.vab-layout-float {
.el-scrollbar__view
.el-menu--collapse.el-menu
li.el-sub-menu.is-active {
.el-sub-menu__title {
background-color: transparent !important;
}
> .el-sub-menu__title {
background-color: var(--el-color-primary) !important;
}
}
}
.vab-header {
background-color: var(--el-color-primary) !important;
.vab-main {
.el-menu.el-menu {
background-color: var(--el-color-primary) !important;
&--horizontal {
.el-sub-menu,
.el-menu-item {
background-color: var(--el-color-primary) !important;
&.is-active {
color: $base-color-white !important;
background-color: $base-color-blue-active !important;
}
}
> .el-menu-item,
.el-sub-menu__title,
> .el-menu-item:hover,
> .el-sub-menu__title:hover {
color: $base-color-white !important;
background-color: var(--el-color-primary) !important;
i {
color: $base-color-white !important;
}
&.is-active {
color: $base-color-white !important;
background-color: $base-color-blue-active !important;
}
}
}
}
}
}
}

View File

@@ -0,0 +1,293 @@
/**
* @description 白
*/
body.vab-theme-white {
$base-menu-background: #fff;
@mixin container {
color: #515a6e !important;
background: $base-menu-background !important;
}
@mixin active {
&:hover {
color: var(--el-color-primary) !important;
background-color: var(--el-color-primary-light-9) !important;
i,
svg,
span[title] {
color: var(--el-color-primary) !important;
}
}
&.is-active {
color: var(--el-color-primary) !important;
background-color: var(--el-color-primary-light-9) !important;
i,
svg,
span[title] {
color: var(--el-color-primary) !important;
}
}
}
.logo-container-common,
.logo-container-vertical,
.logo-container-horizontal,
.logo-container-comprehensive,
.logo-container-float {
@include container;
.title,
.vab-icon {
@include container;
}
}
.logo-container-column {
@include container;
.title {
@include container;
}
.logo,
.vab-icon {
@include container;
}
}
.vab-column-bar-container {
.el-tabs {
@include container;
.el-tabs__nav-wrap.is-left {
background: #f7faff !important;
}
.el-tabs__item,
.el-tabs__nav {
@include container;
}
.el-tabs__item.is-active {
color: var(--el-color-white) !important;
background: var(--el-color-primary) !important;
}
}
.el-menu {
.el-menu-item.is-active,
.el-sub-menu__title.is-active,
.el-menu-item:hover,
.el-sub-menu__title:hover {
i {
color: var(--el-color-primary) !important;
}
color: var(--el-color-primary) !important;
background-color: var(--el-color-primary-light-9) !important;
}
}
&-card {
.el-tabs {
.el-tabs__item {
&.is-active {
background: transparent !important;
}
}
}
}
&-arrow {
.el-tabs {
.el-tabs__item {
&.is-active {
color: var(--el-color-black) !important;
background: transparent !important;
.vab-column-grid {
background: transparent !important;
}
}
}
}
}
}
.vab-layout-float,
.vab-layout-common,
.vab-layout-vertical,
.vab-layout-horizontal,
.vab-layout-comprehensive {
.el-menu {
@include container;
.el-sub-menu .el-sub-menu__title,
.el-menu-item {
@include container;
}
.el-menu-item.is-active,
.el-sub-menu__title.is-active,
.el-menu-item:hover,
.el-sub-menu__title:hover {
i {
color: var(--el-color-primary) !important;
}
color: var(--el-color-primary) !important;
background-color: var(--el-color-primary-light-9) !important;
}
}
.vab-side-bar,
.comprehensive-bar-container {
@include container;
.el-menu-item {
@include active;
}
}
}
.vab-layout-float {
.el-scrollbar__view
.el-menu--collapse.el-menu
li.el-sub-menu.is-active {
.el-sub-menu__title {
background-color: transparent !important;
}
> .el-sub-menu__title {
color: var(--el-color-primary) !important;
background-color: var(--el-color-primary-light-9) !important;
}
}
}
.vab-header {
@include container;
.vab-main {
@include container;
.right-panel {
.user-name,
.user-name *,
> i,
> div > i,
> span > i,
> div > span > i,
> svg,
> div > svg,
> span > svg,
> div > span > svg,
.ri-notification-line,
.ri-translate,
.ri-bug-line {
@include container;
}
.el-menu {
&--horizontal {
.el-sub-menu .el-sub-menu__title,
.el-menu-item {
@include active;
}
.el-sub-menu,
.el-menu-item {
&.is-active {
@include active;
}
}
> .el-sub-menu.is-active {
> .el-sub-menu__title {
background-color: var(
--el-color-primary-light-9
) !important;
@include active;
}
}
}
}
}
}
}
.vab-tabs {
&-more {
&-active,
&:hover {
.vab-tabs-more-icon {
.box:before,
.box:after {
background: var(--el-color-primary) !important;
}
}
}
}
.vab-tabs-content-card {
.el-tabs__header {
.el-tabs__item {
&.is-active {
color: var(--el-color-primary) !important;
background: var(--el-color-primary-light-9) !important;
border: 1px solid var(--el-color-primary) !important;
}
&:hover {
border: 1px solid var(--el-color-primary) !important;
}
}
}
}
.vab-tabs-content-smart {
.el-tabs__header {
.el-tabs__item {
&.is-active {
background: var(--el-color-primary-light-9) !important;
}
&:after {
background-color: var(--el-color-primary) !important;
}
&:hover {
background: var(--el-color-primary-light-9) !important;
}
}
}
}
.vab-tabs-content-smooth {
.el-tabs__header {
.el-tabs__item {
&.is-active {
color: var(--el-color-primary) !important;
background: var(--el-color-primary-light-9) !important;
&:hover {
color: var(--el-color-primary) !important;
background: var(
--el-color-primary-light-9
) !important;
}
}
&:hover {
color: var(--el-color-black) !important;
}
}
}
}
}
}

View File

@@ -0,0 +1,124 @@
.dots-loader:not(:required) {
position: relative;
display: inline-block;
width: 7px;
height: 7px;
margin-bottom: 30px;
overflow: hidden;
text-indent: -9999px;
background: transparent;
border-radius: 100%;
box-shadow:
#f86 -14px -14px 0 7px,
#fc6 14px -14px 0 7px,
#6d7 14px 14px 0 7px,
#4ae -14px 14px 0 7px;
transform-origin: 50% 50%;
animation: dots-loader 5s infinite ease-in-out;
}
@keyframes dots-loader {
0% {
box-shadow:
#f86 -14px -14px 0 7px,
#fc6 14px -14px 0 7px,
#6d7 14px 14px 0 7px,
#4ae -14px 14px 0 7px;
}
8.33% {
box-shadow:
#f86 14px -14px 0 7px,
#fc6 14px -14px 0 7px,
#6d7 14px 14px 0 7px,
#4ae -14px 14px 0 7px;
}
16.67% {
box-shadow:
#f86 14px 14px 0 7px,
#fc6 14px 14px 0 7px,
#6d7 14px 14px 0 7px,
#4ae -14px 14px 0 7px;
}
25% {
box-shadow:
#f86 -14px 14px 0 7px,
#fc6 -14px 14px 0 7px,
#6d7 -14px 14px 0 7px,
#4ae -14px 14px 0 7px;
}
33.33% {
box-shadow:
#f86 -14px -14px 0 7px,
#fc6 -14px 14px 0 7px,
#6d7 -14px -14px 0 7px,
#4ae -14px -14px 0 7px;
}
41.67% {
box-shadow:
#f86 14px -14px 0 7px,
#fc6 -14px 14px 0 7px,
#6d7 -14px -14px 0 7px,
#4ae 14px -14px 0 7px;
}
50% {
box-shadow:
#f86 14px 14px 0 7px,
#fc6 -14px 14px 0 7px,
#6d7 -14px -14px 0 7px,
#4ae 14px -14px 0 7px;
}
58.33% {
box-shadow:
#f86 -14px 14px 0 7px,
#fc6 -14px 14px 0 7px,
#6d7 -14px -14px 0 7px,
#4ae 14px -14px 0 7px;
}
66.67% {
box-shadow:
#f86 -14px -14px 0 7px,
#fc6 -14px -14px 0 7px,
#6d7 -14px -14px 0 7px,
#4ae 14px -14px 0 7px;
}
75% {
box-shadow:
#f86 14px -14px 0 7px,
#fc6 14px -14px 0 7px,
#6d7 14px -14px 0 7px,
#4ae 14px -14px 0 7px;
}
83.33% {
box-shadow:
#f86 14px 14px 0 7px,
#fc6 14px -14px 0 7px,
#6d7 14px 14px 0 7px,
#4ae 14px 14px 0 7px;
}
91.67% {
box-shadow:
#f86 -14px 14px 0 7px,
#fc6 14px -14px 0 7px,
#6d7 14px 14px 0 7px,
#4ae -14px 14px 0 7px;
}
100% {
box-shadow:
#f86 -14px -14px 0 7px,
#fc6 14px -14px 0 7px,
#6d7 14px 14px 0 7px,
#4ae -14px 14px 0 7px;
}
}

View File

@@ -0,0 +1,104 @@
.gauge-loader:not(:required) {
position: relative;
display: inline-block;
width: 64px;
height: 32px;
margin-bottom: 10px;
overflow: hidden;
text-indent: -9999px;
background: #6ca;
border-top-left-radius: 32px;
border-top-right-radius: 32px;
}
.gauge-loader:not(:required)::before {
position: absolute;
top: 5px;
left: 30px;
width: 4px;
height: 27px;
content: '';
background: white;
border-radius: 2px;
transform-origin: 50% 100%;
animation: gauge-loader 4000ms infinite ease;
}
.gauge-loader:not(:required)::after {
position: absolute;
top: 26px;
left: 26px;
width: 13px;
height: 13px;
content: '';
background: white;
-moz-border-radius: 8px;
-webkit-border-radius: 8px;
border-radius: 8px;
}
@keyframes gauge-loader {
0% {
transform: rotate(-50deg);
}
10% {
transform: rotate(20deg);
}
20% {
transform: rotate(60deg);
}
24% {
transform: rotate(60deg);
}
40% {
transform: rotate(-20deg);
}
54% {
transform: rotate(70deg);
}
56% {
transform: rotate(78deg);
}
58% {
transform: rotate(73deg);
}
60% {
transform: rotate(75deg);
}
62% {
transform: rotate(70deg);
}
70% {
transform: rotate(-20deg);
}
80% {
transform: rotate(20deg);
}
83% {
transform: rotate(25deg);
}
86% {
transform: rotate(20deg);
}
89% {
transform: rotate(25deg);
}
100% {
transform: rotate(-50deg);
}
}

View File

@@ -0,0 +1,51 @@
.inner-circles-loader:not(:required) {
position: relative;
display: inline-block;
width: 50px;
height: 50px;
margin-bottom: 10px;
overflow: hidden;
text-indent: -9999px;
background: rgba(25, 165, 152, 0.5);
border-radius: 50%;
transform: translate3d(0, 0, 0);
}
.inner-circles-loader:not(:required)::before,
.inner-circles-loader:not(:required)::after {
position: absolute;
top: 0;
display: inline-block;
width: 50px;
height: 50px;
content: '';
border-radius: 50%;
}
.inner-circles-loader:not(:required)::before {
left: 0;
background: #c7efcf;
transform-origin: 0 50%;
animation: inner-circles-loader 3s infinite;
}
.inner-circles-loader:not(:required)::after {
right: 0;
background: #eef5db;
transform-origin: 100% 50%;
animation: inner-circles-loader 3s 0.2s reverse infinite;
}
@keyframes inner-circles-loader {
0% {
transform: rotate(0deg);
}
50% {
transform: rotate(360deg);
}
100% {
transform: rotate(0deg);
}
}

View File

@@ -0,0 +1,341 @@
.plus-loader:not(:required) {
position: relative;
display: inline-block;
width: 48px;
height: 48px;
margin-bottom: 10px;
overflow: hidden;
text-indent: -9999px;
background: #f86;
-moz-border-radius: 24px;
-webkit-border-radius: 24px;
border-radius: 24px;
-moz-transform: rotateZ(90deg);
-ms-transform: rotateZ(90deg);
-webkit-transform: rotateZ(90deg);
transform: rotateZ(90deg);
-moz-transform-origin: 50% 50%;
-ms-transform-origin: 50% 50%;
-webkit-transform-origin: 50% 50%;
transform-origin: 50% 50%;
-moz-animation: plus-loader-background 3s infinite ease-in-out;
-webkit-animation: plus-loader-background 3s infinite ease-in-out;
animation: plus-loader-background 3s infinite ease-in-out;
}
.plus-loader:not(:required)::after {
position: absolute;
top: 0;
right: 50%;
width: 50%;
height: 100%;
content: '';
background: #f86;
-moz-border-radius: 24px 0 0 24px;
-webkit-border-radius: 24px;
border-radius: 24px 0 0 24px;
-moz-transform-origin: 100% 50%;
-ms-transform-origin: 100% 50%;
-webkit-transform-origin: 100% 50%;
transform-origin: 100% 50%;
-moz-animation: plus-loader-top 3s infinite linear;
-webkit-animation: plus-loader-top 3s infinite linear;
animation: plus-loader-top 3s infinite linear;
}
.plus-loader:not(:required)::before {
position: absolute;
top: 0;
right: 50%;
width: 50%;
height: 100%;
content: '';
background: #fc6;
-moz-border-radius: 24px 0 0 24px;
-webkit-border-radius: 24px;
border-radius: 24px 0 0 24px;
-moz-transform-origin: 100% 50%;
-ms-transform-origin: 100% 50%;
-webkit-transform-origin: 100% 50%;
transform-origin: 100% 50%;
-moz-animation: plus-loader-bottom 3s infinite linear;
-webkit-animation: plus-loader-bottom 3s infinite linear;
animation: plus-loader-bottom 3s infinite linear;
}
@keyframes plus-loader-top {
2.5% {
background: #f86;
-moz-transform: rotateY(0deg);
-ms-transform: rotateY(0deg);
-webkit-transform: rotateY(0deg);
transform: rotateY(0deg);
-moz-animation-timing-function: ease-in;
-webkit-animation-timing-function: ease-in;
animation-timing-function: ease-in;
}
13.75% {
background: #ff430d;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
13.76% {
background: #ffae0d;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: ease-out;
-webkit-animation-timing-function: ease-out;
animation-timing-function: ease-out;
}
25% {
background: #fc6;
-moz-transform: rotateY(180deg);
-ms-transform: rotateY(180deg);
-webkit-transform: rotateY(180deg);
transform: rotateY(180deg);
}
27.5% {
background: #fc6;
-moz-transform: rotateY(180deg);
-ms-transform: rotateY(180deg);
-webkit-transform: rotateY(180deg);
transform: rotateY(180deg);
-moz-animation-timing-function: ease-in;
-webkit-animation-timing-function: ease-in;
animation-timing-function: ease-in;
}
41.25% {
background: #ffae0d;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
41.26% {
background: #2cc642;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: ease-out;
-webkit-animation-timing-function: ease-out;
animation-timing-function: ease-out;
}
50% {
background: #6d7;
-moz-transform: rotateY(0deg);
-ms-transform: rotateY(0deg);
-webkit-transform: rotateY(0deg);
transform: rotateY(0deg);
}
52.5% {
background: #6d7;
-moz-transform: rotateY(0deg);
-ms-transform: rotateY(0deg);
-webkit-transform: rotateY(0deg);
transform: rotateY(0deg);
-moz-animation-timing-function: ease-in;
-webkit-animation-timing-function: ease-in;
animation-timing-function: ease-in;
}
63.75% {
background: #2cc642;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
63.76% {
background: #1386d2;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: ease-out;
-webkit-animation-timing-function: ease-out;
animation-timing-function: ease-out;
}
75% {
background: #4ae;
-moz-transform: rotateY(180deg);
-ms-transform: rotateY(180deg);
-webkit-transform: rotateY(180deg);
transform: rotateY(180deg);
}
77.5% {
background: #4ae;
-moz-transform: rotateY(180deg);
-ms-transform: rotateY(180deg);
-webkit-transform: rotateY(180deg);
transform: rotateY(180deg);
-moz-animation-timing-function: ease-in;
-webkit-animation-timing-function: ease-in;
animation-timing-function: ease-in;
}
91.25% {
background: #1386d2;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
91.26% {
background: #ff430d;
-moz-transform: rotateY(90deg);
-ms-transform: rotateY(90deg);
-webkit-transform: rotateY(90deg);
transform: rotateY(90deg);
-moz-animation-timing-function: ease-in;
-webkit-animation-timing-function: ease-in;
animation-timing-function: ease-in;
}
100% {
background: #f86;
-moz-transform: rotateY(0deg);
-ms-transform: rotateY(0deg);
-webkit-transform: rotateY(0deg);
transform: rotateY(0deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
}
@keyframes plus-loader-bottom {
0% {
background: #fc6;
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
50% {
background: #fc6;
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
75% {
background: #4ae;
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
100% {
background: #4ae;
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
}
@keyframes plus-loader-background {
0% {
background: #f86;
-moz-transform: rotateZ(180deg);
-ms-transform: rotateZ(180deg);
-webkit-transform: rotateZ(180deg);
transform: rotateZ(180deg);
}
25% {
background: #f86;
-moz-transform: rotateZ(180deg);
-ms-transform: rotateZ(180deg);
-webkit-transform: rotateZ(180deg);
transform: rotateZ(180deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
27.5% {
background: #6d7;
-moz-transform: rotateZ(90deg);
-ms-transform: rotateZ(90deg);
-webkit-transform: rotateZ(90deg);
transform: rotateZ(90deg);
}
50% {
background: #6d7;
-moz-transform: rotateZ(90deg);
-ms-transform: rotateZ(90deg);
-webkit-transform: rotateZ(90deg);
transform: rotateZ(90deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
52.5% {
background: #6d7;
-moz-transform: rotateZ(0deg);
-ms-transform: rotateZ(0deg);
-webkit-transform: rotateZ(0deg);
transform: rotateZ(0deg);
}
75% {
background: #6d7;
-moz-transform: rotateZ(0deg);
-ms-transform: rotateZ(0deg);
-webkit-transform: rotateZ(0deg);
transform: rotateZ(0deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
77.5% {
background: #f86;
-moz-transform: rotateZ(270deg);
-ms-transform: rotateZ(270deg);
-webkit-transform: rotateZ(270deg);
transform: rotateZ(270deg);
}
100% {
background: #f86;
-moz-transform: rotateZ(270deg);
-ms-transform: rotateZ(270deg);
-webkit-transform: rotateZ(270deg);
transform: rotateZ(270deg);
-moz-animation-timing-function: step-start;
-webkit-animation-timing-function: step-start;
animation-timing-function: step-start;
}
}

377
library/styles/normalize.scss vendored Normal file
View File

@@ -0,0 +1,377 @@
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
========================================================================== */
/**
* 1. Correct the line height in all browsers.
* 2. Prevent adjustments of font size after orientation changes in iOS.
*/
html {
line-height: 1.15;
/* 1 */
-webkit-text-size-adjust: 100%;
/* 2 */
}
/* Sections
========================================================================== */
/**
* Remove the margin in all browsers.
*/
body {
margin: 0;
}
/**
* Render the `main` element consistently in IE.
*/
main {
display: block;
}
/**
* Correct the font size and margin on `h1` elements within `section` and
* `article` contexts in Chrome, Firefox, and Safari.
*/
h1 {
margin: 0.67em 0;
font-size: 2em;
}
/* Grouping content
========================================================================== */
/**
* 1. Add the correct box sizing in Firefox.
* 2. Show the overflow in Edge and IE.
*/
hr {
box-sizing: content-box;
/* 1 */
height: 0;
/* 1 */
overflow: visible;
/* 2 */
}
/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/
pre {
font-family: monospace;
/* 1 */
font-size: 1em;
/* 2 */
}
/* Text-level semantics
========================================================================== */
/**
* Remove the gray background on active links in IE 10.
*/
a {
background-color: transparent;
}
/**
* 1. Remove the bottom border in Chrome 57-
* 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
*/
abbr[title] {
text-decoration: underline dotted;
/* 2 */
border-bottom: none;
/* 1 */
}
/**
* Add the correct font weight in Chrome, Edge, and Safari.
*/
b,
strong {
font-weight: bolder;
}
/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp {
font-family: monospace;
/* 1 */
font-size: 1em;
/* 2 */
}
/**
* Add the correct font size in all browsers.
*/
small {
font-size: 80%;
}
/**
* Prevent `sub` and `sup` elements from affecting the line height in
* all browsers.
*/
sub,
sup {
position: relative;
font-size: 75%;
line-height: 0;
vertical-align: baseline;
}
sub {
bottom: -0.25em;
}
sup {
top: -0.5em;
}
/* Embedded content
========================================================================== */
/**
* Remove the border on images inside links in IE 10.
*/
img {
border-style: none;
}
/* Forms
========================================================================== */
/**
* 1. Change the font styles in all browsers.
* 2. Remove the margin in Firefox and Safari.
*/
button,
input,
optgroup,
select,
textarea {
margin: 0;
/* 2 */
font-family: inherit;
/* 1 */
font-size: 100%;
/* 1 */
line-height: 1.15;
/* 1 */
}
/**
* Show the overflow in IE.
* 1. Show the overflow in Edge.
*/
button,
input {
/* 1 */
overflow: visible;
}
/**
* Remove the inheritance of text transform in Edge, Firefox, and IE.
* 1. Remove the inheritance of text transform in Firefox.
*/
button,
select {
/* 1 */
text-transform: none;
}
/**
* Correct the inability to style clickable types in iOS and Safari.
*/
button,
[type='button'],
[type='reset'],
[type='submit'] {
-webkit-appearance: button;
}
/**
* Remove the inner border and padding in Firefox.
*/
button::-moz-focus-inner,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
padding: 0;
border-style: none;
}
/**
* Restore the focus styles unset by the previous rule.
*/
button:-moz-focusring,
[type='button']:-moz-focusring,
[type='reset']:-moz-focusring,
[type='submit']:-moz-focusring {
outline: 1px dotted ButtonText;
}
/**
* Correct the padding in Firefox.
*/
fieldset {
padding: 0.35em 0.75em 0.625em;
}
/**
* 1. Correct the text wrapping in Edge and IE.
* 2. Correct the color inheritance from `fieldset` elements in IE.
* 3. Remove the padding so developers are not caught out when they zero out
* `fieldset` elements in all browsers.
*/
legend {
box-sizing: border-box;
/* 1 */
display: table;
/* 1 */
max-width: 100%;
/* 1 */
padding: 0;
/* 3 */
color: inherit;
/* 2 */
white-space: normal;
/* 1 */
}
/**
* Add the correct vertical alignment in Chrome, Firefox, and Opera.
*/
progress {
vertical-align: baseline;
}
/**
* Remove the default vertical scrollbar in IE 10+.
*/
textarea {
overflow: auto;
}
/**
* 1. Add the correct box sizing in IE 10.
* 2. Remove the padding in IE 10.
*/
[type='checkbox'],
[type='radio'] {
box-sizing: border-box;
/* 1 */
padding: 0;
/* 2 */
}
/**
* Correct the cursor style of increment and decrement buttons in Chrome.
*/
[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button {
height: auto;
}
/**
* 1. Correct the odd appearance in Chrome and Safari.
* 2. Correct the outline style in Safari.
*/
[type='search'] {
-webkit-appearance: textfield;
/* 1 */
outline-offset: -2px;
/* 2 */
}
/**
* Remove the inner padding in Chrome and Safari on macOS.
*/
[type='search']::-webkit-search-decoration {
-webkit-appearance: none;
}
/**
* 1. Correct the inability to style clickable types in iOS and Safari.
* 2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
/* 1 */
font: inherit;
-webkit-appearance: button;
/* 2 */
}
/* Interactive
========================================================================== */
/*
* Add the correct display in Edge, IE 10+, and Firefox.
*/
details {
display: block;
}
/*
* Add the correct display in all browsers.
*/
summary {
display: list-item;
}
/* Misc
========================================================================== */
/**
* Add the correct display in IE 10+.
*/
template {
display: none;
}
/**
* Add the correct display in IE 10.
*/
[hidden] {
display: none;
}

View File

@@ -0,0 +1,39 @@
/**
* @description vue过渡动画
*/
.fade-transform {
&-leave-active,
&-enter-active {
transition: $base-transition;
}
&-enter,
&-leave-to {
opacity: 0;
}
}
.no-transform {
&-leave-active,
&-enter-active {
transition: none;
}
&-enter,
&-leave-to {
opacity: 0;
}
}
/**
* @description 旋转动画
*/
@keyframes rotate {
0% {
transform: rotate(0);
}
100% {
transform: rotate(360deg);
}
}

633
library/styles/vab.scss Normal file
View File

@@ -0,0 +1,633 @@
/**
* @description 全局样式
*/
@import 'element-plus/theme-chalk/display.css';
@import './normalize';
@import './transition';
@mixin base-scrollbar {
&::-webkit-scrollbar {
width: 8px;
height: 8px;
}
&::-webkit-scrollbar-thumb {
background-color: mix($base-color-white, $base-menu-background, 90%);
border: 3px solid transparent;
border-radius: 7px;
}
&::-webkit-scrollbar-thumb:hover {
background-color: mix($base-color-white, $base-menu-background, 80%);
}
}
.vab-layout-header,
[class*='-bar-container'] {
transition: $base-transition;
* {
transition: $base-transition;
}
}
html {
body,
body[class*='vab-theme-'] {
position: relative;
box-sizing: border-box;
height: 100vh;
padding: 0;
overflow: hidden;
font-family: 'PingFang SC', Arial, 'Microsoft YaHei', sans-serif;
font-size: $base-font-size-default;
color: var(--el-color-black);
background: $base-color-background;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
#app {
height: 100vh;
overflow: auto;
@include base-scrollbar;
.vab-main {
transition: $base-transition;
.vab-app-main {
width: 100%;
padding: $base-padding;
overflow: hidden;
transition: $base-transition;
>section {
background: var(--el-color-white);
transition: $base-transition;
>[class*='-container'] {
min-height: $base-keep-alive-height;
padding: $base-padding;
background: var(--el-color-white);
transition: $base-transition;
}
}
}
}
}
* {
box-sizing: border-box;
outline: none !important;
@include base-scrollbar;
}
[class*='ri-'] {
vertical-align: -3px !important;
}
.vab-icon {
margin: 0 3px 0 0 !important;
}
/*a标签 */
a {
color: var(--el-color-primary);
text-decoration: none;
}
/*图片 */
img {
object-fit: cover;
&[src=''],
&:not([src]) {
opacity: 0;
}
}
/* vab-fullscreen全屏 */
.vab-fullscreen {
position: fixed !important;
top: 0 !important;
left: 0 !important;
z-index: $base-z-index + 3 !important;
box-sizing: border-box !important;
width: 100vw !important;
height: 100vh !important;
padding-bottom: 15px !important;
overflow: auto !important;
}
/* vab-dropdown下拉动画 */
.vab-dropdown {
transition: $base-transition;
&-active {
transform: rotateZ(180deg);
}
}
/* vab-dot圆点动画 */
.vab-dot {
position: relative;
display: inline-block;
width: 6px;
height: 6px;
margin-right: 3px;
vertical-align: middle;
border-radius: 50%;
span {
position: absolute;
top: 0;
left: 0;
box-sizing: border-box;
display: block;
width: 100%;
height: 100%;
border-radius: 50%;
animation: vabDot 1.2s ease-in-out infinite;
@keyframes vabDot {
0% {
opacity: 0.6;
transform: scale(0.8);
}
to {
opacity: 0;
transform: scale(2.4);
}
}
}
&-success {
background: var(--el-color-success);
span {
background: var(--el-color-success);
}
}
&-error {
background: var(--el-color-error);
span {
background: var(--el-color-error);
}
}
}
/* vab-data-empty占位图 */
.vab-data-empty {
display: flex;
align-items: center;
justify-content: center;
min-height: 600px;
margin: auto;
}
/* el-descriptions */
.el-descriptions {
&__title {
padding-left: 10px;
border-left: 5px solid var(--el-color-primary);
}
}
/* el-button按钮 */
.el-button {
border-radius: var(--el-border-radius-base);
&:hover,
&:focus,
&:active,
&.is-disabled {
background-clip: padding-box;
}
&.is-round {
border-radius: var(--el-border-radius-round);
}
&.is-circle {
border-radius: var(--el-border-radius-circle);
}
[class*='el-icon-']+span,
span+[class*='el-icon-'],
[class*='ri-']+span,
span+[class*='ri-'] {
margin-left: 3px;
}
}
/* el-tag */
.el-tag {
border-radius: var(--el-border-radius-base);
&+.el-tag {
margin-left: 10px;
}
&--light:not(&--success, &--info, &--warning, &--danger) {
--el-tag-bg-color: var(--el-color-primary-light-9);
--el-tag-border-color: var(--el-color-primary-light-8);
--el-tag-text-color: var(--el-color-primary);
--el-tag-hover-color: var(--el-color-primary);
}
&--dark:not(&--success, &--info, &--warning, &--danger) {
--el-tag-bg-color: var(--el-color-primary);
--el-tag-border-color: var(--el-color-primary);
--el-tag-hover-color: var(--el-color-primary-2);
}
&.is-round {
border-radius: var(--el-border-radius-round);
}
}
/* .el-select-tags */
.el-select-tags-wrapper {
.el-tag.el-tag {
margin-left: 0px;
}
}
/* el-select */
.el-select {
min-width: 115px;
}
a+a,
/* span + span, */
a+.el-button,
.el-button+a {
margin-left: 10px;
}
.el-drawer__wrapper {
outline: none !important;
* {
outline: none !important;
}
}
/* el-overlay遮罩 */
.el-overlay {
background-color: rgba(0, 0, 0, 0.1);
backdrop-filter: blur(3px);
}
/* el-image-viewer遮罩 */
.el-image-viewer__mask {
background-color: rgba(0, 0, 0, 0.1);
backdrop-filter: blur(3px);
}
/* v-modal遮罩 */
.v-modal {
z-index: $base-z-index;
background-color: rgba(0, 0, 0, 0.5);
opacity: 0.6;
//backdrop-filter: blur(10px);
}
/* el-loading-mask遮罩 */
.el-loading-mask {
z-index: $base-z-index - 10 !important;
&.is-fullscreen {
z-index: $base-z-index + 99 !important;
}
}
/* el-scrollbar滚动条 */
.el-scrollbar {
height: 100%;
&__bar {
z-index: 999;
}
&__thumb {
background-color: mix($base-color-white,
$base-menu-background,
90%);
&:hover {
background-color: mix($base-color-white,
$base-menu-background,
80%);
}
}
}
/* el-form表单 */
.el-form--label-top {
.el-form-item__label {
padding: 0;
}
}
.el-form-item__label {
padding: 0 10px 0 0;
}
.el-range-editor--small {
.el-range__icon,
.el-range__close-icon {
line-height: 23.5px;
}
}
/* el-badge */
.el-badge__content {
border: 0;
}
/* .el-page-header */
.el-page-header {
margin: 0 0 $base-margin 0;
}
/* el-alert */
.el-alert {
margin: 0 0 $base-margin 0;
&__closebtn {
position: absolute !important;
}
&--success.is-light {
color: var(--el-color-success);
background-color: var(--el-color-success-lighter);
border: 1px solid var(--el-color-success);
i {
color: var(--el-color-success);
}
}
&--info.is-light {
color: var(--el-color-primary);
background-color: var(--el-color-primary-light-9);
border: 1px solid var(--el-color-primary);
i {
color: var(--el-color-primary);
}
}
&--warning.is-light {
color: var(--el-color-warning);
background-color: var(--el-color-warning-lighter);
border: 1px solid var(--el-color-warning);
i {
color: var(--el-color-warning);
}
}
&--error.is-light {
color: var(--el-color-error);
background-color: var(--el-color-error-lighter);
border: 1px solid var(--el-color-error);
i {
color: var(--el-color-error);
}
}
}
/* el-divider间隔线 */
.el-divider--horizontal {
margin: 8px 0 $base-margin + 8px 0;
.el-divider__text {
display: -webkit-box;
overflow: hidden;
text-overflow: ellipsis;
-webkit-line-clamp: 1;
-webkit-box-orient: vertical;
}
}
/* nprogress进度条 */
#nprogress {
position: fixed;
z-index: $base-z-index + 3;
.bar {
background: var(--el-color-primary);
}
.peg {
box-shadow:
0 0 10px var(--el-color-primary),
0 0 5px var(--el-color-primary);
}
}
/* el-table表格 */
.el-table {
.el-table__body-wrapper {
@include base-scrollbar;
}
th {
background: #f5f7fa !important;
}
td,
th {
position: relative;
box-sizing: border-box;
.cell {
font-size: $base-font-size-default;
font-weight: normal;
color: #606266;
.el-image {
width: 50px;
height: 50px;
border-radius: $base-border-radius;
}
}
}
}
/* el-pagination分页 */
.el-pagination {
justify-content: center;
margin: $base-margin 0 0 0;
font-weight: normal;
color: var(--el-color-black);
}
/* el-menu菜单开始 */
.el-menu,
.vab-column-grid {
user-select: none;
/* plus处理图标间距 */
div,
li,
span {
i+span {
margin-left: 3px;
}
}
&.vab-column-grid-card,
&.vab-column-grid-vertical {
div {
i+span {
margin-left: 0;
}
}
}
}
.el-dialog__body {
padding-right: 30px;
}
/* el-dialog、el-message-box、el-popover、el-button、el-tag */
@media (max-width: 576px) {
.el-dialog,
.el-message-box,
.el-popover.el-popper {
width: 95% !important;
}
.el-button {
margin-bottom: 10px;
}
}
/* el-card卡片 */
.el-card {
margin-bottom: $base-margin;
border-radius: var(--el-border-radius-base);
&__header {
position: relative;
.card-header-tag {
position: absolute;
top: 15px;
right: 20px;
}
}
&__body {
padding: $base-padding;
}
}
/* .vab-hey-message */
.vab-hey-message {
@mixin vab-hey-message {
padding: 15px;
background-color: var(--el-color-white);
border-color: var(--el-color-white);
box-shadow: 0 5px 10px rgba(0, 0, 0, 0.15);
.el-message__content {
padding-right: $base-padding;
color: #34495e;
}
.el-icon-close {
color: #34495e;
&:hover {
opacity: 0.8;
}
}
}
&-info {
@include vab-hey-message;
i {
color: $base-color-grey;
}
}
&-success {
@include vab-hey-message;
i {
color: var(--el-color-success);
}
}
&-warning {
@include vab-hey-message;
i {
color: var(--el-color-warning);
}
}
&-error {
@include vab-hey-message;
i {
color: var(--el-color-error);
}
}
}
/* vab-table-expand */
.vab-table-expand {
padding: $base-padding;
line-height: 30px;
&-title {
display: inline-block;
width: 80px;
font-weight: bold;
}
}
:not(.no-background-container).auto-height-container {
display: flex;
flex-direction: column;
height: var(--el-container-height);
.el-table {
flex: 1;
}
.el-scrollbar {
//margin-right: -20px;
.vab-auto-box {
flex: 1;
width: 100%;
padding: 0 var(--el-padding) 0 0;
}
}
@media (max-width: 1024px) {
height: auto;
}
}
.el-card__body {
overflow: hidden;
flex: none;
}
}
}

View File

@@ -0,0 +1,43 @@
$base-color-primary: #1890ff;
$base-color-success: #13ce66;
$base-color-warning: #ffba00;
$base-color-danger: #ff4d4f;
$base-color-error: #ff4d4f;
$base-color-transition: #77e19d;
:export {
vab-color-grey: $base-color-grey;
vab-color-black: $base-color-black;
vab-color-primary: $base-color-primary;
vab-color-primary-light-1: mix($base-color-white, $base-color-primary, 10%);
vab-color-primary-light-2: mix($base-color-white, $base-color-primary, 20%);
vab-color-primary-light-3: mix($base-color-white, $base-color-primary, 30%);
vab-color-primary-light-4: mix($base-color-white, $base-color-primary, 40%);
vab-color-primary-light-5: mix($base-color-white, $base-color-primary, 50%);
vab-color-primary-light-6: mix($base-color-white, $base-color-primary, 60%);
vab-color-primary-light-7: mix($base-color-white, $base-color-primary, 70%);
vab-color-primary-light-8: mix($base-color-white, $base-color-primary, 80%);
vab-color-primary-light-9: mix($base-color-white, $base-color-primary, 90%);
vab-color-success: $base-color-success;
vab-color-success-light: mix($base-color-white, $base-color-success, 80%);
vab-color-success-lighter: mix($base-color-white, $base-color-success, 90%);
vab-color-warning: $base-color-warning;
vab-color-warning-light: mix($base-color-white, $base-color-warning, 80%);
vab-color-warning-lighter: mix($base-color-white, $base-color-warning, 90%);
vab-color-danger: $base-color-danger;
vab-color-danger-light: mix($base-color-white, $base-color-danger, 80%);
vab-color-danger-lighter: mix($base-color-white, $base-color-danger, 90%);
vab-color-error: $base-color-error;
vab-color-error-light: mix($base-color-white, $base-color-error, 80%);
vab-color-error-lighter: mix($base-color-white, $base-color-error, 90%);
vab-color-info: $base-color-text-secondary;
vab-color-info-light: mix($base-color-white,
$base-color-text-secondary,
80%);
vab-color-info-lighter: mix($base-color-white,
$base-color-text-secondary,
90%);
vab-border-radius-base: 5px;
vab-color-transition: $base-color-transition;
vab-left-menu-width: $base-left-menu-width;
}

View File

@@ -0,0 +1,43 @@
$base-color-primary: #41b584;
$base-color-success: #13ce66;
$base-color-warning: #ffba00;
$base-color-danger: #ff4d4f;
$base-color-error: #ff4d4f;
$base-color-transition: #1890ff;
:export {
vab-color-grey: $base-color-grey;
vab-color-black: $base-color-black;
vab-color-primary: $base-color-primary;
vab-color-primary-light-1: mix($base-color-white, $base-color-primary, 10%);
vab-color-primary-light-2: mix($base-color-white, $base-color-primary, 20%);
vab-color-primary-light-3: mix($base-color-white, $base-color-primary, 30%);
vab-color-primary-light-4: mix($base-color-white, $base-color-primary, 40%);
vab-color-primary-light-5: mix($base-color-white, $base-color-primary, 50%);
vab-color-primary-light-6: mix($base-color-white, $base-color-primary, 60%);
vab-color-primary-light-7: mix($base-color-white, $base-color-primary, 70%);
vab-color-primary-light-8: mix($base-color-white, $base-color-primary, 80%);
vab-color-primary-light-9: mix($base-color-white, $base-color-primary, 90%);
vab-color-success: $base-color-success;
vab-color-success-light: mix($base-color-white, $base-color-success, 80%);
vab-color-success-lighter: mix($base-color-white, $base-color-success, 90%);
vab-color-warning: $base-color-warning;
vab-color-warning-light: mix($base-color-white, $base-color-warning, 80%);
vab-color-warning-lighter: mix($base-color-white, $base-color-warning, 90%);
vab-color-danger: $base-color-danger;
vab-color-danger-light: mix($base-color-white, $base-color-danger, 80%);
vab-color-danger-lighter: mix($base-color-white, $base-color-danger, 90%);
vab-color-error: $base-color-error;
vab-color-error-light: mix($base-color-white, $base-color-error, 80%);
vab-color-error-lighter: mix($base-color-white, $base-color-error, 90%);
vab-color-info: $base-color-text-secondary;
vab-color-info-light: mix($base-color-white,
$base-color-text-secondary,
80%);
vab-color-info-lighter: mix($base-color-white,
$base-color-text-secondary,
90%);
vab-border-radius-base: 5px;
vab-color-transition: $base-color-transition;
vab-left-menu-width: $base-left-menu-width;
}

View File

@@ -0,0 +1,43 @@
$base-color-primary: #6954f0;
$base-color-success: #13ce66;
$base-color-warning: #ffba00;
$base-color-danger: #ff4d4f;
$base-color-error: #ff4d4f;
$base-color-transition: #1890ff;
:export {
vab-color-grey: $base-color-grey;
vab-color-black: $base-color-black;
vab-color-primary: $base-color-primary;
vab-color-primary-light-1: mix($base-color-white, $base-color-primary, 10%);
vab-color-primary-light-2: mix($base-color-white, $base-color-primary, 20%);
vab-color-primary-light-3: mix($base-color-white, $base-color-primary, 30%);
vab-color-primary-light-4: mix($base-color-white, $base-color-primary, 40%);
vab-color-primary-light-5: mix($base-color-white, $base-color-primary, 50%);
vab-color-primary-light-6: mix($base-color-white, $base-color-primary, 60%);
vab-color-primary-light-7: mix($base-color-white, $base-color-primary, 70%);
vab-color-primary-light-8: mix($base-color-white, $base-color-primary, 80%);
vab-color-primary-light-9: mix($base-color-white, $base-color-primary, 90%);
vab-color-success: $base-color-success;
vab-color-success-light: mix($base-color-white, $base-color-success, 80%);
vab-color-success-lighter: mix($base-color-white, $base-color-success, 90%);
vab-color-warning: $base-color-warning;
vab-color-warning-light: mix($base-color-white, $base-color-warning, 80%);
vab-color-warning-lighter: mix($base-color-white, $base-color-warning, 90%);
vab-color-danger: $base-color-danger;
vab-color-danger-light: mix($base-color-white, $base-color-danger, 80%);
vab-color-danger-lighter: mix($base-color-white, $base-color-danger, 90%);
vab-color-error: $base-color-error;
vab-color-error-light: mix($base-color-white, $base-color-error, 80%);
vab-color-error-lighter: mix($base-color-white, $base-color-error, 90%);
vab-color-info: $base-color-text-secondary;
vab-color-info-light: mix($base-color-white,
$base-color-text-secondary,
80%);
vab-color-info-lighter: mix($base-color-white,
$base-color-text-secondary,
90%);
vab-border-radius-base: 5px;
vab-color-transition: $base-color-transition;
vab-left-menu-width: $base-left-menu-width;
}

View File

@@ -0,0 +1,43 @@
$base-color-primary: #f34d37;
$base-color-success: #13ce66;
$base-color-warning: #ffba00;
$base-color-danger: #ff4d4f;
$base-color-error: #ff4d4f;
$base-color-transition: #ffa194;
:export {
vab-color-grey: $base-color-grey;
vab-color-black: $base-color-black;
vab-color-primary: $base-color-primary;
vab-color-primary-light-1: mix($base-color-white, $base-color-primary, 10%);
vab-color-primary-light-2: mix($base-color-white, $base-color-primary, 20%);
vab-color-primary-light-3: mix($base-color-white, $base-color-primary, 30%);
vab-color-primary-light-4: mix($base-color-white, $base-color-primary, 40%);
vab-color-primary-light-5: mix($base-color-white, $base-color-primary, 50%);
vab-color-primary-light-6: mix($base-color-white, $base-color-primary, 60%);
vab-color-primary-light-7: mix($base-color-white, $base-color-primary, 70%);
vab-color-primary-light-8: mix($base-color-white, $base-color-primary, 80%);
vab-color-primary-light-9: mix($base-color-white, $base-color-primary, 90%);
vab-color-success: $base-color-success;
vab-color-success-light: mix($base-color-white, $base-color-success, 80%);
vab-color-success-lighter: mix($base-color-white, $base-color-success, 90%);
vab-color-warning: $base-color-warning;
vab-color-warning-light: mix($base-color-white, $base-color-warning, 80%);
vab-color-warning-lighter: mix($base-color-white, $base-color-warning, 90%);
vab-color-danger: $base-color-danger;
vab-color-danger-light: mix($base-color-white, $base-color-danger, 80%);
vab-color-danger-lighter: mix($base-color-white, $base-color-danger, 90%);
vab-color-error: $base-color-error;
vab-color-error-light: mix($base-color-white, $base-color-error, 80%);
vab-color-error-lighter: mix($base-color-white, $base-color-error, 90%);
vab-color-info: $base-color-text-secondary;
vab-color-info-light: mix($base-color-white,
$base-color-text-secondary,
80%);
vab-color-info-lighter: mix($base-color-white,
$base-color-text-secondary,
90%);
vab-border-radius-base: 5px;
vab-color-transition: $base-color-transition;
vab-left-menu-width: $base-left-menu-width;
}

View File

@@ -0,0 +1,109 @@
/**
* @description 全局主题变量配置
*/
//颜色配置
$base-color-white: #ffffff;
$base-color-black: #515a6e;
$base-color-primary: #1890ff;
$base-color-success: #13ce66;
$base-color-warning: #ffba00;
$base-color-danger: #ff6700;
$base-color-error: #ff4d4f;
$base-color-grey: rgba(0, 0, 0, 0.65);
$base-color-background: #f6f8f9;
$base-color-text-primary: #303133;
$base-color-text-regular: #606266;
$base-color-text-secondary: #909399;
$base-color-text-placeholder: #c0c4cc;
$base-border-color-base: #dcdfe6;
$base-border-color-light: #e4e7ed;
$base-border-color-lighter: #ebeef5;
$base-border-color-extra-light: #f2f6fc;
$base-background-color-base: #f5f7fa;
//默认层级
$base-z-index: 1999;
//分栏最左侧菜单背景色
$base-column-first-menu-background: #282c34;
//分栏菜单背景色
$base-column-second-menu-background: #fff;
//分栏菜单选中背景色
$base-column-second-menu-active: mix($base-color-white,
$base-color-primary,
10%);
//横向、纵向菜单背景色
$base-menu-background: #282c34;
//菜单文字颜色
$base-menu-color: hsla(0, 0%, 100%, 0.95);
//菜单选中文字颜色
$base-menu-color-active: hsla(0, 0%, 100%, 0.95);
//菜单选中背景色
$base-menu-active: $base-color-primary;
//标题颜色
$base-title-color: #fff;
//字体大小配置
$base-font-size-small: 12px;
$base-font-size-default: 14px;
$base-font-size-big: 16px;
$base-font-size-bigger: 18px;
$base-font-size-max: 22px;
//最大宽度
$base-main-width: 1279px;
//圆角
$base-border-radius: 5px;
//边框颜色
$base-border-color: #dcdfe6;
//输入框高度
$base-input-height: 32px;
//默认margin
$base-margin: 20px;
//默认padding
$base-padding: 20px;
//默认阴影
$base-box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
//横向top-bar、logo、一级菜单的高度
$base-header-height: 60px;
//纵向、综合、分栏logo的高度
$base-logo-height: 60px;
//顶部nav-bar的高度
$base-nav-height: 60px;
//顶部标签页tabs-bar的高度
$base-tabs-height: 50px;
//顶部标签页tabs-bar中每一个item的高度
$base-tag-item-height: 34px;
//菜单li标签的高度
$base-menu-item-height: 50px;
//app-main的高度
$base-keep-alive-height: calc(100vh - #{$base-nav-height} - #{$base-tabs-height} - #{$base-padding} * 2 - 55px);
//纵向左侧导航未折叠的宽度
$base-left-menu-width: 266px;
//纵向左侧导航已折叠的宽度
$base-left-menu-width-min: 64px;
//纵向左侧导航已折叠右侧内容的宽度
$base-right-content-width-min: calc(100% - #{$base-left-menu-width-min});
//默认动画
$base-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1),
border 0s,
color 0.1s,
font-size 0s;
:export {
// 菜单文字颜色变量导出
menu-color: $base-menu-color;
// 菜单选中文字颜色变量导出
menu-color-active: $base-menu-color-active;
// 菜单背景色变量导出
menu-background: $base-menu-background;
// 分栏菜单背景色变量导出
column-second-menu-background: $base-column-second-menu-background;
// 导出圆角
vab-border-radius: $base-border-radius;
}
:root {
--el-container-height: #{$base-keep-alive-height};
--el-margin: #{$base-margin};
--el-padding: #{$base-padding};
--el-border-radius-base: #{$base-border-radius} !important;
}