123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 |
- <template>
- <el-scrollbar class="side-bar-container" :class="{ 'is-collapse': collapse }">
- <logo />
- <el-menu
- :background-color="variables['menu-background']"
- :text-color="variables['menu-color']"
- :active-text-color="variables['menu-color-active']"
- :default-active="activeMenu"
- :collapse="collapse"
- :collapse-transition="false"
- :default-openeds="defaultOpens"
- :unique-opened="uniqueOpened"
- mode="vertical"
- >
- <template v-for="route in routes">
- <side-bar-item
- :key="route.path"
- :full-path="route.path"
- :item="route"
- ></side-bar-item>
- </template>
- </el-menu>
- </el-scrollbar>
- </template>
- <script>
- import { Logo } from "@/layouts/components";
- import SideBarItem from "./components/SideBarItem";
- import variables from "@/styles/variables.scss";
- import { mapGetters } from "vuex";
- import { defaultOopeneds, uniqueOpened } from "@/config/settings";
- export default {
- name: "SideBar",
- components: { SideBarItem, Logo },
- data() {
- return {
- uniqueOpened,
- };
- },
- computed: {
- ...mapGetters({
- collapse: "settings/collapse",
- routes: "routes/routes",
- }),
- defaultOpens() {
- if (this.collapse) {
- }
- return defaultOopeneds;
- },
- activeMenu() {
- const route = this.$route;
- const { meta, path } = route;
- if (meta.activeMenu) {
- return meta.activeMenu;
- }
- return path;
- },
- variables() {
- return variables;
- },
- },
- };
- </script>
- <style lang="scss" scoped>
- @mixin active {
- &:hover {
- color: $base-color-white;
- background-color: $base-menu-background-active !important;
- }
- &.is-active {
- color: $base-color-white;
- background-color: $base-menu-background-active !important;
- }
- }
- .side-bar-container {
- position: fixed;
- top: 0;
- bottom: 0;
- left: 0;
- z-index: $base-z-index;
- width: $base-left-menu-width;
- height: 100vh;
- overflow: hidden;
- background: $base-menu-background;
- box-shadow: 2px 0 6px rgba(0, 21, 41, 0.35);
- transition: width $base-transition-time;
- &.is-collapse {
- width: $base-left-menu-width-min;
- border-right: 0;
- ::v-deep {
- .el-menu {
- transition: width $base-transition-time;
- }
- .el-menu--collapse {
- border-right: 0;
- .el-submenu__icon-arrow {
- right: 10px;
- margin-top: -3px;
- }
- }
- }
- }
- ::v-deep {
- .el-scrollbar__wrap {
- overflow-x: hidden;
- }
- .el-menu {
- border: 0;
- .vab-fas-icon {
- padding-right: 3px;
- font-size: $base-font-size-default;
- }
- .vab-remix-icon {
- padding-right: 3px;
- font-size: $base-font-size-default + 2;
- }
- }
- .el-menu-item,
- .el-submenu__title {
- height: $base-menu-item-height;
- overflow: hidden;
- line-height: $base-menu-item-height;
- text-overflow: ellipsis;
- white-space: nowrap;
- vertical-align: middle;
- }
- .el-menu-item {
- @include active;
- }
- }
- }
- </style>
|