This commit is contained in:
251
library/styles/background/black.scss
Normal file
251
library/styles/background/black.scss
Normal 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;
|
||||
}
|
||||
}
|
||||
}
|
||||
108
library/styles/background/image.scss
Normal file
108
library/styles/background/image.scss
Normal 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;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
181
library/styles/background/ocean.scss
Normal file
181
library/styles/background/ocean.scss
Normal 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;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
293
library/styles/background/white.scss
Normal file
293
library/styles/background/white.scss
Normal 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;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
124
library/styles/loading/dots.css
Normal file
124
library/styles/loading/dots.css
Normal 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;
|
||||
}
|
||||
}
|
||||
104
library/styles/loading/gauge.css
Normal file
104
library/styles/loading/gauge.css
Normal 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);
|
||||
}
|
||||
}
|
||||
51
library/styles/loading/inner-circles.css
Normal file
51
library/styles/loading/inner-circles.css
Normal 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);
|
||||
}
|
||||
}
|
||||
341
library/styles/loading/plus.css
Normal file
341
library/styles/loading/plus.css
Normal 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
377
library/styles/normalize.scss
vendored
Normal 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;
|
||||
}
|
||||
39
library/styles/transition.scss
Normal file
39
library/styles/transition.scss
Normal 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
633
library/styles/vab.scss
Normal 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;
|
||||
}
|
||||
}
|
||||
}
|
||||
43
library/styles/variables/vab-blue-variables.module.scss
Normal file
43
library/styles/variables/vab-blue-variables.module.scss
Normal 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;
|
||||
}
|
||||
43
library/styles/variables/vab-green-variables.module.scss
Normal file
43
library/styles/variables/vab-green-variables.module.scss
Normal 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;
|
||||
}
|
||||
43
library/styles/variables/vab-purple-variables.module.scss
Normal file
43
library/styles/variables/vab-purple-variables.module.scss
Normal 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;
|
||||
}
|
||||
43
library/styles/variables/vab-red-variables.module.scss
Normal file
43
library/styles/variables/vab-red-variables.module.scss
Normal 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;
|
||||
}
|
||||
109
library/styles/variables/variables.module.scss
Normal file
109
library/styles/variables/variables.module.scss
Normal 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;
|
||||
}
|
||||
Reference in New Issue
Block a user