index.vue 2.4 KB
Newer Older
Mr.奇淼('s avatar
Mr.奇淼( 已提交
1
<template>
2
  <div>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
3 4 5 6 7 8
    <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"
          :collapse-transition="true"
          :default-active="active"
D
Devil 已提交
9 10
          :active-text-color="$store.getters['user/getSideMode'] === 'dark' ? '#1890ff' : '#1890ff'"
          :background-color="$store.getters['user/getSideMode'] === 'dark' ? '#191a23 ' : '#fff'"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
11
          class="el-menu-vertical"
D
Devil 已提交
12
          text-color="#999"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
13
          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 27
import { mapGetters, mapMutations } from 'vuex'
import AsideComponent from '@/view/layout/aside/asideComponent'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
28
export default {
何秀钢 已提交
29 30 31 32
  name: 'Aside',
  components: {
    AsideComponent
  },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
33 34
  data() {
    return {
何秀钢 已提交
35
      active: '',
36
      isCollapse: false
Mr.奇淼('s avatar
Mr.奇淼( 已提交
37 38
    }
  },
39
  computed: {
何秀钢 已提交
40
    ...mapGetters('router', ['asyncRouters'])
Mr.奇淼('s avatar
Mr.奇淼( 已提交
41
  },
何秀钢 已提交
42 43 44 45
  watch: {
    $route() {
      this.active = this.$route.name
    }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
46 47
  },
  created() {
何秀钢 已提交
48 49
    this.active = this.$route.name
    const screenWidth = document.body.clientWidth
Mr.奇淼('s avatar
Mr.奇淼( 已提交
50
    if (screenWidth < 1000) {
何秀钢 已提交
51
      this.isCollapse = !this.isCollapse
Mr.奇淼('s avatar
Mr.奇淼( 已提交
52
    }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
53

何秀钢 已提交
54 55 56
    this.$bus.on('collapse', item => {
      this.isCollapse = item
    })
Mr.奇淼('s avatar
Mr.奇淼( 已提交
57
  },
58
  beforeDestroy() {
何秀钢 已提交
59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
    this.$bus.off('collapse')
  },
  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.奇淼( 已提交
81
  }
何秀钢 已提交
82
}
Mr.奇淼('s avatar
Mr.奇淼( 已提交
83
</script>
84 85

<style lang="scss">
86 87
.el-scrollbar {
  .el-scrollbar__view {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
88 89 90
    height: 100%;
  }
}
91 92 93 94 95 96 97 98
.menu-info {
  .menu-contorl {
    line-height: 52px;
    font-size: 20px;
    display: table-cell;
    vertical-align: middle;
  }
}
何秀钢 已提交
99
</style>