1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- import type { RouteRecordRaw } from 'vue-router';
- import type { App } from 'vue';
- import { createRouter, createWebHashHistory, createWebHistory } from 'vue-router';
- import { basicRoutes } from './routes';
- // 白名单应该包含基本静态路由
- const WHITE_NAME_LIST: string[] = [];
- const getRouteNames = (array: any[]) =>
- array.forEach((item) => {
- WHITE_NAME_LIST.push(item.name);
- getRouteNames(item.children || []);
- });
- getRouteNames(basicRoutes);
- // app router
- export const router = createRouter({
- history: createWebHistory(import.meta.env.VITE_PUBLIC_PATH),
- routes: basicRoutes as unknown as RouteRecordRaw[],
- strict: true,
- scrollBehavior: () => ({ left: 0, top: 0 }),
- });
- // TODO 【QQYUN-4517】【表单设计器】记录分享路由守卫测试
- router.beforeEach(async (to, from, next) => {
- debugger;
- //console.group('【QQYUN-4517】beforeEach');
- //console.warn('from', from);
- //console.warn('to', to);
- //console.groupEnd();
- next();
- });
- // reset router
- export function resetRouter() {
- router.getRoutes().forEach((route) => {
- const { name } = route;
- if (name && !WHITE_NAME_LIST.includes(name as string)) {
- router.hasRoute(name) && router.removeRoute(name);
- }
- });
- }
- // config router
- export function setupRouter(app: App<Element>) {
- app.use(router);
- }
|