This commit is contained in:
曹辉 2023-04-19 17:32:37 +08:00
parent 66c86d7388
commit 6bddc60477

View File

@ -1,227 +1,188 @@
#app { #app {
.main-container {
min-height: 100%;
transition: margin-left .28s;
margin-left: $base-sidebar-width;
position: relative;
}
.sidebarHide {
margin-left: 0!important;
}
.sidebar-container {
-webkit-transition: width .28s;
transition: width 0.28s;
width: $base-sidebar-width !important;
background-color: $base-menu-background;
height: 100%;
position: fixed;
font-size: 0px;
top: 0;
bottom: 0;
left: 0;
z-index: 1001;
overflow: hidden;
-webkit-box-shadow: 2px 0 6px rgba(0,21,41,.35);
box-shadow: 2px 0 6px rgba(0,21,41,.35);
// reset element-ui css
.horizontal-collapse-transition {
transition: 0s width ease-in-out, 0s padding-left ease-in-out, 0s padding-right ease-in-out;
}
.scrollbar-wrapper {
overflow-x: hidden !important;
}
.el-scrollbar__bar.is-vertical {
right: 0px;
}
.el-scrollbar {
height: 100%;
}
&.has-logo {
.el-scrollbar {
height: calc(100% - 50px);
}
}
.is-horizontal {
display: none;
}
a {
display: inline-block;
width: 100%;
overflow: hidden;
}
.svg-icon {
margin-right: 16px;
}
.el-menu {
border: none;
height: 100%;
width: 100% !important;
}
.el-menu-item, .el-submenu__title {
overflow: hidden !important;
text-overflow: ellipsis !important;
white-space: nowrap !important;
}
// menu hover
.submenu-title-noDropdown,
.el-submenu__title {
&:hover {
background-color: rgba(0, 0, 0, 0.06) !important;
}
}
& .theme-dark .is-active > .el-submenu__title {
color: $base-menu-color-active !important;
}
& .nest-menu .el-submenu>.el-submenu__title,
& .el-submenu .el-menu-item {
min-width: $base-sidebar-width !important;
&:hover {
background-color: rgba(0, 0, 0, 0.06) !important;
}
}
& .theme-dark .nest-menu .el-submenu>.el-submenu__title,
& .theme-dark .el-submenu .el-menu-item {
background-color: $base-sub-menu-background !important;
&:hover {
background-color: $base-sub-menu-hover !important;
}
}
}
.hideSidebar {
.sidebar-container {
width: 54px !important;
}
.main-container { .main-container {
margin-left: 54px; min-height: 100%;
transition: margin-left .28s;
margin-left: $base-sidebar-width;
position: relative;
} }
.sidebarHide {
.submenu-title-noDropdown { margin-left: 0!important;
padding: 0 !important; }
position: relative; .sidebar-container {
-webkit-transition: width .28s;
.el-tooltip { transition: width 0.28s;
padding: 0 !important; width: $base-sidebar-width !important;
background-color: $base-menu-background;
.svg-icon { height: 100%;
margin-left: 20px; position: fixed;
font-size: 0px;
top: 0;
bottom: 0;
left: 0;
z-index: 1001;
overflow: hidden;
-webkit-box-shadow: 2px 0 6px rgba(0, 21, 41, .35);
box-shadow: 2px 0 6px rgba(0, 21, 41, .35);
// reset element-ui css
.horizontal-collapse-transition {
transition: 0s width ease-in-out, 0s padding-left ease-in-out, 0s padding-right ease-in-out;
} }
} .scrollbar-wrapper {
} overflow-x: hidden !important;
.el-submenu {
overflow: hidden;
&>.el-submenu__title {
padding: 0 !important;
.svg-icon {
margin-left: 20px;
} }
.el-scrollbar__bar.is-vertical {
} right: 0px;
} }
.el-scrollbar {
.el-menu--collapse { height: 100%;
.el-submenu { }
&>.el-submenu__title { &.has-logo {
&>span { .el-scrollbar {
height: 0; height: calc(100% - 90px);
width: 0; }
overflow: hidden; }
visibility: hidden; .is-horizontal {
display: none;
}
a {
display: inline-block; display: inline-block;
} width: 100%;
overflow: hidden;
}
.svg-icon {
margin-right: 16px;
}
.el-menu {
border: none;
height: 100%;
width: 100% !important;
}
.el-menu-item,
.el-submenu__title {
overflow: hidden !important;
text-overflow: ellipsis !important;
white-space: nowrap !important;
}
// menu hover
.submenu-title-noDropdown,
.el-submenu__title {
&:hover {
background-color: rgba(0, 0, 0, 0.06) !important;
}
}
& .theme-dark .is-active>.el-submenu__title {
color: $base-menu-color-active !important;
}
& .nest-menu .el-submenu>.el-submenu__title,
& .el-submenu .el-menu-item {
min-width: $base-sidebar-width !important;
&:hover {
background-color: rgba(0, 0, 0, 0.06) !important;
}
}
& .theme-dark .nest-menu .el-submenu>.el-submenu__title,
& .theme-dark .el-submenu .el-menu-item {
background-color: $base-sub-menu-background !important;
&:hover {
background-color: $base-sub-menu-hover !important;
}
} }
}
} }
} .hideSidebar {
.sidebar-container {
.el-menu--collapse .el-menu .el-submenu { width: 54px !important;
min-width: $base-sidebar-width !important; }
} .main-container {
margin-left: 54px;
// mobile responsive }
.mobile { .submenu-title-noDropdown {
.main-container { padding: 0 !important;
margin-left: 0px; position: relative;
.el-tooltip {
padding: 0 !important;
.svg-icon {
margin-left: 20px;
}
}
}
.el-submenu {
overflow: hidden;
&>.el-submenu__title {
padding: 0 !important;
.svg-icon {
margin-left: 20px;
}
}
}
.el-menu--collapse {
.el-submenu {
&>.el-submenu__title {
&>span {
height: 0;
width: 0;
overflow: hidden;
visibility: hidden;
display: inline-block;
}
}
}
}
} }
.el-menu--collapse .el-menu .el-submenu {
.sidebar-container { min-width: $base-sidebar-width !important;
transition: transform .28s;
width: $base-sidebar-width !important;
} }
// mobile responsive
&.hideSidebar { .mobile {
.sidebar-container { .main-container {
pointer-events: none; margin-left: 0px;
transition-duration: 0.3s; }
transform: translate3d(-$base-sidebar-width, 0, 0); .sidebar-container {
} transition: transform .28s;
width: $base-sidebar-width !important;
}
&.hideSidebar {
.sidebar-container {
pointer-events: none;
transition-duration: 0.3s;
transform: translate3d(-$base-sidebar-width, 0, 0);
}
}
} }
} .withoutAnimation {
.main-container,
.withoutAnimation { .sidebar-container {
transition: none;
.main-container, }
.sidebar-container {
transition: none;
} }
}
} }
// when menu collapsed // when menu collapsed
.el-menu--vertical { .el-menu--vertical {
&>.el-menu { &>.el-menu {
.svg-icon { .svg-icon {
margin-right: 16px; margin-right: 16px;
}
} }
} .nest-menu .el-submenu>.el-submenu__title,
.el-menu-item {
.nest-menu .el-submenu>.el-submenu__title, &:hover {
.el-menu-item { // you can use $subMenuHover
&:hover { background-color: rgba(0, 0, 0, 0.06) !important;
// you can use $subMenuHover }
background-color: rgba(0, 0, 0, 0.06) !important;
} }
} // the scroll bar appears when the subMenu is too long
>.el-menu--popup {
// the scroll bar appears when the subMenu is too long max-height: 100vh;
>.el-menu--popup { overflow-y: auto;
max-height: 100vh; &::-webkit-scrollbar-track-piece {
overflow-y: auto; background: #d3dce6;
}
&::-webkit-scrollbar-track-piece { &::-webkit-scrollbar {
background: #d3dce6; width: 6px;
}
&::-webkit-scrollbar-thumb {
background: #99a9bf;
border-radius: 20px;
}
} }
}
&::-webkit-scrollbar {
width: 6px;
}
&::-webkit-scrollbar-thumb {
background: #99a9bf;
border-radius: 20px;
}
}
}