From d9c657aa78cf0ebe31933a87e63ca92edd8a8da3 Mon Sep 17 00:00:00 2001
From: doum <doum>
Date: 星期四, 11 六月 2026 09:57:50 +0800
Subject: [PATCH] 数据采集站
---
admin/src/components/common/Menu.vue | 184 +++++++++++++++++++++++++++++++++------------
1 files changed, 133 insertions(+), 51 deletions(-)
diff --git a/admin/src/components/common/Menu.vue b/admin/src/components/common/Menu.vue
index 15f7c56..c59f2f7 100644
--- a/admin/src/components/common/Menu.vue
+++ b/admin/src/components/common/Menu.vue
@@ -1,78 +1,122 @@
<template>
- <div class="menu" :class="{collapse: menuData.collapse}">
+ <div class="menu" :class="{ collapse: menuData.collapse }">
<scrollbar>
<el-menu
ref="menu"
- :default-active="activeIndex"
- text-color="#fff"
- active-text-color="#fff"
+ :key="menuRenderKey"
+ :default-active="activeMenuIndex"
+ text-color="#333333"
+ active-text-color="#207FF7"
:collapse="menuData.collapse"
- :default-openeds="defaultOpeneds"
+ :default-openeds="openMenuIndexes"
:collapse-transition="false"
unique-opened
@select="handleSelect"
>
- <MenuItems v-for="menu in menuData.list" :key="menu.index" :menu="menu" :is-root-menu="true"/>
+ <MenuItems
+ v-for="menu in menuData.list"
+ :key="menu.index"
+ :menu="menu"
+ :is-root-menu="true"
+ />
</el-menu>
</scrollbar>
</div>
</template>
<script>
-import { mapState } from 'vuex'
+import { mapState, mapMutations } from 'vuex'
import MenuItems from './MenuItems'
import Scrollbar from './Scrollbar'
+import { findMenuByRoute } from '@/utils/menuRoute'
+
export default {
name: 'Menu',
components: { Scrollbar, MenuItems },
- computed: {
- ...mapState(['menuData']),
- // 閫変腑鐨勮彍鍗昳ndex
- activeIndex () {
- let path = this.$route.path
- if (path.endsWith('/')) {
- path = path.substring(0, path.length - 1)
- }
- const menuConfig = this.__getMenuConfig(path, 'index', this.menuData.list)
- if (menuConfig == null) {
- return null
- } else {
- this.$store.commit('pushtags', menuConfig)
- }
- // console.log(menuConfig.index);
- return menuConfig.index
- },
- // 榛樿灞曞紑鐨勮彍鍗昳ndex
- defaultOpeneds () {
- // return this.menuData.list.map(menu => menu.index)
-
- return [this.menuData.list[0].index]
+ data () {
+ return {
+ activeMenuIndex: '',
+ openMenuIndexes: [],
+ menuRenderKey: 0
}
},
+ computed: {
+ ...mapState(['menuData', 'topMenuList'])
+ },
+ watch: {
+ '$route' () {
+ this.syncMenuFromRoute()
+ },
+ 'menuData.list' () {
+ this.syncMenuFromRoute()
+ }
+ },
+ mounted () {
+ this.syncMenuFromRoute()
+ },
methods: {
+ ...mapMutations(['pushtags', 'syncTopMenuFromRoute']),
+ syncMenuFromRoute () {
+ const path = this.normalizePath(this.$route.path)
+ const menuIndex = this.$route.query.index
+ const result = findMenuByRoute(this.topMenuList.list, path, menuIndex)
+ if (result == null) {
+ return
+ }
+ if (result.topMenu.id !== this.$store.state.topMenuCurrent.id) {
+ this.syncTopMenuFromRoute({
+ topMenu: result.topMenu,
+ topIndex: result.topIndex
+ })
+ }
+ this.activeMenuIndex = result.menu.index
+ this.openMenuIndexes = result.parents.map(item => item.index)
+ this.menuRenderKey += 1
+ this.pushtags(result.menu)
+ this.$nextTick(() => {
+ this.openParentMenus()
+ })
+ },
+ openParentMenus () {
+ const menuRef = this.$refs.menu
+ if (!menuRef || this.openMenuIndexes.length === 0) {
+ return
+ }
+ this.openMenuIndexes.forEach(index => {
+ if (typeof menuRef.open === 'function') {
+ menuRef.open(index)
+ }
+ })
+ },
+ normalizePath (path) {
+ if (path == null || path === '') {
+ return ''
+ }
+ return path.endsWith('/') ? path.substring(0, path.length - 1) : path
+ },
// 澶勭悊鑿滃崟閫変腑
handleSelect (menuIndex) {
const menuConfig = this.__getMenuConfig(menuIndex, 'index', this.menuData.list)
+ if (menuConfig == null) {
+ return
+ }
// 鎵句笉鍒伴〉闈�
try {
- require('@/views' + menuConfig.url)
+ require('@/views' + menuConfig.url)
} catch (e) {
this.$tip.error('鏈壘鍒伴〉闈㈡枃浠禓/views' + menuConfig.url + '.vue锛岃妫�鏌ヨ彍鍗曡矾寰勬槸鍚︽纭�')
return
}
// 鐐瑰嚮褰撳墠鑿滃崟涓嶅仛澶勭悊
- if (menuConfig.url === this.$route.path && (menuConfig.params ==null || menuConfig.params==undefined || menuConfig.params=='' || menuConfig.params === this.$route.query.param)) {
+ if (menuConfig.url === this.$route.path && (menuConfig.params == null || menuConfig.params === undefined || menuConfig.params === '' || menuConfig.params === this.$route.query.param)) {
return
}
if (menuConfig.url == null || menuConfig.url.trim().length === 0) {
return
}
- if(menuConfig.params!=null && menuConfig.params!=''){
- this.$router.push({path:menuConfig.url,query:{index:menuConfig.index,param:menuConfig.params}})
- }else{
- this.$router.push(menuConfig.url)
- }
- this.$store.commit('pushtags', menuConfig)
+
+ this.$router.push({ path: menuConfig.url, query: { index: menuConfig.index, param: menuConfig.params, time: (Math.random().toString()) } })
+ this.pushtags(menuConfig)
},
// 鑾峰彇鑿滃崟閰嶇疆
__getMenuConfig (value, key, menus) {
@@ -88,6 +132,41 @@
}
}
return null
+ },
+ computeTableHeight () {
+ this.$nextTick(() => {
+ const height = window.innerHeight
+ const height13 = this.getEleHeghtByClassName('common-header', 0)
+ const height5 = document.getElementsByTagName('thead') && document.getElementsByTagName('thead')[0] ? document.getElementsByTagName('thead')[0].clientHeight : 0
+ if (document.getElementsByClassName('main_app') && document.getElementsByClassName('main_app')[0]) {
+ const height3 = this.getEleHeghtByClassName('main-header', 0)
+ const height4 = this.getEleHeghtByClassName('table-pagination', 0)
+ const height2 = this.getEleHeghtByClassName('toolbar', 0)
+ const height6 = this.getEleHeghtByClassName('doumee-filter', 0, 16)
+ const height7 = this.getEleHeghtByClassName('pt16', 0, 0)
+ const height9 = this.getEleHeghtByClassName('static_wrap', 0)
+ const height10 = this.getEleHeghtByClassName('query_btns', 0)
+ const height11 = this.getEleHeghtByClassName('el-tabs-ele', 0)
+ const height12 = this.getEleHeghtByClassName('platgroup_tabs', 0)
+ this.$router.app.$store.commit('setTableHeightNew', height - height13 - height3 - height5 - height6 - height2 - height7 - height4 - height9 - height10 - height11 - height12)
+ } else {
+ const height1 = this.getEleHeghtByClassName('table-search-form', 40, 16)
+ const height3 = this.getEleHeghtByClassName('main-header', 0)
+ const height4 = this.getEleHeghtByClassName('table-pagination', 0)
+ const height2 = this.getEleHeghtByClassName('toolbar', 0)
+ this.$router.app.$store.commit('setTableHeightNew', height - height4 - height3 - height2 - height1 - height5 - height13)
+ }
+ })
+ },
+ getEleHeghtByClassName (name, dv, margin) {
+ if ((document.getElementsByClassName(name) && document.getElementsByClassName(name)[0])) {
+ let t = 0
+ document.getElementsByClassName(name).forEach(e => {
+ t++
+ })
+ return document.getElementsByClassName(name)[document.getElementsByClassName(name).length - 1].clientHeight + (margin || 0)
+ }
+ return dv || 0
}
}
}
@@ -107,46 +186,49 @@
.el-menu {
border-right: 0 !important;
user-select: none;
- background: $primary-color !important;
+ background: #fff !important;
.el-menu-item {
- background: $primary-color;
+ background: #fff;
+ height: 48px;
+ line-height: 48px;
// 閫変腑鐘舵��
&.is-active {
- background: $primary-color-sel !important;
+ background: #eff5fe !important;
}
// 鎮诞
&:hover {
- background-color: $primary-color-hover;
+ background-color: #eff5fe;
}
&:focus {
- background: $primary-color;
+ background: #eff5fe;
}
}
// 瀛愯彍鍗�
.el-submenu {
- .el-submenu__title{
- background-color: $primary-color;
+ .el-submenu__title {
+ background-color: #fff;
}
&.is-active {
- .el-submenu__title{
- background-color: $icon-background-color;
+ .el-submenu__title {
+ background-color: #fff;
}
- .el-menu .el-menu-item{
- background-color: $icon-background-color;
+ .el-menu .el-menu-item {
+ background-color: #fff;
// 鎮诞
&:hover {
- background-color: $icon-background-color;
+ background-color: #eff5fe;
}
}
}
// 鑿滃崟涓婁笅绠ご
.el-submenu__title i {
- color: #f7f7f7;
+ color: #979797;
+ font-size: 14px;
}
}
// 鑿滃崟鍥炬爣
i:not(.el-submenu__icon-arrow) {
- color: #f7f7f7 !important;
+ color: #333333 !important;
position: relative;
top: -1px;
// 鑷畾涔夊浘鏍�
--
Gitblit v1.9.3