import Vue from "vue";
import VueRouter from "vue-router";

import Display from "../views/Display";
import Login from "../views/Login";
import Layout from "../views/Layout";
import BusRouter from "../views/Business/BusRouter";
import ReviewRouter from "../views/Review/ReviewRouter";
import DocRouter from "../views/Docpan/DocRouter";
import ModelViewer from "../views/ModeViewer"
// 新交易模块
import Business from "./modules/business";
import Review from "./modules/review";
import StaticsRouter from "../views/Statics/StaticsRouter";

Vue.use(VueRouter);

const DisplayRouter = Business.map(route => {
    const newRoute = Object.assign({}, route)
    newRoute.name = newRoute.name + 'Display'
    return newRoute;
})

/**
 * Detail see: https://panjiachen.github.io/vue-element-admin-site/guide/essentials/router-and-nav.html
 * 
 * name:'router-name'             name 必填 <keep-alive>使用这个
 * meta : {
 *   title: 'title'               title
 *   icon: 'svg-name'/'el-icon-x' 图标
 *   noCache: true                无需缓存起来的页面
 *   affix: true                  固定的页面视图
 *   activeMenu: '/example/list'  if set path, the sidebar will highlight the path you set
 * }
 */
export const routes = [
    // 刷新时使用
    {
        path: '/redirect',
        component: Layout,
        hidden: true,
        children: [
            {
                path: '/redirect/:path(.*)',
                component: () => import('~/views/Redirect/index')
            }
        ]
    },
    {
        path: "/",
        component: Layout,
        redirect: "/home",
        children: [
            { path: 'home', component: () => import('~/views/Home/index1.vue'), name: 'Home', meta: { title: '首页', icon: 'el-icon-s-home', affix: true } },
            { path: 'taskList', component: () => import('~/views/TaskList'), name: 'TaskList', meta: { title: '任务列表', icon: 'el-icon-s-claim', affix: true } },
        ],
    },
    { path: "/review", component: Layout, children: ReviewRouter },
    { path: "/review-new", component: Layout, children: Review },
    { path: "/business", component: Layout, children: BusRouter },
    { path: "/business-new", component: Layout, children: Business },
    { path: "/statics", component: Layout, children: StaticsRouter },
    { path: "/display", component: Display, children: DisplayRouter },
    { path: "/login", component: Login, name: "Login" },
    { path: "/docpan", component: () => import("../views/Docpan"), children: DocRouter },
    { path: "/model/viewer",component:ModelViewer},
];

const rootRouter = new VueRouter({
    routes,
});


// 解决ElementUI导航栏中的vue-router在3.0版本以上重复点菜单报错问题
const originalPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location) {
    return originalPush.call(this, location).catch(err => err)
}

export default rootRouter;