vue2-client 1.5.21 → 1.5.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (101) hide show
  1. package/CHANGELOG.md +522 -519
  2. package/index.js +30 -30
  3. package/package.json +78 -78
  4. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +225 -225
  5. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +667 -667
  6. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +508 -508
  7. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +140 -140
  8. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +165 -165
  9. package/src/base-client/components/common/JSONToTree/jsontotree.vue +275 -275
  10. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  11. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +109 -109
  12. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  13. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  14. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  15. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  16. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  17. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  18. package/src/base-client/plugins/AppData.js +76 -75
  19. package/src/base-client/plugins/GetLoginInfoService.js +179 -179
  20. package/src/base-client/plugins/PagedList.js +177 -177
  21. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  22. package/src/base-client/plugins/i18n-extend.js +32 -32
  23. package/src/components/Ellipsis/Ellipsis.vue +65 -65
  24. package/src/components/Ellipsis/index.md +38 -38
  25. package/src/components/NumberInfo/index.md +43 -43
  26. package/src/components/STable/README.md +341 -341
  27. package/src/components/STable/index.js +318 -318
  28. package/src/components/Trend/index.md +45 -45
  29. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  30. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  31. package/src/components/exception/ExceptionPage.vue +70 -70
  32. package/src/components/form/FormRow.vue +52 -52
  33. package/src/components/index.js +36 -36
  34. package/src/components/menu/SideMenu.vue +62 -62
  35. package/src/components/menu/menu.js +273 -273
  36. package/src/components/page/header/index.less +40 -40
  37. package/src/components/setting/Setting.vue +235 -235
  38. package/src/components/table/StandardTable.vue +141 -141
  39. package/src/components/table/advance/ActionColumns.vue +158 -158
  40. package/src/components/table/advance/SearchArea.vue +355 -355
  41. package/src/components/tool/AStepItem.vue +60 -60
  42. package/src/components/tool/AvatarList.vue +68 -68
  43. package/src/components/tool/Drawer.vue +142 -142
  44. package/src/components/tool/TagSelect.vue +83 -83
  45. package/src/components/transition/PageToggleTransition.vue +97 -97
  46. package/src/config/default/admin.config.js +18 -18
  47. package/src/config/default/setting.config.js +44 -44
  48. package/src/config/replacer/resolve.config.js +67 -67
  49. package/src/layouts/AdminLayout.vue +174 -174
  50. package/src/layouts/CommonLayout.vue +42 -42
  51. package/src/layouts/ComponentLayoutOne.vue +47 -47
  52. package/src/layouts/PageLayout.vue +151 -151
  53. package/src/layouts/SinglePageView.vue +111 -111
  54. package/src/layouts/footer/PageFooter.vue +49 -49
  55. package/src/layouts/header/AdminHeader.vue +104 -104
  56. package/src/layouts/header/HeaderAvatar.vue +64 -61
  57. package/src/layouts/header/HeaderNotice.vue +176 -176
  58. package/src/layouts/header/HeaderSearch.vue +67 -67
  59. package/src/layouts/header/InstitutionDetail.vue +181 -181
  60. package/src/layouts/header/index.less +92 -92
  61. package/src/layouts/tabs/TabsHead.vue +190 -190
  62. package/src/layouts/tabs/TabsView.vue +379 -379
  63. package/src/mock/goods/index.js +108 -108
  64. package/src/pages/exception/404.vue +25 -25
  65. package/src/pages/login/Login.vue +363 -363
  66. package/src/pages/report/ReportTable.js +124 -124
  67. package/src/pages/report/ReportTableHome.vue +28 -28
  68. package/src/pages/resourceManage/orgListManage.vue +98 -98
  69. package/src/pages/system/dictionary/index.vue +43 -43
  70. package/src/pages/system/file/index.vue +317 -317
  71. package/src/pages/system/monitor/loginInfor/index.vue +36 -36
  72. package/src/pages/system/monitor/operLog/index.vue +36 -36
  73. package/src/pages/system/queryParams/index.vue +43 -43
  74. package/src/pages/system/settings/index.vue +126 -0
  75. package/src/pages/system/settings/modifyPassword.vue +109 -0
  76. package/src/router/async/config.async.js +28 -27
  77. package/src/router/async/router.map.js +68 -68
  78. package/src/router/index.js +27 -27
  79. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  80. package/src/services/api/LogDetailsViewApi.js +10 -10
  81. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  82. package/src/services/api/TicketDetailsViewApi.js +34 -34
  83. package/src/services/api/cas.js +79 -79
  84. package/src/services/api/commonTempTable.js +10 -10
  85. package/src/services/api/index.js +17 -17
  86. package/src/services/api/logininfor/index.js +6 -6
  87. package/src/services/api/manage.js +8 -8
  88. package/src/services/apiService.js +14 -13
  89. package/src/services/user.js +64 -53
  90. package/src/store/modules/index.js +4 -4
  91. package/src/theme/default/nprogress.less +76 -76
  92. package/src/theme/default/style.less +47 -47
  93. package/src/utils/colors.js +107 -107
  94. package/src/utils/excel/Blob.js +180 -180
  95. package/src/utils/excel/Export2Excel.js +141 -141
  96. package/src/utils/formatter.js +68 -68
  97. package/src/utils/i18n.js +80 -80
  98. package/src/utils/theme-color-replacer-extend.js +91 -91
  99. package/src/utils/themeUtil.js +100 -100
  100. package/src/utils/util.js +230 -230
  101. package/vue.config.js +106 -106
@@ -1,36 +1,36 @@
1
- <template>
2
- <a-card :bordered="false">
3
- <x-form-table
4
- title="登录日志"
5
- :queryParamsName="queryParamsName"
6
- @action="toDetail">
7
- </x-form-table>
8
- </a-card>
9
- </template>
10
-
11
- <script>
12
- import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
13
-
14
- export default {
15
- name: 'loginInfor',
16
- components: {
17
- XFormTable
18
- },
19
- data () {
20
- return {
21
- // 选中的编号
22
- selectNo: undefined,
23
- // 查询配置文件名
24
- queryParamsName: 'loginInforQueryParams',
25
- // 是否显示详情抽屉
26
- detailVisible: false
27
- }
28
- },
29
- methods: {
30
- toDetail (record, id) {
31
- this.selectNo = id + ''
32
- this.detailVisible = true
33
- }
34
- }
35
- }
36
- </script>
1
+ <template>
2
+ <a-card :bordered="false">
3
+ <x-form-table
4
+ title="登录日志"
5
+ :queryParamsName="queryParamsName"
6
+ @action="toDetail">
7
+ </x-form-table>
8
+ </a-card>
9
+ </template>
10
+
11
+ <script>
12
+ import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
13
+
14
+ export default {
15
+ name: 'loginInfor',
16
+ components: {
17
+ XFormTable
18
+ },
19
+ data () {
20
+ return {
21
+ // 选中的编号
22
+ selectNo: undefined,
23
+ // 查询配置文件名
24
+ queryParamsName: 'loginInforQueryParams',
25
+ // 是否显示详情抽屉
26
+ detailVisible: false
27
+ }
28
+ },
29
+ methods: {
30
+ toDetail (record, id) {
31
+ this.selectNo = id + ''
32
+ this.detailVisible = true
33
+ }
34
+ }
35
+ }
36
+ </script>
@@ -1,36 +1,36 @@
1
- <template>
2
- <a-card :bordered="false">
3
- <x-form-table
4
- title="操作日志"
5
- :queryParamsName="queryParamsName"
6
- @action="toDetail">
7
- </x-form-table>
8
- </a-card>
9
- </template>
10
-
11
- <script>
12
- import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
13
-
14
- export default {
15
- name: 'operLog',
16
- components: {
17
- XFormTable
18
- },
19
- data () {
20
- return {
21
- // 选中的编号
22
- selectNo: undefined,
23
- // 查询配置文件名
24
- queryParamsName: 'operLogQueryParams',
25
- // 是否显示详情抽屉
26
- detailVisible: false
27
- }
28
- },
29
- methods: {
30
- toDetail (record, id) {
31
- this.selectNo = id + ''
32
- this.detailVisible = true
33
- }
34
- }
35
- }
36
- </script>
1
+ <template>
2
+ <a-card :bordered="false">
3
+ <x-form-table
4
+ title="操作日志"
5
+ :queryParamsName="queryParamsName"
6
+ @action="toDetail">
7
+ </x-form-table>
8
+ </a-card>
9
+ </template>
10
+
11
+ <script>
12
+ import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
13
+
14
+ export default {
15
+ name: 'operLog',
16
+ components: {
17
+ XFormTable
18
+ },
19
+ data () {
20
+ return {
21
+ // 选中的编号
22
+ selectNo: undefined,
23
+ // 查询配置文件名
24
+ queryParamsName: 'operLogQueryParams',
25
+ // 是否显示详情抽屉
26
+ detailVisible: false
27
+ }
28
+ },
29
+ methods: {
30
+ toDetail (record, id) {
31
+ this.selectNo = id + ''
32
+ this.detailVisible = true
33
+ }
34
+ }
35
+ }
36
+ </script>
@@ -1,43 +1,43 @@
1
- <template>
2
- <a-card :bordered="false">
3
- <query-params-details-view
4
- v-if="selectId"
5
- :id="selectId"
6
- :visible.sync="detailVisible"
7
- />
8
- <x-form-table
9
- :queryParamsName="queryParamsName"
10
- title="查询配置"
11
- @action="toDetail">
12
- </x-form-table>
13
- </a-card>
14
- </template>
15
-
16
- <script>
17
- import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
18
- import QueryParamsDetailsView from '@vue2-client/base-client/components/system/QueryParamsDetailsView'
19
-
20
- export default {
21
- name: 'QueryParams',
22
- components: {
23
- XFormTable,
24
- QueryParamsDetailsView
25
- },
26
- data () {
27
- return {
28
- // 选中的编号
29
- selectId: undefined,
30
- // 查询配置文件名
31
- queryParamsName: 'queryParams',
32
- // 是否显示详情抽屉
33
- detailVisible: false
34
- }
35
- },
36
- methods: {
37
- toDetail (record, id) {
38
- this.selectId = id + ''
39
- this.detailVisible = true
40
- }
41
- }
42
- }
43
- </script>
1
+ <template>
2
+ <a-card :bordered="false">
3
+ <query-params-details-view
4
+ v-if="selectId"
5
+ :id="selectId"
6
+ :visible.sync="detailVisible"
7
+ />
8
+ <x-form-table
9
+ :queryParamsName="queryParamsName"
10
+ title="查询配置"
11
+ @action="toDetail">
12
+ </x-form-table>
13
+ </a-card>
14
+ </template>
15
+
16
+ <script>
17
+ import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
18
+ import QueryParamsDetailsView from '@vue2-client/base-client/components/system/QueryParamsDetailsView'
19
+
20
+ export default {
21
+ name: 'QueryParams',
22
+ components: {
23
+ XFormTable,
24
+ QueryParamsDetailsView
25
+ },
26
+ data () {
27
+ return {
28
+ // 选中的编号
29
+ selectId: undefined,
30
+ // 查询配置文件名
31
+ queryParamsName: 'queryParams',
32
+ // 是否显示详情抽屉
33
+ detailVisible: false
34
+ }
35
+ },
36
+ methods: {
37
+ toDetail (record, id) {
38
+ this.selectId = id + ''
39
+ this.detailVisible = true
40
+ }
41
+ }
42
+ }
43
+ </script>
@@ -0,0 +1,126 @@
1
+ <template>
2
+ <div class="page-header-index-wide">
3
+ <a-card :bordered="false" :bodyStyle="{ padding: '16px 0', height: '100%' }" :style="{ height: '100%' }">
4
+ <div class="account-settings-info-main" :class="{ 'mobile': isMobile }">
5
+ <div class="account-settings-info-left">
6
+ <a-menu
7
+ :mode="isMobile ? 'horizontal' : 'inline'"
8
+ :style="{ border: '0', width: isMobile ? '560px' : 'auto'}"
9
+ :selectedKeys="selectedKeys"
10
+ type="inner"
11
+ @click="onClick"
12
+ >
13
+ <a-menu-item key="modifyPassword">
14
+ 修改密码
15
+ </a-menu-item>
16
+ </a-menu>
17
+ </div>
18
+ <div class="account-settings-info-right">
19
+ <div class="account-settings-info-title">
20
+ <span>{{ $route.meta.title }}</span>
21
+ </div>
22
+ <a-page-header
23
+ v-if="openKey === 'modifyPassword'"
24
+ title="修改密码">
25
+ <modify-password/>
26
+ </a-page-header>
27
+ </div>
28
+ </div>
29
+ </a-card>
30
+ </div>
31
+ </template>
32
+
33
+ <script>
34
+ import { mapState } from 'vuex'
35
+ import modifyPassword from '@vue2-client/pages/system/settings/modifyPassword'
36
+
37
+ export default {
38
+ components: { modifyPassword },
39
+ computed: {
40
+ ...mapState('setting', ['isMobile']),
41
+ },
42
+ data () {
43
+ return {
44
+ // horizontal inline
45
+ mode: 'inline',
46
+
47
+ openKey: 'modifyPassword',
48
+ selectedKeys: [],
49
+
50
+ // cropper
51
+ preview: {},
52
+ option: {
53
+ img: '/avatar2.jpg',
54
+ info: true,
55
+ size: 1,
56
+ outputType: 'jpeg',
57
+ canScale: false,
58
+ autoCrop: true,
59
+ // 只有自动截图开启 宽度高度才生效
60
+ autoCropWidth: 180,
61
+ autoCropHeight: 180,
62
+ fixedBox: true,
63
+ // 开启宽度和高度比例
64
+ fixed: true,
65
+ fixedNumber: [1, 1]
66
+ },
67
+
68
+ pageTitle: ''
69
+ }
70
+ },
71
+ mounted () {
72
+ },
73
+ methods: {
74
+ onClick (openKeys) {
75
+ this.openKey = openKeys.key
76
+ }
77
+ }
78
+ }
79
+ </script>
80
+
81
+ <style lang="less" scoped>
82
+ .account-settings-info-main {
83
+ width: 100%;
84
+ display: flex;
85
+ height: 100%;
86
+ overflow: auto;
87
+
88
+ &.mobile {
89
+ display: block;
90
+
91
+ .account-settings-info-left {
92
+ border-right: unset;
93
+ border-bottom: 1px solid #e8e8e8;
94
+ width: 100%;
95
+ height: 50px;
96
+ overflow-x: auto;
97
+ overflow-y: scroll;
98
+ }
99
+ .account-settings-info-right {
100
+ padding: 20px 40px;
101
+ }
102
+ }
103
+
104
+ .account-settings-info-left {
105
+ border-right: 1px solid #e8e8e8;
106
+ width: 224px;
107
+ }
108
+
109
+ .account-settings-info-right {
110
+ flex: 1 1;
111
+ padding: 8px 40px;
112
+
113
+ .account-settings-info-title {
114
+ color: rgba(0,0,0,.85);
115
+ font-size: 20px;
116
+ font-weight: 500;
117
+ line-height: 28px;
118
+ margin-bottom: 12px;
119
+ }
120
+ .account-settings-info-view {
121
+ padding-top: 12px;
122
+ }
123
+ }
124
+ }
125
+
126
+ </style>
@@ -0,0 +1,109 @@
1
+ <template>
2
+ <div class="account-settings-info-view">
3
+ <a-row :gutter="16">
4
+ <a-col :md="24" :lg="16">
5
+ <a-form-model
6
+ ref="form"
7
+ :rules="rules"
8
+ :model="form"
9
+ >
10
+ <a-form-model-item
11
+ label="原密码"
12
+ prop="oldPassword">
13
+ <a-input-password v-model="form.oldPassword" placeholder="原密码"/>
14
+ </a-form-model-item>
15
+ <a-form-model-item
16
+ label="新密码"
17
+ prop="newPassword">
18
+ <a-input-password v-model="form.newPassword" placeholder="新密码"/>
19
+ </a-form-model-item>
20
+ <a-form-model-item
21
+ label="重复一遍新密码"
22
+ prop="confirmNewPassword">
23
+ <a-input-password v-model="form.confirmNewPassword" placeholder="重复一遍新密码"/>
24
+ </a-form-model-item>
25
+ <a-button type="primary" @click="onSubmit()" :loading="loading">提交</a-button>
26
+ </a-form-model>
27
+ </a-col>
28
+ </a-row>
29
+ </div>
30
+ </template>
31
+
32
+ <script>
33
+ import { logout, modifyPassword } from '@vue2-client/services/user'
34
+ import { mapState } from 'vuex'
35
+
36
+ export default {
37
+ name: 'modifyPassword',
38
+ computed: {
39
+ ...mapState('account', { currUser: 'user' })
40
+ },
41
+ data () {
42
+ return {
43
+ loading: false,
44
+ // 表单Model
45
+ form: {},
46
+ // 校验
47
+ rules: {
48
+ oldPassword: [
49
+ {
50
+ required: true,
51
+ message: '请输入原密码',
52
+ trigger: 'blur'
53
+ }
54
+ ],
55
+ newPassword: [
56
+ {
57
+ required: true,
58
+ message: '请输入新密码',
59
+ trigger: 'blur'
60
+ }
61
+ ],
62
+ confirmNewPassword: [
63
+ {
64
+ required: true,
65
+ message: '请重复输入一遍新密码',
66
+ trigger: 'blur'
67
+ }
68
+ ],
69
+ }
70
+ }
71
+ },
72
+ methods: {
73
+ onSubmit () {
74
+ this.$refs.form.validate(valid => {
75
+ // 验证未通过直接返回
76
+ if (!valid) {
77
+ return false
78
+ }
79
+ if (this.form.oldPassword === this.form.newPassword) {
80
+ this.$message.warn('新密码不可与原密码相同!')
81
+ return false
82
+ }
83
+ if (this.form.newPassword !== this.form.confirmNewPassword) {
84
+ this.$message.warn('两次新密码不一致!')
85
+ return false
86
+ }
87
+ this.loading = true
88
+ modifyPassword(this.currUser.ename, this.form.oldPassword, this.form.newPassword).then(data => {
89
+ if (data) {
90
+ this.$message.success('修改密码成功,请重新登录!')
91
+ logout().finally(res => {
92
+ location.href = '/login'
93
+ })
94
+ } else {
95
+ this.$message.error('修改密码失败,原密码错误,请重试')
96
+ }
97
+ }).catch(e => {
98
+ this.$message.error('修改密码失败:' + e)
99
+ }).finally(() => {
100
+ this.loading = false
101
+ })
102
+ })
103
+ },
104
+ }
105
+ }
106
+ </script>
107
+
108
+ <style lang="less" scoped>
109
+ </style>
@@ -1,27 +1,28 @@
1
- import routerMap from './router.map'
2
- import { parseRoutes } from '@vue2-client/utils/routerUtil'
3
-
4
- // 异步路由配置
5
- const routesConfig = [
6
- 'login',
7
- 'submitTicket',
8
- 'root',
9
- {
10
- router: 'exp404',
11
- path: '*',
12
- name: '404'
13
- },
14
- {
15
- router: 'exp403',
16
- path: '/403',
17
- name: '403'
18
- }
19
- ]
20
-
21
- const options = {
22
- mode: 'history',
23
- routes: parseRoutes(routesConfig, routerMap),
24
- config: routesConfig
25
- }
26
-
27
- export default options
1
+ import routerMap from './router.map'
2
+ import { parseRoutes } from '@vue2-client/utils/routerUtil'
3
+
4
+ // 异步路由配置
5
+ const routesConfig = [
6
+ 'login',
7
+ 'submitTicket',
8
+ 'settings',
9
+ 'root',
10
+ {
11
+ router: 'exp404',
12
+ path: '*',
13
+ name: '404'
14
+ },
15
+ {
16
+ router: 'exp403',
17
+ path: '/403',
18
+ name: '403'
19
+ }
20
+ ]
21
+
22
+ const options = {
23
+ mode: 'history',
24
+ routes: parseRoutes(routesConfig, routerMap),
25
+ config: routesConfig
26
+ }
27
+
28
+ export default options
@@ -1,68 +1,68 @@
1
- const { homePage } = require('../../config')
2
- // 视图组件
3
- const view = {
4
- tabs: () => import('@vue2-client/layouts/tabs'),
5
- blank: () => import('@vue2-client/layouts/BlankView'),
6
- page: () => import('@vue2-client/layouts/PageView')
7
- }
8
- // 动态路由对象定义
9
- const routerResource = {}
10
- // --------------------------------------基本视图组件--------------------------------------
11
- // 空白视图
12
- routerResource.blank = view.blank
13
- // 单页面视图
14
- routerResource.singlePage = view.blank
15
-
16
- // --------------------------------------仪表盘--------------------------------------
17
- routerResource.dashboard = view.blank
18
- // 工作台
19
- routerResource.workplace = () => import('@vue2-client/pages/dashboard/workplace')
20
- // --------------------------------------系统配置--------------------------------------
21
- routerResource.system = view.blank
22
- // 报表测试用页面
23
- routerResource.testPage = () => import('@vue2-client/pages/ReportView.vue')
24
- // 字典管理
25
- routerResource.dictionaryManage = () => import(/* webpackChunkName: "dictionary" */ '@vue2-client/pages/system/dictionary')
26
- // 查询配置管理
27
- routerResource.queryParamsManage = () => import(/* webpackChunkName: "queryParams" */ '@vue2-client/pages/system/queryParams')
28
- // 文件管理
29
- routerResource.fileManager = () => import('@vue2-client/pages/system/file')
30
- // 登录日志
31
- routerResource.loginInfor = () => import('@vue2-client/pages/system/monitor/loginInfor')
32
- // 操作日志
33
- routerResource.operLog = () => import('@vue2-client/pages/system/monitor/operLog')
34
- // 系统问题反馈工单
35
- routerResource.submitTicket = () => import(/* webpackChunkName: "submitTicket" */ '@vue2-client/pages/system/ticket')
36
-
37
- // 基础路由组件注册
38
- const routerMap = {
39
- login: {
40
- authority: '*',
41
- path: '/login',
42
- component: () => import('@vue2-client/pages/login')
43
- },
44
- root: {
45
- path: '/',
46
- name: '首页',
47
- redirect: homePage,
48
- component: view.tabs
49
- },
50
- exp403: {
51
- authority: '*',
52
- name: 'exp403',
53
- path: '403',
54
- component: () => import('@vue2-client/pages/exception/403')
55
- },
56
- exp404: {
57
- name: 'exp404',
58
- path: '404',
59
- component: () => import('@vue2-client/pages/exception/404')
60
- },
61
- exp500: {
62
- name: 'exp500',
63
- path: '500',
64
- component: () => import('@vue2-client/pages/exception/500')
65
- }
66
- }
67
- Object.assign(routerMap, routerResource)
68
- export default routerMap
1
+ const { homePage } = require('../../config')
2
+ // 视图组件
3
+ const view = {
4
+ tabs: () => import('@vue2-client/layouts/tabs'),
5
+ blank: () => import('@vue2-client/layouts/BlankView'),
6
+ page: () => import('@vue2-client/layouts/PageView')
7
+ }
8
+ // 动态路由对象定义
9
+ const routerResource = {}
10
+ // --------------------------------------基本视图组件--------------------------------------
11
+ // 空白视图
12
+ routerResource.blank = view.blank
13
+ // 单页面视图
14
+ routerResource.singlePage = view.blank
15
+
16
+ // --------------------------------------仪表盘--------------------------------------
17
+ routerResource.dashboard = view.blank
18
+ // 工作台
19
+ routerResource.workplace = () => import('@vue2-client/pages/dashboard/workplace')
20
+ // --------------------------------------系统配置--------------------------------------
21
+ routerResource.system = view.blank
22
+ // 字典管理
23
+ routerResource.dictionaryManage = () => import('@vue2-client/pages/system/dictionary')
24
+ // 查询配置管理
25
+ routerResource.queryParamsManage = () => import('@vue2-client/pages/system/queryParams')
26
+ // 文件管理
27
+ routerResource.fileManager = () => import('@vue2-client/pages/system/file')
28
+ // 登录日志
29
+ routerResource.loginInfor = () => import('@vue2-client/pages/system/monitor/loginInfor')
30
+ // 操作日志
31
+ routerResource.operLog = () => import('@vue2-client/pages/system/monitor/operLog')
32
+ // 系统问题反馈工单
33
+ routerResource.submitTicket = () => import('@vue2-client/pages/system/ticket')
34
+ // 系统设置
35
+ routerResource.settings = () => import('@vue2-client/pages/system/settings')
36
+
37
+ // 基础路由组件注册
38
+ const routerMap = {
39
+ login: {
40
+ authority: '*',
41
+ path: '/login',
42
+ component: () => import('@vue2-client/pages/login')
43
+ },
44
+ root: {
45
+ path: '/',
46
+ name: '首页',
47
+ redirect: homePage,
48
+ component: view.tabs
49
+ },
50
+ exp403: {
51
+ authority: '*',
52
+ name: 'exp403',
53
+ path: '403',
54
+ component: () => import('@vue2-client/pages/exception/403')
55
+ },
56
+ exp404: {
57
+ name: 'exp404',
58
+ path: '404',
59
+ component: () => import('@vue2-client/pages/exception/404')
60
+ },
61
+ exp500: {
62
+ name: 'exp500',
63
+ path: '500',
64
+ component: () => import('@vue2-client/pages/exception/500')
65
+ }
66
+ }
67
+ Object.assign(routerMap, routerResource)
68
+ export default routerMap