index.ts 3.7 KB
Newer Older
V
vben 已提交
1
import type { Menu, MenuModule } from '/@/router/types';
陈文彬 已提交
2 3 4 5 6 7 8
import type { RouteRecordNormalized } from 'vue-router';
import { appStore } from '/@/store/modules/app';
import { permissionStore } from '/@/store/modules/permission';
import { transformMenuModule, flatMenus, getAllParentPath } from '/@/utils/helper/menuHelper';
import { filter } from '/@/utils/helper/treeHelper';
import router from '/@/router';
import { PermissionModeEnum } from '/@/enums/appEnum';
V
vben 已提交
9
import { pathToRegexp } from 'path-to-regexp';
V
vben 已提交
10
import modules from 'globby!/@/router/menus/modules/**/*.@(ts)';
陈文彬 已提交
11 12 13 14

// ===========================
// ==========module import====
// ===========================
V
vben 已提交
15
// import dashboard from './modules/dashboard';
N
nebv 已提交
16

V
vben 已提交
17 18 19 20 21 22 23 24 25
// import exceptionDemo from './modules/demo/exception';
// import iframeDemo from './modules/demo/iframe';
// import compDemo from './modules/demo/comp';
// import permissionDemo from './modules/demo/permission';
// import featDemo from './modules/demo/feat';
// import chartsDemo from './modules/demo/charts';
// import tableDemo from './modules/demo/table';
// import formDemo from './modules/demo/form';
// import treeDemo from './modules/demo/tree';
陈文彬 已提交
26

V
vben 已提交
27 28 29 30 31 32 33 34 35 36 37
const menuModules: MenuModule[] = [
  // dashboard,
  // featDemo,
  // exceptionDemo,
  // iframeDemo,
  // compDemo,
  // permissionDemo,
  // chartsDemo,
  // tableDemo,
  // formDemo,
  // treeDemo,
38
];
陈文彬 已提交
39

V
vben 已提交
40 41 42 43
Object.keys(modules).forEach((key) => {
  menuModules.push(modules[key]);
});

陈文彬 已提交
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
// ===========================
// ==========Helper===========
// ===========================

const staticMenus: Menu[] = [];
(() => {
  menuModules.sort((a, b) => {
    return (a.orderNo || 0) - (b.orderNo || 0);
  });
  for (const menu of menuModules) {
    staticMenus.push(transformMenuModule(menu));
  }
})();

const isBackMode = () => {
  return appStore.getProjectConfig.permissionMode === PermissionModeEnum.BACK;
};

async function getAsyncMenus() {
  // 前端角色控制菜单 直接取菜单文件
  if (!isBackMode()) {
    return staticMenus;
  }
  return permissionStore.getBackMenuListState;
}

// 获取深层扁平化菜单
export const getFlatMenus = async () => {
  const menus = await getAsyncMenus();

  return flatMenus(menus);
};

// 获取菜单 树级
export const getMenus = async () => {
  const menus = await getAsyncMenus();
  const routes = router.getRoutes();
  return !isBackMode() ? filter(menus, basicFilter(routes)) : menus;
};

// 获取当前路径的顶级路径
export async function getCurrentParentPath(currentPath: string) {
  const menus = await getAsyncMenus();
  const allParentPath = await getAllParentPath(menus, currentPath);
  return allParentPath[0];
}

// 获取1级菜单,删除children
export async function getShallowMenus() {
  const menus = await getAsyncMenus();
  const routes = router.getRoutes();
  const shallowMenuList = menus.map((item) => ({ ...item, children: undefined }));
  return !isBackMode() ? shallowMenuList.filter(basicFilter(routes)) : shallowMenuList;
}

// 获取菜单的children
export async function getChildrenMenus(parentPath: string) {
  const menus = await getAsyncMenus();
  const parent = menus.find((item) => item.path === parentPath);
  if (!parent) return [] as Menu[];
  return parent.children;
}

// 扁平化children
export async function getFlatChildrenMenus(children: Menu[]) {
  return flatMenus(children);
}

// 通用过滤方法
function basicFilter(routes: RouteRecordNormalized[]) {
  return (menu: Menu) => {
V
vben 已提交
115 116 117 118 119 120 121 122
    const matchRoute = routes.find((route) => {
      if (route.meta && route.meta.carryParam) {
        return pathToRegexp(route.path).test(menu.path);
      }
      return route.path === menu.path;
    });

    if (!matchRoute) return false;
陈文彬 已提交
123 124 125 126 127
    menu.icon = menu.icon || matchRoute.meta.icon;
    menu.meta = matchRoute.meta;
    return true;
  };
}