Forráskód Böngészése

feat: 修改菜单解析

aXin-0810 2 éve
szülő
commit
e9897223f4
1 módosított fájl, 8 hozzáadás és 80 törlés
  1. 8 80
      src/layout/components/Sidebar/SidebarItem.vue

+ 8 - 80
src/layout/components/Sidebar/SidebarItem.vue

@@ -1,45 +1,23 @@
 <template>
-  <div v-if="!item.hidden">
-    <!-- <template v-if="hasOneShowingChild(item.children,item) && (!onlyOneChild.children||onlyOneChild.noShowingChildren) && !item.alwaysShow"> -->
-    <template
-      v-if="
-        hasOneShowingChild(item.children, item) &&
-        (!onlyOneChild.children ||
-          onlyOneChild.noShowingChildren ||
-          (onlyOneChild.children &&
-          onlyOneChild.children&& onlyOneChild.children.length < 1 &&
-            (onlyOneChild.name == 'issue_index' ||
-              onlyOneChild.name == 'notice_index' ||
-              onlyOneChild.name == 'dashboard'))) &&
-        !item.alwaysShow
-      "
-    >
-      <app-link v-if="onlyOneChild.meta" :to="resolvePath(onlyOneChild.path)">
-        <el-menu-item :index="resolvePath(onlyOneChild.path)" :class="{ 'submenu-title-noDropdown': !isNest }">
-          <item :icon="onlyOneChild.meta.icon || (item.meta && item.meta.icon)" :title="onlyOneChild.meta.title" />
+  <div v-if="!item.hidden || item.noShowingChildren">
+    <template v-if="!item.children || !item.children.length">
+      <app-link v-if="item.meta" :to="item.name">
+        <el-menu-item :index="item.name" :class="{ 'submenu-title-noDropdown': !isNest }">
+          <item :icon="item.meta.icon || (item.meta && item.meta.icon)" :title="item.meta.title" />
         </el-menu-item>
       </app-link>
     </template>
 
-    <el-submenu v-else ref="subMenu" :index="resolvePath(item.path)" popper-append-to-body>
+    <el-submenu v-else ref="subMenu" :index="item.name" popper-append-to-body>
       <template slot="title">
         <item v-if="item.meta" :icon="item.meta && item.meta.icon" :title="item.meta.title" />
       </template>
-      <sidebar-item
-        v-for="child in item.children"
-        :key="child.path"
-        :is-nest="true"
-        :item="child"
-        :base-path="resolvePath(child.path)"
-        class="nest-menu"
-      />
+      <sidebar-item v-for="child in item.children" :key="child.name" :is-nest="true" :item="child" class="nest-menu" />
     </el-submenu>
   </div>
 </template>
 
 <script>
-import path from 'path'
-import { isExternal } from '@/utils/validate'
 import Item from './Item'
 import AppLink from './Link'
 import FixiOSBug from './FixiOSBug'
@@ -49,7 +27,6 @@ export default {
   components: { Item, AppLink },
   mixins: [FixiOSBug],
   props: {
-    // route object
     item: {
       type: Object,
       required: true
@@ -57,60 +34,11 @@ export default {
     isNest: {
       type: Boolean,
       default: false
-    },
-    basePath: {
-      type: String,
-      default: ''
     }
   },
   data() {
-    // To fix https://github.com/PanJiaChen/vue-admin-template/issues/237
-    // TODO: refactor with render function
-    this.onlyOneChild = null
     return {}
   },
-  methods: {
-    hasOneShowingChild(children = [], parent) {
-      const showingChildren = children.filter(item => {
-        if (item.hidden) {
-          return false
-        } else {
-          // Temp set(will be used if only has one showing child)
-
-          // 删除空的children
-          if (item.children&&item.children.length < 1) {
-            // delete item['children']
-          }
-
-          this.onlyOneChild = item
-
-          // console.log(item);
-          return true
-        }
-      })
-
-      // When there is only one child router, the child router is displayed by default
-      if (showingChildren&&showingChildren.length === 1) {
-        return true
-      }
-
-      // Show parent if there are no child router to display
-      if (showingChildren&&showingChildren.length === 0) {
-        this.onlyOneChild = { ...parent, path: '', noShowingChildren: true }
-        return true
-      }
-      return false
-    },
-    resolvePath(routePath) {
-      if (isExternal(routePath)) {
-        return routePath
-      }
-      if (isExternal(this.basePath)) {
-        return this.basePath
-      }
-
-      return path.resolve(this.basePath, routePath)
-    }
-  }
+  methods: {}
 }
 </script>