vben
2020-11-12 ecfb702b09e296efd5bf095d65840147d47b7923
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
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
import type { RouteRecordRaw } from 'vue-router';
import { RoleEnum } from '/@/enums/roleEnum';
export interface RouteMeta {
  // title
  title: string;
  // Whether to ignore permissions
  ignoreAuth?: boolean;
  // role info
  roles?: RoleEnum[];
  // Whether not to cache
  ignoreKeepAlive?: boolean;
  // Is it fixed on tab
  affix?: boolean;
  // icon on tab
  icon?: string;
  // Jump address
  frameSrc?: string;
  // Outer link jump address
  externalLink?: string;
 
  // current page transition
  transitionName?: string;
 
  // Whether the route has been dynamically added
  hideBreadcrumb?: boolean;
 
  // disabled redirect
  disabledRedirect?: boolean;
 
  // close loading
  afterCloseLoading?: boolean;
  // Is it in the tab
  inTab?: boolean;
  // Carrying parameters
  carryParam?: boolean;
}
 
export interface AppRouteRecordRaw extends Omit<RouteRecordRaw, 'meta'> {
  meta: RouteMeta;
  component?: any;
  components?: any;
  children?: AppRouteRecordRaw[];
  props?: any;
  fullPath?: string;
}
export interface MenuTag {
  type?: 'primary' | 'error' | 'warn' | 'success';
  content?: string;
  dot?: boolean;
}
 
export interface Menu {
  name: string;
 
  icon?: string;
 
  path: string;
 
  disabled?: boolean;
 
  children?: Menu[];
 
  orderNo?: number;
 
  roles?: RoleEnum[];
 
  meta?: Partial<RouteMeta>;
 
  tag?: MenuTag;
}
export interface MenuModule {
  orderNo?: number;
  menu: Menu;
}
 
interface RouteModule {
  layout: AppRouteRecordRaw;
  routes: AppRouteRecordRaw[];
  children?: AppRouteRecordRaw[];
  component?: any;
}
 
export type AppRouteModule = RouteModule | AppRouteRecordRaw;