vue2-client 1.2.0 → 1.2.3

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 (134) hide show
  1. package/README.md +65 -65
  2. package/babel.config.js +1 -0
  3. package/docs/notice.md +22 -0
  4. package/index.js +28 -28
  5. package/package.json +1 -1
  6. package/src/App.vue +93 -93
  7. package/src/assets/img/SunClientDownload.png +0 -0
  8. package/src/assets/img/SunClientManual/1.png +0 -0
  9. package/src/assets/img/SunClientManual/2.png +0 -0
  10. package/src/assets/img/SunClientManual/3.png +0 -0
  11. package/src/assets/img/SunClientManual/4.png +0 -0
  12. package/src/assets/img/ToDeskDownload.png +0 -0
  13. package/src/assets/img/ToDeskManual/1.png +0 -0
  14. package/src/assets/img/ToDeskManual/2.png +0 -0
  15. package/src/assets/img/ToDeskManual/3.png +0 -0
  16. package/src/assets/img/ToDeskManual/4.png +0 -0
  17. package/src/assets/sound/newNote.mp3 +0 -0
  18. package/src/base-client/all.js +57 -57
  19. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +1157 -1159
  20. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  21. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +540 -540
  22. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  23. package/src/base-client/components/common/CustomColumnsDrawer/index.md +46 -46
  24. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +150 -150
  25. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  26. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  27. package/src/base-client/components/common/XAddForm/XAddForm.vue +323 -323
  28. package/src/base-client/components/common/XAddForm/index.md +60 -60
  29. package/src/base-client/components/common/XBadge/index.md +39 -39
  30. package/src/base-client/components/common/XCard/index.md +43 -43
  31. package/src/base-client/components/common/XForm/XForm.vue +275 -275
  32. package/src/base-client/components/common/XForm/XFormItem.vue +217 -217
  33. package/src/base-client/components/common/XForm/index.md +196 -196
  34. package/src/base-client/components/common/XFormCol/index.md +35 -35
  35. package/src/base-client/components/common/XFormTable/XFormTable.vue +407 -405
  36. package/src/base-client/components/common/XFormTable/index.md +89 -89
  37. package/src/base-client/components/common/XTable/XTable.vue +262 -262
  38. package/src/base-client/components/common/XTable/index.md +255 -255
  39. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +105 -105
  40. package/src/base-client/components/iot/CustomerDetailsView/CustomerDetailsView.vue +226 -226
  41. package/src/base-client/components/iot/CustomerDetailsView/index.md +41 -41
  42. package/src/base-client/components/iot/DataAnalysisUser/DataAnalysisUser.vue +127 -127
  43. package/src/base-client/components/iot/DataAnalysisView/DataAnalysisView.vue +244 -250
  44. package/src/base-client/components/iot/DataAnalysisViewGD/DataAnalysisViewGD.vue +548 -548
  45. package/src/base-client/components/iot/DeviceBrandDetailsView/DeviceBrandDetailsView.vue +453 -453
  46. package/src/base-client/components/iot/DeviceDetailsView/DeviceDetailsView.vue +231 -231
  47. package/src/base-client/components/iot/DeviceDetailsView/index.md +43 -43
  48. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsCount.vue +330 -330
  49. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsException.vue +57 -57
  50. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsInstruct.vue +122 -122
  51. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsInstructOperate.vue +122 -122
  52. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsMain.vue +225 -225
  53. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsRead.vue +135 -135
  54. package/src/base-client/components/iot/DeviceTypeDetailsView/DeviceTypeDetailsView.vue +277 -277
  55. package/src/base-client/components/iot/InstructDetailsView/InstructDetailsView.vue +472 -472
  56. package/src/base-client/components/iot/InstructDetailsView/index.md +45 -45
  57. package/src/base-client/components/iot/LogDetailsView/LogDetailsView.vue +380 -380
  58. package/src/base-client/components/iot/LogDetailsView/index.md +43 -43
  59. package/src/base-client/components/iot/MeterDetailsView/MeterDetailsView.vue +360 -360
  60. package/src/base-client/components/iot/MeterDetailsView/index.md +43 -43
  61. package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsCount.vue +335 -335
  62. package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsException.vue +185 -185
  63. package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsHandPlan.vue +292 -292
  64. package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsInstruct.vue +237 -237
  65. package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsMain.vue +257 -257
  66. package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsSellGas.vue +190 -190
  67. package/src/base-client/components/iot/WebmeterAnalysisView/WebmeterAnalysisView.vue +723 -723
  68. package/src/base-client/components/iot/WebmeterAnalysisView/index.md +48 -48
  69. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  70. package/src/base-client/components/system/DictionaryDetailsView/index.md +41 -41
  71. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +248 -248
  72. package/src/base-client/components/ticket/EmployeeDetailsView/EmployeeDetailsView.vue +371 -406
  73. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +838 -486
  74. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +261 -184
  75. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +528 -303
  76. package/src/base-client/plugins/AppData.js +69 -69
  77. package/src/base-client/plugins/GetLoginInfoService.js +221 -221
  78. package/src/base-client/plugins/index.js +21 -21
  79. package/src/bootstrap.js +27 -27
  80. package/src/components/Ellipsis/Ellipsis.vue +64 -64
  81. package/src/components/Ellipsis/index.md +38 -38
  82. package/src/components/NumberInfo/index.md +43 -43
  83. package/src/components/STable/README.md +341 -341
  84. package/src/components/Trend/index.md +45 -45
  85. package/src/components/cache/AKeepAlive.js +172 -172
  86. package/src/components/checkbox/index.js +7 -7
  87. package/src/components/index.js +36 -36
  88. package/src/components/menu/menu.js +273 -273
  89. package/src/components/setting/Setting.vue +237 -237
  90. package/src/components/table/advance/AdvanceTable.vue +275 -275
  91. package/src/components/transition/PageToggleTransition.vue +97 -97
  92. package/src/layouts/CommonLayout.vue +42 -42
  93. package/src/layouts/PageLayout.vue +151 -151
  94. package/src/layouts/SinglePageView.vue +74 -74
  95. package/src/layouts/header/AdminHeader.vue +109 -109
  96. package/src/layouts/header/HeaderAvatar.vue +60 -60
  97. package/src/layouts/header/HeaderNotice.vue +97 -97
  98. package/src/layouts/tabs/TabsHead.vue +190 -190
  99. package/src/layouts/tabs/TabsView.vue +355 -355
  100. package/src/main.js +20 -20
  101. package/src/mock/goods/index.js +108 -108
  102. package/src/mock/index.js +12 -12
  103. package/src/mock/project/index.js +17 -17
  104. package/src/mock/user/current.js +13 -13
  105. package/src/mock/user/login.js +39 -39
  106. package/src/mock/workplace/index.js +15 -15
  107. package/src/pages/exception/403.vue +25 -25
  108. package/src/pages/exception/404.vue +25 -25
  109. package/src/pages/exception/500.vue +25 -25
  110. package/src/pages/login/Login.vue +194 -194
  111. package/src/pages/report/ReportTableHome.vue +28 -28
  112. package/src/pages/resourceManage/resourceManageMain.vue +55 -55
  113. package/src/pages/system/applyInstallView/Core.vue +570 -570
  114. package/src/pages/system/applyInstallView/index.vue +34 -34
  115. package/src/pages/system/dictionary/index.vue +41 -41
  116. package/src/pages/system/queryParams/index.vue +41 -41
  117. package/src/router/async/config.async.js +25 -25
  118. package/src/router/async/router.map.js +59 -59
  119. package/src/router/guards.js +104 -104
  120. package/src/router/index.js +27 -27
  121. package/src/services/api/EmployeeDetailsViewApi.js +3 -1
  122. package/src/services/api/TicketDetailsViewApi.js +9 -1
  123. package/src/services/api/common.js +37 -39
  124. package/src/services/api/restTools.js +23 -23
  125. package/src/services/dataSource.js +12 -12
  126. package/src/services/user.js +34 -34
  127. package/src/store/modules/setting.js +114 -114
  128. package/src/utils/i18n.js +80 -80
  129. package/src/utils/indexedDB.js +146 -146
  130. package/src/utils/request.js +197 -197
  131. package/src/utils/routerUtil.js +15 -2
  132. package/tests/unit/ReportTable.spec.js +15 -15
  133. package/vue.config.js +153 -153
  134. package/webpack.config.js +12 -12
@@ -1,146 +1,146 @@
1
- // indexDB 存储
2
- import { post } from '@vue2-client/services/api/restTools'
3
-
4
- export const indexedDB = {
5
- db: undefined,
6
- indexedDB: window.indexedDB || window.webkitindexedDB,
7
- IDBKeyRange: window.IDBKeyRange || window.webkitIDBKeyRange, // 键范围
8
- openDB: function (callback) {
9
- // 建立或打开数据库,建立对象存储空间(ObjectStore)
10
- const self = this
11
- if (self.db) {
12
- callback(self.db)
13
- } else {
14
- const version = 1
15
- const request = self.indexedDB.open('view', version)
16
-
17
- request.onerror = function (e) {
18
- console.error('打开数据库失败:' + e.currentTarget.error.message)
19
- }
20
- request.onsuccess = function (e) {
21
- self.db = e.target.result
22
- callback(self.db)
23
- }
24
- request.onupgradeneeded = function (e) {
25
- const db = e.target.result
26
- if (!db.objectStoreNames.contains('metaCache')) {
27
- // 没有该对象空间时创建该对象空间
28
- db.createObjectStore('metaCache', {
29
- keyPath: 'key'
30
- })
31
- }
32
- }
33
- }
34
- },
35
- deleteDB: function (dbname) {
36
- // 删除数据库
37
- const self = this
38
- self.indexedDB.deleteDatabase(dbname)
39
- console.log(dbname + '数据库已删除')
40
- },
41
- closeDB: function () {
42
- const self = this
43
- if (!self.db) {
44
- self.db.close()
45
- }
46
- console.log('数据库已关闭')
47
- },
48
- add: function (key, data) {
49
- const self = this
50
- self.openDB((res) => {
51
- const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').add({
52
- key: key,
53
- data: data
54
- })
55
- request.onerror = function () {
56
- self.update(data)
57
- }
58
- request.onsuccess = function () {
59
- console.log('数据已存入到数据库')
60
- }
61
- })
62
- },
63
- update: function (key, data) {
64
- const self = this
65
- self.openDB((res) => {
66
- const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').put({
67
- key: key,
68
- data: data
69
- })
70
- request.onerror = function () {
71
- console.error('数据更新失败')
72
- }
73
- request.onsuccess = function () {
74
- console.log('数据已更新到数据库')
75
- }
76
- })
77
- },
78
- get: function (key, callback) {
79
- const self = this
80
- self.openDB((res) => {
81
- // 根据存储空间的键找到对应数据
82
- const store = res.transaction('metaCache', 'readwrite').objectStore('metaCache')
83
- const request = store.get(key)
84
- request.onerror = function () {
85
- console.log('读取数据失败,键:' + key)
86
- }
87
- request.onsuccess = function (e) {
88
- const result = e.target.result
89
- if (typeof (callback) === 'function') {
90
- callback(result.data)
91
- }
92
- }
93
- })
94
- },
95
- getByWeb: function (key, url, params, callback) {
96
- const self = this
97
- self.openDB((res) => {
98
- // 根据存储空间的键找到对应数据
99
- const store = res.transaction('metaCache', 'readwrite').objectStore('metaCache')
100
- const request = store.get(key)
101
- request.onerror = function () {
102
- console.log('读取数据失败,键:' + key)
103
- }
104
- request.onsuccess = function (e) {
105
- const result = e.target.result
106
- if (!result && url) {
107
- post(url, params).then((res) => {
108
- self.add(key, res)
109
- callback(res)
110
- })
111
- } else {
112
- callback(result.data)
113
- }
114
- }
115
- })
116
- },
117
- delete: function (key) {
118
- const self = this
119
- self.openDB((res) => {
120
- // 删除某一条记录
121
- const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').delete(key)
122
-
123
- request.onerror = function () {
124
- console.error('数据删除失败')
125
- }
126
- request.onsuccess = function (event) {
127
- console.log('已删除存储空间' + 'metaCache' + '中' + key + '记录')
128
- }
129
- })
130
- },
131
- clear: function (callback) {
132
- const self = this
133
- self.openDB((res) => {
134
- // 删除存储空间全部记录
135
- const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').clear()
136
-
137
- request.onerror = function () {
138
- console.error('数据删除失败')
139
- }
140
- request.onsuccess = function (event) {
141
- console.log('已删除存储空间' + 'metaCache' + '中所有记录')
142
- callback()
143
- }
144
- })
145
- }
146
- }
1
+ // indexDB 存储
2
+ import { post } from '@vue2-client/services/api/restTools'
3
+
4
+ export const indexedDB = {
5
+ db: undefined,
6
+ indexedDB: window.indexedDB || window.webkitindexedDB,
7
+ IDBKeyRange: window.IDBKeyRange || window.webkitIDBKeyRange, // 键范围
8
+ openDB: function (callback) {
9
+ // 建立或打开数据库,建立对象存储空间(ObjectStore)
10
+ const self = this
11
+ if (self.db) {
12
+ callback(self.db)
13
+ } else {
14
+ const version = 1
15
+ const request = self.indexedDB.open('view', version)
16
+
17
+ request.onerror = function (e) {
18
+ console.error('打开数据库失败:' + e.currentTarget.error.message)
19
+ }
20
+ request.onsuccess = function (e) {
21
+ self.db = e.target.result
22
+ callback(self.db)
23
+ }
24
+ request.onupgradeneeded = function (e) {
25
+ const db = e.target.result
26
+ if (!db.objectStoreNames.contains('metaCache')) {
27
+ // 没有该对象空间时创建该对象空间
28
+ db.createObjectStore('metaCache', {
29
+ keyPath: 'key'
30
+ })
31
+ }
32
+ }
33
+ }
34
+ },
35
+ deleteDB: function (dbname) {
36
+ // 删除数据库
37
+ const self = this
38
+ self.indexedDB.deleteDatabase(dbname)
39
+ console.log(dbname + '数据库已删除')
40
+ },
41
+ closeDB: function () {
42
+ const self = this
43
+ if (!self.db) {
44
+ self.db.close()
45
+ }
46
+ console.log('数据库已关闭')
47
+ },
48
+ add: function (key, data) {
49
+ const self = this
50
+ self.openDB((res) => {
51
+ const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').add({
52
+ key: key,
53
+ data: data
54
+ })
55
+ request.onerror = function () {
56
+ self.update(data)
57
+ }
58
+ request.onsuccess = function () {
59
+ console.log('数据已存入到数据库')
60
+ }
61
+ })
62
+ },
63
+ update: function (key, data) {
64
+ const self = this
65
+ self.openDB((res) => {
66
+ const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').put({
67
+ key: key,
68
+ data: data
69
+ })
70
+ request.onerror = function () {
71
+ console.error('数据更新失败')
72
+ }
73
+ request.onsuccess = function () {
74
+ console.log('数据已更新到数据库')
75
+ }
76
+ })
77
+ },
78
+ get: function (key, callback) {
79
+ const self = this
80
+ self.openDB((res) => {
81
+ // 根据存储空间的键找到对应数据
82
+ const store = res.transaction('metaCache', 'readwrite').objectStore('metaCache')
83
+ const request = store.get(key)
84
+ request.onerror = function () {
85
+ console.log('读取数据失败,键:' + key)
86
+ }
87
+ request.onsuccess = function (e) {
88
+ const result = e.target.result
89
+ if (typeof (callback) === 'function') {
90
+ callback(result.data)
91
+ }
92
+ }
93
+ })
94
+ },
95
+ getByWeb: function (key, url, params, callback) {
96
+ const self = this
97
+ self.openDB((res) => {
98
+ // 根据存储空间的键找到对应数据
99
+ const store = res.transaction('metaCache', 'readwrite').objectStore('metaCache')
100
+ const request = store.get(key)
101
+ request.onerror = function () {
102
+ console.log('读取数据失败,键:' + key)
103
+ }
104
+ request.onsuccess = function (e) {
105
+ const result = e.target.result
106
+ if (!result && url) {
107
+ post(url, params).then((res) => {
108
+ self.add(key, res)
109
+ callback(res)
110
+ })
111
+ } else {
112
+ callback(result.data)
113
+ }
114
+ }
115
+ })
116
+ },
117
+ delete: function (key) {
118
+ const self = this
119
+ self.openDB((res) => {
120
+ // 删除某一条记录
121
+ const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').delete(key)
122
+
123
+ request.onerror = function () {
124
+ console.error('数据删除失败')
125
+ }
126
+ request.onsuccess = function (event) {
127
+ console.log('已删除存储空间' + 'metaCache' + '中' + key + '记录')
128
+ }
129
+ })
130
+ },
131
+ clear: function (callback) {
132
+ const self = this
133
+ self.openDB((res) => {
134
+ // 删除存储空间全部记录
135
+ const request = res.transaction('metaCache', 'readwrite').objectStore('metaCache').clear()
136
+
137
+ request.onerror = function () {
138
+ console.error('数据删除失败')
139
+ }
140
+ request.onsuccess = function (event) {
141
+ console.log('已删除存储空间' + 'metaCache' + '中所有记录')
142
+ callback()
143
+ }
144
+ })
145
+ }
146
+ }
@@ -1,197 +1,197 @@
1
- import axios from 'axios'
2
- import Cookie from 'js-cookie'
3
- import Vue from 'vue'
4
- import { ACCESS_TOKEN } from '@vue2-client/store/mutation-types'
5
- import notification from 'ant-design-vue/es/notification'
6
-
7
- // 跨域认证信息 header 名
8
- const xsrfHeaderName = 'Authorization'
9
-
10
- axios.defaults.timeout = 5000
11
- axios.defaults.withCredentials = true
12
- axios.defaults.xsrfHeaderName = xsrfHeaderName
13
- axios.defaults.xsrfCookieName = xsrfHeaderName
14
-
15
- // 认证类型
16
- const AUTH_TYPE = {
17
- BEARER: 'Bearer',
18
- BASIC: 'basic',
19
- AUTH1: 'auth1',
20
- AUTH2: 'auth2'
21
- }
22
-
23
- // http method
24
- const METHOD = {
25
- GET: 'get',
26
- POST: 'post'
27
- }
28
-
29
- /**
30
- * axios请求
31
- * @param url 请求地址
32
- * @param method {METHOD} http method
33
- * @param params 请求参数
34
- * @returns {Promise<AxiosResponse<T>>}
35
- */
36
- async function request (url, method, params, config) {
37
- switch (method) {
38
- case METHOD.GET:
39
- return axios.get(url, { params, ...config })
40
- case METHOD.POST:
41
- return axios.post(url, params, config)
42
- default:
43
- return axios.get(url, { params, ...config })
44
- }
45
- }
46
-
47
- /**
48
- * 设置认证信息
49
- * @param auth {Object}
50
- * @param authType {AUTH_TYPE} 认证类型,默认:{AUTH_TYPE.BEARER}
51
- */
52
- function setAuthorization (auth, authType = AUTH_TYPE.BEARER) {
53
- switch (authType) {
54
- case AUTH_TYPE.BEARER:
55
- Cookie.set(xsrfHeaderName, 'Bearer ' + auth.token, { expires: auth.expireAt })
56
- break
57
- case AUTH_TYPE.BASIC:
58
- case AUTH_TYPE.AUTH1:
59
- case AUTH_TYPE.AUTH2:
60
- default:
61
- break
62
- }
63
- }
64
-
65
- /**
66
- * 移出认证信息
67
- * @param authType {AUTH_TYPE} 认证类型
68
- */
69
- function removeAuthorization (authType = AUTH_TYPE.BEARER) {
70
- switch (authType) {
71
- case AUTH_TYPE.BEARER:
72
- Cookie.remove(xsrfHeaderName)
73
- break
74
- case AUTH_TYPE.BASIC:
75
- case AUTH_TYPE.AUTH1:
76
- case AUTH_TYPE.AUTH2:
77
- default:
78
- break
79
- }
80
- }
81
-
82
- /**
83
- * 检查认证信息
84
- * @param authType
85
- * @returns {boolean}
86
- */
87
- function checkAuthorization (authType = AUTH_TYPE.BEARER) {
88
- switch (authType) {
89
- case AUTH_TYPE.BEARER:
90
- if (Cookie.get(xsrfHeaderName)) {
91
- return true
92
- }
93
- break
94
- case AUTH_TYPE.BASIC:
95
- case AUTH_TYPE.AUTH1:
96
- case AUTH_TYPE.AUTH2:
97
- default:
98
- break
99
- }
100
- return false
101
- }
102
-
103
- /**
104
- * 加载 axios 拦截器
105
- * @param interceptors
106
- * @param options
107
- */
108
- function loadInterceptors () {
109
- // 加载请求拦截器
110
- axios.interceptors.request.use(config => {
111
- const token = localStorage.getItem(ACCESS_TOKEN)
112
- // 如果 token 存在
113
- // 让每个请求携带自定义 token 请根据实际情况自行修改
114
- if (token) {
115
- config.headers['Access-Token'] = token
116
- }
117
- if (!config.headers['Content-Type']) {
118
- config.headers['Content-Type'] = 'application/json;charset=UTF-8'
119
- }
120
- return config
121
- }, errorHandler)
122
- // 加载响应拦截器
123
- axios.interceptors.response.use((response) => {
124
- return response.data
125
- }, errorHandler)
126
- }
127
-
128
- // 异常拦截处理器
129
- const errorHandler = (error) => {
130
- if (error.response) {
131
- const data = error.response.data
132
- // 从 localstorage 获取 token
133
- const token = localStorage.getItem(ACCESS_TOKEN)
134
- if (error.response.status === 403) {
135
- notification.error({
136
- message: '禁止访问',
137
- description: data
138
- })
139
- } else if (error.response.status === 401 && !(data.result && data.result.isLogin)) {
140
- notification.error({
141
- message: '鉴权失败',
142
- description: data
143
- })
144
- if (token) {
145
- Vue.$store.dispatch('Logout').then(() => {
146
- setTimeout(() => {
147
- window.location.reload()
148
- }, 1500)
149
- })
150
- }
151
- } else if (error.response.status === 500) {
152
- notification.error({
153
- message: '系统异常',
154
- description: data
155
- })
156
- } else {
157
- notification.error({
158
- message: '数据异常',
159
- description: data
160
- })
161
- }
162
- }
163
- return Promise.reject(error)
164
- }
165
-
166
- /**
167
- * 解析 url 中的参数
168
- * @param url
169
- * @returns {Object}
170
- */
171
- function parseUrlParams (url) {
172
- const params = {}
173
- if (!url || url === '' || typeof url !== 'string') {
174
- return params
175
- }
176
- const paramsStr = url.split('?')[1]
177
- if (!paramsStr) {
178
- return params
179
- }
180
- const paramsArr = paramsStr.replace(/&|=/g, ' ').split(' ')
181
- for (let i = 0; i < paramsArr.length / 2; i++) {
182
- const value = paramsArr[i * 2 + 1]
183
- params[paramsArr[i * 2]] = value === 'true' ? true : (value === 'false' ? false : value)
184
- }
185
- return params
186
- }
187
-
188
- export {
189
- METHOD,
190
- AUTH_TYPE,
191
- request,
192
- setAuthorization,
193
- removeAuthorization,
194
- checkAuthorization,
195
- loadInterceptors,
196
- parseUrlParams
197
- }
1
+ import axios from 'axios'
2
+ import Cookie from 'js-cookie'
3
+ import Vue from 'vue'
4
+ import { ACCESS_TOKEN } from '@vue2-client/store/mutation-types'
5
+ import notification from 'ant-design-vue/es/notification'
6
+
7
+ // 跨域认证信息 header 名
8
+ const xsrfHeaderName = 'Authorization'
9
+
10
+ axios.defaults.timeout = 5000
11
+ axios.defaults.withCredentials = true
12
+ axios.defaults.xsrfHeaderName = xsrfHeaderName
13
+ axios.defaults.xsrfCookieName = xsrfHeaderName
14
+
15
+ // 认证类型
16
+ const AUTH_TYPE = {
17
+ BEARER: 'Bearer',
18
+ BASIC: 'basic',
19
+ AUTH1: 'auth1',
20
+ AUTH2: 'auth2'
21
+ }
22
+
23
+ // http method
24
+ const METHOD = {
25
+ GET: 'get',
26
+ POST: 'post'
27
+ }
28
+
29
+ /**
30
+ * axios请求
31
+ * @param url 请求地址
32
+ * @param method {METHOD} http method
33
+ * @param params 请求参数
34
+ * @returns {Promise<AxiosResponse<T>>}
35
+ */
36
+ async function request (url, method, params, config) {
37
+ switch (method) {
38
+ case METHOD.GET:
39
+ return axios.get(url, { params, ...config })
40
+ case METHOD.POST:
41
+ return axios.post(url, params, config)
42
+ default:
43
+ return axios.get(url, { params, ...config })
44
+ }
45
+ }
46
+
47
+ /**
48
+ * 设置认证信息
49
+ * @param auth {Object}
50
+ * @param authType {AUTH_TYPE} 认证类型,默认:{AUTH_TYPE.BEARER}
51
+ */
52
+ function setAuthorization (auth, authType = AUTH_TYPE.BEARER) {
53
+ switch (authType) {
54
+ case AUTH_TYPE.BEARER:
55
+ Cookie.set(xsrfHeaderName, 'Bearer ' + auth.token, { expires: auth.expireAt })
56
+ break
57
+ case AUTH_TYPE.BASIC:
58
+ case AUTH_TYPE.AUTH1:
59
+ case AUTH_TYPE.AUTH2:
60
+ default:
61
+ break
62
+ }
63
+ }
64
+
65
+ /**
66
+ * 移出认证信息
67
+ * @param authType {AUTH_TYPE} 认证类型
68
+ */
69
+ function removeAuthorization (authType = AUTH_TYPE.BEARER) {
70
+ switch (authType) {
71
+ case AUTH_TYPE.BEARER:
72
+ Cookie.remove(xsrfHeaderName)
73
+ break
74
+ case AUTH_TYPE.BASIC:
75
+ case AUTH_TYPE.AUTH1:
76
+ case AUTH_TYPE.AUTH2:
77
+ default:
78
+ break
79
+ }
80
+ }
81
+
82
+ /**
83
+ * 检查认证信息
84
+ * @param authType
85
+ * @returns {boolean}
86
+ */
87
+ function checkAuthorization (authType = AUTH_TYPE.BEARER) {
88
+ switch (authType) {
89
+ case AUTH_TYPE.BEARER:
90
+ if (Cookie.get(xsrfHeaderName)) {
91
+ return true
92
+ }
93
+ break
94
+ case AUTH_TYPE.BASIC:
95
+ case AUTH_TYPE.AUTH1:
96
+ case AUTH_TYPE.AUTH2:
97
+ default:
98
+ break
99
+ }
100
+ return false
101
+ }
102
+
103
+ /**
104
+ * 加载 axios 拦截器
105
+ * @param interceptors
106
+ * @param options
107
+ */
108
+ function loadInterceptors () {
109
+ // 加载请求拦截器
110
+ axios.interceptors.request.use(config => {
111
+ const token = localStorage.getItem(ACCESS_TOKEN)
112
+ // 如果 token 存在
113
+ // 让每个请求携带自定义 token 请根据实际情况自行修改
114
+ if (token) {
115
+ config.headers['Access-Token'] = token
116
+ }
117
+ if (!config.headers['Content-Type']) {
118
+ config.headers['Content-Type'] = 'application/json;charset=UTF-8'
119
+ }
120
+ return config
121
+ }, errorHandler)
122
+ // 加载响应拦截器
123
+ axios.interceptors.response.use((response) => {
124
+ return response.data
125
+ }, errorHandler)
126
+ }
127
+
128
+ // 异常拦截处理器
129
+ const errorHandler = (error) => {
130
+ if (error.response) {
131
+ const data = error.response.data
132
+ // 从 localstorage 获取 token
133
+ const token = localStorage.getItem(ACCESS_TOKEN)
134
+ if (error.response.status === 403) {
135
+ notification.error({
136
+ message: '禁止访问',
137
+ description: data
138
+ })
139
+ } else if (error.response.status === 401 && !(data.result && data.result.isLogin)) {
140
+ notification.error({
141
+ message: '鉴权失败',
142
+ description: data
143
+ })
144
+ if (token) {
145
+ Vue.$store.dispatch('Logout').then(() => {
146
+ setTimeout(() => {
147
+ window.location.reload()
148
+ }, 1500)
149
+ })
150
+ }
151
+ } else if (error.response.status === 500) {
152
+ notification.error({
153
+ message: '系统异常',
154
+ description: data
155
+ })
156
+ } else {
157
+ notification.error({
158
+ message: '数据异常',
159
+ description: data
160
+ })
161
+ }
162
+ }
163
+ return Promise.reject(error)
164
+ }
165
+
166
+ /**
167
+ * 解析 url 中的参数
168
+ * @param url
169
+ * @returns {Object}
170
+ */
171
+ function parseUrlParams (url) {
172
+ const params = {}
173
+ if (!url || url === '' || typeof url !== 'string') {
174
+ return params
175
+ }
176
+ const paramsStr = url.split('?')[1]
177
+ if (!paramsStr) {
178
+ return params
179
+ }
180
+ const paramsArr = paramsStr.replace(/&|=/g, ' ').split(' ')
181
+ for (let i = 0; i < paramsArr.length / 2; i++) {
182
+ const value = paramsArr[i * 2 + 1]
183
+ params[paramsArr[i * 2]] = value === 'true' ? true : (value === 'false' ? false : value)
184
+ }
185
+ return params
186
+ }
187
+
188
+ export {
189
+ METHOD,
190
+ AUTH_TYPE,
191
+ request,
192
+ setAuthorization,
193
+ removeAuthorization,
194
+ checkAuthorization,
195
+ loadInterceptors,
196
+ parseUrlParams
197
+ }