vue2-client 1.2.0 → 1.2.1
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.
- package/README.md +65 -65
- package/babel.config.js +1 -0
- package/docs/notice.md +24 -0
- package/index.js +28 -28
- package/package.json +1 -1
- package/src/App.vue +93 -93
- package/src/base-client/all.js +57 -57
- package/src/base-client/components/common/CreateQuery/CreateQuery.vue +1159 -1159
- package/src/base-client/components/common/CreateQuery/index.md +42 -42
- package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +540 -540
- package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
- package/src/base-client/components/common/CustomColumnsDrawer/index.md +46 -46
- package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +150 -150
- package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
- package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
- package/src/base-client/components/common/XAddForm/XAddForm.vue +323 -323
- package/src/base-client/components/common/XAddForm/index.md +60 -60
- package/src/base-client/components/common/XBadge/index.md +39 -39
- package/src/base-client/components/common/XCard/index.md +43 -43
- package/src/base-client/components/common/XForm/XForm.vue +275 -275
- package/src/base-client/components/common/XForm/XFormItem.vue +217 -217
- package/src/base-client/components/common/XForm/index.md +196 -196
- package/src/base-client/components/common/XFormCol/index.md +35 -35
- package/src/base-client/components/common/XFormTable/XFormTable.vue +405 -405
- package/src/base-client/components/common/XFormTable/index.md +89 -89
- package/src/base-client/components/common/XTable/XTable.vue +262 -262
- package/src/base-client/components/common/XTable/index.md +255 -255
- package/src/base-client/components/common/XTreeOne/XTreeOne.vue +105 -105
- package/src/base-client/components/iot/CustomerDetailsView/CustomerDetailsView.vue +226 -226
- package/src/base-client/components/iot/CustomerDetailsView/index.md +41 -41
- package/src/base-client/components/iot/DataAnalysisUser/DataAnalysisUser.vue +127 -127
- package/src/base-client/components/iot/DataAnalysisViewGD/DataAnalysisViewGD.vue +548 -548
- package/src/base-client/components/iot/DeviceBrandDetailsView/DeviceBrandDetailsView.vue +453 -453
- package/src/base-client/components/iot/DeviceDetailsView/DeviceDetailsView.vue +231 -231
- package/src/base-client/components/iot/DeviceDetailsView/index.md +43 -43
- package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsCount.vue +330 -330
- package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsException.vue +57 -57
- package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsInstruct.vue +122 -122
- package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsInstructOperate.vue +122 -122
- package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsMain.vue +225 -225
- package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsRead.vue +135 -135
- package/src/base-client/components/iot/DeviceTypeDetailsView/DeviceTypeDetailsView.vue +277 -277
- package/src/base-client/components/iot/InstructDetailsView/InstructDetailsView.vue +472 -472
- package/src/base-client/components/iot/InstructDetailsView/index.md +45 -45
- package/src/base-client/components/iot/LogDetailsView/LogDetailsView.vue +380 -380
- package/src/base-client/components/iot/LogDetailsView/index.md +43 -43
- package/src/base-client/components/iot/MeterDetailsView/MeterDetailsView.vue +360 -360
- package/src/base-client/components/iot/MeterDetailsView/index.md +43 -43
- package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsCount.vue +335 -335
- package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsException.vue +185 -185
- package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsHandPlan.vue +292 -292
- package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsInstruct.vue +237 -237
- package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsMain.vue +257 -257
- package/src/base-client/components/iot/MeterDetailsView/part/MeterDetailsSellGas.vue +190 -190
- package/src/base-client/components/iot/WebmeterAnalysisView/WebmeterAnalysisView.vue +723 -723
- package/src/base-client/components/iot/WebmeterAnalysisView/index.md +48 -48
- package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
- package/src/base-client/components/system/DictionaryDetailsView/index.md +41 -41
- package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +248 -248
- package/src/base-client/components/ticket/EmployeeDetailsView/EmployeeDetailsView.vue +406 -406
- package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +486 -486
- package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +184 -184
- package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +303 -303
- package/src/base-client/plugins/AppData.js +69 -69
- package/src/base-client/plugins/GetLoginInfoService.js +221 -221
- package/src/base-client/plugins/index.js +21 -21
- package/src/bootstrap.js +27 -27
- package/src/components/Ellipsis/Ellipsis.vue +64 -64
- package/src/components/Ellipsis/index.md +38 -38
- package/src/components/NumberInfo/index.md +43 -43
- package/src/components/STable/README.md +341 -341
- package/src/components/Trend/index.md +45 -45
- package/src/components/cache/AKeepAlive.js +172 -172
- package/src/components/checkbox/index.js +7 -7
- package/src/components/index.js +36 -36
- package/src/components/menu/menu.js +273 -273
- package/src/components/setting/Setting.vue +237 -237
- package/src/components/table/advance/AdvanceTable.vue +275 -275
- package/src/components/transition/PageToggleTransition.vue +97 -97
- package/src/layouts/CommonLayout.vue +42 -42
- package/src/layouts/PageLayout.vue +151 -151
- package/src/layouts/SinglePageView.vue +74 -74
- package/src/layouts/header/AdminHeader.vue +109 -109
- package/src/layouts/header/HeaderAvatar.vue +60 -60
- package/src/layouts/header/HeaderNotice.vue +97 -97
- package/src/layouts/tabs/TabsHead.vue +190 -190
- package/src/layouts/tabs/TabsView.vue +355 -355
- package/src/main.js +20 -20
- package/src/mock/goods/index.js +108 -108
- package/src/mock/index.js +12 -12
- package/src/mock/project/index.js +17 -17
- package/src/mock/user/current.js +13 -13
- package/src/mock/user/login.js +39 -39
- package/src/mock/workplace/index.js +15 -15
- package/src/pages/exception/403.vue +25 -25
- package/src/pages/exception/404.vue +25 -25
- package/src/pages/exception/500.vue +25 -25
- package/src/pages/login/Login.vue +194 -194
- package/src/pages/report/ReportTableHome.vue +28 -28
- package/src/pages/resourceManage/resourceManageMain.vue +55 -55
- package/src/pages/system/applyInstallView/Core.vue +570 -570
- package/src/pages/system/applyInstallView/index.vue +34 -34
- package/src/pages/system/dictionary/index.vue +41 -41
- package/src/pages/system/queryParams/index.vue +41 -41
- package/src/router/async/config.async.js +25 -25
- package/src/router/async/router.map.js +59 -59
- package/src/router/guards.js +104 -104
- package/src/router/index.js +27 -27
- package/src/services/api/common.js +39 -39
- package/src/services/api/restTools.js +23 -23
- package/src/services/dataSource.js +12 -12
- package/src/services/user.js +34 -34
- package/src/store/modules/setting.js +114 -114
- package/src/utils/i18n.js +80 -80
- package/src/utils/indexedDB.js +146 -146
- package/src/utils/request.js +197 -197
- package/src/utils/routerUtil.js +15 -2
- package/tests/unit/ReportTable.spec.js +15 -15
- package/vue.config.js +153 -153
- package/webpack.config.js +12 -12
package/src/utils/indexedDB.js
CHANGED
|
@@ -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
|
+
}
|
package/src/utils/request.js
CHANGED
|
@@ -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
|
+
}
|