|
@@ -1,75 +1,83 @@
|
|
|
-import { modeFlags, ModeFlag } from '@/store/sys';
|
|
|
-import { ComputedRef } from 'vue';
|
|
|
-import { RouteRecordRaw } from 'vue-router';
|
|
|
-import { RouteNameRaw, RouteMetaRaw, readyRouteMeta, readyRouteName, defRouteName } from './constant';
|
|
|
+import { modeFlags, ModeFlag } from "@/store/sys";
|
|
|
+import { ComputedRef } from "vue";
|
|
|
+import { RouteRecordRaw } from "vue-router";
|
|
|
+import {
|
|
|
+ RouteNameRaw,
|
|
|
+ RouteMetaRaw,
|
|
|
+ readyRouteMeta,
|
|
|
+ readyRouteName,
|
|
|
+ defRouteName,
|
|
|
+} from "./constant";
|
|
|
|
|
|
-export type RouteAtom<T extends ModeFlag = any, key = RouteNameRaw<T>[keyof RouteNameRaw<T>]> = {
|
|
|
+export type RouteAtom<
|
|
|
+ T extends ModeFlag = any,
|
|
|
+ key = RouteNameRaw<T>[keyof RouteNameRaw<T>]
|
|
|
+> = {
|
|
|
path: string;
|
|
|
name: key;
|
|
|
meta: key extends keyof RouteMetaRaw<T> ? RouteMetaRaw<T>[key] : never;
|
|
|
- component: RouteRecordRaw['component'];
|
|
|
+ component: RouteRecordRaw["component"];
|
|
|
redirect?: string;
|
|
|
children?: RoutesRaw<T>;
|
|
|
};
|
|
|
|
|
|
export type RoutesRaw<T extends ModeFlag = any> = RouteAtom<T>[];
|
|
|
|
|
|
-import graphic from '@/views/graphic/index.vue';
|
|
|
export const writeRoutesRaw: RoutesRaw<typeof modeFlags.LOGIN> = [
|
|
|
{
|
|
|
- path: '/graphic/:mode/:action/:id',
|
|
|
+ path: "/graphic/:mode/:action/:id",
|
|
|
name: readyRouteName.graphic,
|
|
|
meta: readyRouteMeta.graphic,
|
|
|
- component: () => import('@/views/graphic/index.vue'),
|
|
|
+ component: () => import("@/views/graphic/index.vue"),
|
|
|
},
|
|
|
{
|
|
|
- path: '/scene',
|
|
|
+ path: "/scene",
|
|
|
name: readyRouteName.scene,
|
|
|
meta: readyRouteMeta.scene,
|
|
|
- component: () => import('@/views/scene/index.vue'),
|
|
|
+ component: () => import("@/views/scene/index.vue"),
|
|
|
},
|
|
|
|
|
|
{
|
|
|
- path: '/photos',
|
|
|
+ path: "/photos",
|
|
|
name: readyRouteName.photos,
|
|
|
meta: readyRouteMeta.photos,
|
|
|
- component: () => import('@/views/photos/index.vue'),
|
|
|
+ component: () => import("@/views/photos/index.vue"),
|
|
|
},
|
|
|
{
|
|
|
- path: '/accidents',
|
|
|
+ path: "/accidents",
|
|
|
name: readyRouteName.accidents,
|
|
|
meta: readyRouteMeta.accidents,
|
|
|
- component: () => import('@/views/accidents/index.vue'),
|
|
|
+ component: () => import("@/views/accidents/index.vue"),
|
|
|
},
|
|
|
{
|
|
|
- path: '/gena4/:id1/:id2',
|
|
|
+ path: "/gena4/:id1/:id2",
|
|
|
name: readyRouteName.gena4,
|
|
|
meta: readyRouteMeta.gena4,
|
|
|
- component: () => import('@/views/accidents/print.vue'),
|
|
|
+ component: () => import("@/views/accidents/print.vue"),
|
|
|
},
|
|
|
{
|
|
|
- path: '/roads',
|
|
|
+ path: "/roads",
|
|
|
name: readyRouteName.roads,
|
|
|
meta: readyRouteMeta.roads,
|
|
|
- component: () => import('@/views/roads/index.vue'),
|
|
|
+ component: () => import("@/views/roads/index.vue"),
|
|
|
},
|
|
|
{
|
|
|
- path: '/tabulation/:id',
|
|
|
+ path: "/tabulation/:id",
|
|
|
name: readyRouteName.tabulation,
|
|
|
meta: readyRouteMeta.tabulation,
|
|
|
- component: () => import('@/views/roads/tabulation.vue'),
|
|
|
+ component: () => import("@/views/roads/tabulation.vue"),
|
|
|
},
|
|
|
{
|
|
|
- path: '/tables/:name',
|
|
|
+ path: "/tables/:name",
|
|
|
name: readyRouteName.tables,
|
|
|
meta: readyRouteMeta.tables,
|
|
|
- component: () => import('@/views/tables/index.vue'),
|
|
|
+ component: () => import("@/views/tables/index.vue"),
|
|
|
},
|
|
|
{
|
|
|
- path: '/demo/:id',
|
|
|
+ path: "/demo/:id",
|
|
|
name: readyRouteName.demo,
|
|
|
meta: readyRouteMeta.demo,
|
|
|
- component: () => import('@/views/tables/demo.vue'),
|
|
|
+ component: () => import("@/views/tables/demo.vue"),
|
|
|
},
|
|
|
];
|
|
|
|