From a8fb7ae2dbb61a94141ed5e73d3bb2632b7b84df Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期日, 28 九月 2025 15:25:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/wuhuyancao' into wuhuyancao

---
 admin/src/main.js |   51 ++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 46 insertions(+), 5 deletions(-)

diff --git a/admin/src/main.js b/admin/src/main.js
index 0cac6e7..a98f12b 100644
--- a/admin/src/main.js
+++ b/admin/src/main.js
@@ -37,7 +37,7 @@
   router,
   store,
   computed: {
-    ...mapState(['userInfo', 'homePage'])
+    ...mapState(['userInfo', 'homePage','topMenuCurrent','menuData'])
   },
   watch: {
     async userInfo () {
@@ -45,10 +45,16 @@
         return
       }
       await this.initRoutes()
+    },
+    async topMenuCurrent () {
+      if (this.topMenuCurrent == null) {
+        return
+      }
+      await this.chagneRoutes()
     }
   },
   methods: {
-    ...mapMutations(['switchCollapseMenu', 'setHomePage']),
+    ...mapMutations(['switchCollapseMenu', 'setHomePage', 'setTopMenuCurrent', 'setTopMenuCurrent','cleartagsview']),
     // 鍒濆鍖栨湰鍦伴厤缃�
     initLocalConfig () {
       // 鑿滃崟鐘舵�侀厤缃�
@@ -67,15 +73,40 @@
       this.$store.commit('resetMenus')
       // 鑾峰彇鑿滃崟
       const storeMenus = this.$store.state.menuData.list
+      const storeTopMenus = this.$store.state.topMenuList.list
       if (storeMenus.length > 0 && this.homePage == null) {
         this.setHomePage(storeMenus[0])
       }
       await fetchMenuTree()
-        .then(menus => {
+        .then(allmenus => {
           // 娣诲姞鑿滃崟
-          storeMenus.push.apply(storeMenus, menus)
+          var topList = allmenus.filter(item => {
+            return item.type === 1
+          })
+          storeTopMenus.push.apply(storeTopMenus, topList)
+          var topCurrent = null
+          var tlist =[]
+          topList.forEach(item => {
+            if (item.linkType === 0 ) {
+              if (topCurrent == null) {
+                topCurrent = item
+              }
+              tlist.push(...item.children)
+            }
+          })
+          this.setTopMenuCurrent(topCurrent)
+          // console.log(topList)
+          // var menus = []
+          // topList.forEach(item => {
+          //   console.log(topCurrent.id, item.id)
+          //   if (item.id == this.topMenuCurrent.id) {
+          //     menus = item.children
+          //   }
+          // })
+          console.log('menus', this.menuData.list)
+          storeMenus.push.apply(storeMenus, this.menuData.list)
           // 娣诲姞璺敱
-          this.__addRouters(storeMenus)
+          this.__addRouters(tlist)
           // 404
           router.addRoute({
             path: '*',
@@ -99,6 +130,16 @@
           this.loading = false
         })
     },
+    async chagneRoutes () {
+      // 閲嶇疆鑿滃崟
+      this.cleartagsview('/index')
+      console.log('menus', this.menuData.list)
+      // 娣诲姞璺敱
+      // this.__addRouters(this.menuData.list)
+      if(this.topMenuCurrent.homeUrl){
+        await this.$router.push({path: this.topMenuCurrent.homeUrl, query: {}})
+      }
+    },
     // 鏂板缓璺敱
     __addRouters (routes, parents = []) {
       if (routes == null || routes.length === 0) {

--
Gitblit v1.9.3