index.vue 2.6 KB
Newer Older
Mr.奇淼('s avatar
Mr.奇淼( 已提交
1
<template>
2
  <div>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
3 4 5 6
    <el-scrollbar style="height:calc(100vh - 64px)">
      <transition :duration="{ enter: 800, leave: 100 }" mode="out-in" name="el-fade-in-linear">
        <el-menu
          :collapse="isCollapse"
7
          :collapse-transition="false"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
8
          :default-active="active"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
9
          :background-color="sideMode"
10
          :active-text-color="activeColor"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
11
          :text-color="baseColor"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
12 13
          class="el-menu-vertical"
          unique-opened
何秀钢 已提交
14
          @select="selectMenuItem"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
15 16
        >
          <template v-for="item in asyncRouters[0].children">
何秀钢 已提交
17
            <aside-component v-if="!item.hidden" :key="item.name" :router-info="item" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
18 19 20
          </template>
        </el-menu>
      </transition>
21
    </el-scrollbar>
22
  </div>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
23 24 25
</template>

<script>
何秀钢 已提交
26
import { mapGetters, mapMutations } from 'vuex'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
27
import AsideComponent from '@/view/layout/aside/asideComponent/index.vue'
28 29
import { emitter } from '@/utils/bus.js'

Mr.奇淼('s avatar
Mr.奇淼( 已提交
30
export default {
何秀钢 已提交
31 32 33 34
  name: 'Aside',
  components: {
    AsideComponent
  },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
35 36
  data() {
    return {
何秀钢 已提交
37
      active: '',
38
      isCollapse: false
Mr.奇淼('s avatar
Mr.奇淼( 已提交
39 40
    }
  },
41
  computed: {
42
    ...mapGetters('router', ['asyncRouters']),
Mr.奇淼('s avatar
Mr.奇淼( 已提交
43
    ...mapGetters('user', ['baseColor', 'activeColor', 'sideMode'])
Mr.奇淼('s avatar
Mr.奇淼( 已提交
44
  },
何秀钢 已提交
45 46 47 48
  watch: {
    $route() {
      this.active = this.$route.name
    }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
49 50
  },
  created() {
何秀钢 已提交
51 52
    this.active = this.$route.name
    const screenWidth = document.body.clientWidth
Mr.奇淼('s avatar
Mr.奇淼( 已提交
53
    if (screenWidth < 1000) {
何秀钢 已提交
54
      this.isCollapse = !this.isCollapse
Mr.奇淼('s avatar
Mr.奇淼( 已提交
55
    }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
56

57
    emitter.on('collapse', item => {
何秀钢 已提交
58 59
      this.isCollapse = item
    })
Mr.奇淼('s avatar
Mr.奇淼( 已提交
60
  },
61
  beforeDestroy() {
62
    emitter.off('collapse')
何秀钢 已提交
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
  },
  methods: {
    ...mapMutations('history', ['addHistory']),
    selectMenuItem(index, _, ele) {
      const query = {}
      const params = {}
      ele.route.parameters &&
      ele.route.parameters.map(item => {
        if (item.type === 'query') {
          query[item.key] = item.value
        } else {
          params[item.key] = item.value
        }
      })
      if (index === this.$route.name) return
      if (index.indexOf('http://') > -1 || index.indexOf('https://') > -1) {
        window.open(index)
      } else {
        this.$router.push({ name: index, query, params })
      }
    }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
84
  }
何秀钢 已提交
85
}
Mr.奇淼('s avatar
Mr.奇淼( 已提交
86
</script>
87 88

<style lang="scss">
89
.el-sub-menu__title,.el-menu-item{
90 91 92 93
  i{
    color: inherit !important;
  }
}
Mr.奇淼('s avatar
Mr.奇淼( 已提交
94

95
.el-sub-menu__title:hover,.el-menu-item:hover{
Mr.奇淼('s avatar
Mr.奇淼( 已提交
96 97 98 99 100 101 102 103
  i{
    color: inherit !important;
  }
  span{
    color: inherit !important;
  }
}

104 105
.el-scrollbar {
  .el-scrollbar__view {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
106 107 108
    height: 100%;
  }
}
109 110 111 112 113 114 115 116
.menu-info {
  .menu-contorl {
    line-height: 52px;
    font-size: 20px;
    display: table-cell;
    vertical-align: middle;
  }
}
何秀钢 已提交
117
</style>