@utogether/udp-core 1.0.1-beta.10 → 1.0.1-beta.12
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/dist/{403-Ctxjn4q8.js → 403-D7L5zm05.js} +1 -1
- package/dist/{404-W5yzyiZ9.js → 404-BQKzkK5W.js} +1 -1
- package/dist/{500-DXuGEOm4.js → 500-BM6k8XR5.js} +1 -1
- package/dist/{AuthorityInfo-C2tflCt8.js → AuthorityInfo-Dc-7W4L_.js} +1 -1
- package/dist/{AuthorityInfo.vue_vue_type_style_index_0_lang-SVgy3HX7.js → AuthorityInfo.vue_vue_type_style_index_0_lang-CKvlh3lm.js} +1 -1
- package/dist/{Company-PLez5GoH.js → Company-BgwMUr-I.js} +3 -3
- package/dist/{CompanyPanel-CIGaQooL.js → CompanyPanel-CDfVCPKC.js} +1 -1
- package/dist/{Department-B9wLsXFm.js → Department-CFvEB4Ys.js} +3 -3
- package/dist/{DepartmentPanel-DSM4lTaz.js → DepartmentPanel-11Ytcj2u.js} +1 -1
- package/dist/{DesignPanel-B6a9wW_A.js → DesignPanel-CP8z6teZ.js} +1 -1
- package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-DtHfoDQk.js → DesignPanel.vue_vue_type_style_index_0_lang-Cp-WR8yE.js} +2 -2
- package/dist/{DictView-DhFbQxdJ.js → DictView-13NoDgPW.js} +1 -1
- package/dist/InvOrganization-DOD4QdEX.js +72 -0
- package/dist/{Org-DxBkYabD.js → Org-cezJs-6P.js} +1 -1
- package/dist/{Preview-BFtRpBxw.js → Preview-DzOKwnp8.js} +1 -1
- package/dist/{ReportDefine-BIa2QryC.js → ReportDefine-DWJq2q0f.js} +1 -1
- package/dist/{ReportDesign-CnyjI-WD.js → ReportDesign-f_ed8u_q.js} +2 -2
- package/dist/{ReportQuery-BiK7yEhV.js → ReportQuery-D58gv_yZ.js} +1 -1
- package/dist/{ReportQueryFrom-C2rqdFTm.js → ReportQueryFrom-R0R6EbYv.js} +1 -1
- package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-Ba9HLnXQ.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-CIFpgUAH.js} +1 -1
- package/dist/{ReportTemplate-DdkLscP3.js → ReportTemplate-BTknctTT.js} +1 -1
- package/dist/{Role-BrsxgK8D.js → Role-QTDJ16h8.js} +3 -3
- package/dist/{RoleAssign-DiqwJqDa.js → RoleAssign-7aZ3ufp5.js} +3 -3
- package/dist/{RolePanel-Dqx5dI3f.js → RolePanel-CSe-UoR5.js} +1 -1
- package/dist/{RolePanel-BDusGyo7.js → RolePanel-XXwmaAgy.js} +1 -1
- package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-2Z1q_5uW.js → RolePanel.vue_vue_type_script_setup_true_lang-BsNhkvFo.js} +1 -1
- package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-B5lUnaMI.js → RolePanel.vue_vue_type_script_setup_true_lang-kConrKpo.js} +3 -3
- package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-vSP23fEq.js → ScrollPanel.vue_vue_type_style_index_0_lang-DtaqM_iA.js} +1 -1
- package/dist/{Staff-Cwi9LQiZ.js → Staff-BsREgfrQ.js} +3 -3
- package/dist/{StaffInfo-XjVtyaMv.js → StaffInfo-CQtVXfvS.js} +1 -1
- package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-wSrAuyet.js → StaffInfo.vue_vue_type_script_setup_true_lang-BRRtcGIH.js} +1 -1
- package/dist/{StaffPanel-C-wYcFdv.js → StaffPanel-cQTAulcP.js} +1 -1
- package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-DZNArmnC.js → StaffPanel.vue_vue_type_script_setup_true_lang-BLeXlrI1.js} +2 -2
- package/dist/{SysUser-O4tvr-Ur.js → SysUser-DN5_46io.js} +2 -2
- package/dist/{SysUserPanel-B853docZ.js → SysUserPanel-DTBNR42y.js} +1 -1
- package/dist/{SysUserPanel.vue_vue_type_script_setup_true_lang-DhiYYC97.js → SysUserPanel.vue_vue_type_script_setup_true_lang-CF2pHcPP.js} +1 -1
- package/dist/{SystemMenu-CXR6mrXr.js → SystemMenu-D9TKZwgb.js} +2 -2
- package/dist/{UserInfo-BkP8pE2a.js → UserInfo-DJ5LRTMe.js} +1 -1
- package/dist/{UserInfo.vue_vue_type_style_index_0_lang-D4r_umjV.js → UserInfo.vue_vue_type_style_index_0_lang-CIpPef_S.js} +1 -1
- package/dist/{childView-D0HwbgDT.js → childView-CGZSd19y.js} +1 -1
- package/dist/{childView-TRqUkSDC.js → childView-DrL_Qi-q.js} +1 -1
- package/dist/{childView.vue_vue_type_style_index_0_lang-BzISq0Jf.js → childView.vue_vue_type_style_index_0_lang-B8wEeuFX.js} +1 -1
- package/dist/{childView.vue_vue_type_style_index_0_lang-DQRgNsJY.js → childView.vue_vue_type_style_index_0_lang-D2AzjPNV.js} +1 -1
- package/dist/{code-rule-BV7PQWhK.js → code-rule-DVEoh1Z4.js} +1 -1
- package/dist/core.es.js +1 -1
- package/dist/{cron-task-9ZS9bi7K.js → cron-task-BBpccUV_.js} +1 -1
- package/dist/{frameView-DE83AN50.js → frameView-Cw6_EqfJ.js} +1 -1
- package/dist/index-BAkwQh8m.js +4467 -0
- package/dist/{layoutView-D1U-c4By.js → layoutView-CL2Ef3bw.js} +1187 -1183
- package/dist/{login-sPCEiTGT.js → login-BDocwo7t.js} +115 -108
- package/dist/{lov-view-76NcYTYl.js → lov-view-R8nnUEbA.js} +2 -2
- package/dist/{menuInfo-CxjfjFpm.js → menuInfo-B-nGOcSv.js} +1 -1
- package/dist/{menuInfo.vue_vue_type_style_index_0_lang-C2qahH3r.js → menuInfo.vue_vue_type_style_index_0_lang-1VuzxMb0.js} +1 -1
- package/dist/{pda-app-BUH16bLj.js → pda-app-D5wBClj0.js} +1 -1
- package/dist/{resource-CCuHzoA6.js → resource-BXGSsXzw.js} +1 -1
- package/dist/{su-welcome-mRArONsd.js → su-welcome-DISZAkBB.js} +1 -1
- package/dist/sys-config-DuyYdzXL.js +290 -0
- package/dist/udp-core.css +2 -2
- package/dist/{utogether-Dm_VBQHR.js → utogether-C2KGHvut.js} +1 -1
- package/package.json +18 -18
- package/src/api/index.ts +31 -31
- package/src/components/udp/form.vue +2 -2
- package/src/components/udp/modal-form.vue +2 -1
- package/src/components/udp/modal-grid.vue +11 -1
- package/src/layout/components/lay-navbar/index.vue +239 -237
- package/src/layout/components/lay-search/index.vue +1 -1
- package/src/layout/components/lay-select-org/index.vue +64 -69
- package/src/layout/components/lay-sidebar/horizontal.vue +190 -191
- package/src/layout/components/lay-sidebar/mixNav.vue +260 -258
- package/src/layout/components/lay-sidebar/sidebar-logo.vue +92 -98
- package/src/layout/hooks/useNav.ts +173 -173
- package/src/main.ts +119 -119
- package/src/plugins/i18n/zh.ts +1 -0
- package/src/router/index.ts +3 -13
- package/src/store/modules/permission.ts +1 -4
- package/src/utils/propTypes.ts +42 -47
- package/src/utils/udp/http/index.ts +283 -281
- package/src/views/login/login-view.vue +300 -314
- package/src/views/organization/inv-org/InvOrganization.vue +68 -53
- package/src/views/system/sys/sys-config.vue +287 -291
- package/src/views/ulogin/login.vue +3 -4
- package/dist/InvOrganization-D90AbR3b.js +0 -66
- package/dist/index-DVARtten.js +0 -2623
- package/dist/sys-config-Cvt05yF6.js +0 -277
|
@@ -1,281 +1,283 @@
|
|
|
1
|
-
import Axios, { type AxiosInstance, type AxiosRequestConfig } from 'axios';
|
|
2
|
-
import type { SuHttpError, RequestMethods, SuHttpResponse, SuHttpRequestConfig } from './types.d';
|
|
3
|
-
|
|
4
|
-
import { errorMessage, cookies, NProgress } from '@utogether/utils';
|
|
5
|
-
import { isRef } from 'vue';
|
|
6
|
-
import { has } from 'xe-utils';
|
|
7
|
-
|
|
8
|
-
const kTOKENKEY = 'authorized-token';
|
|
9
|
-
const defaultConfig: AxiosRequestConfig = {
|
|
10
|
-
timeout: 180000,
|
|
11
|
-
headers: {
|
|
12
|
-
Accept: 'application/json, text/plain, */*',
|
|
13
|
-
'Content-Type': 'application/json',
|
|
14
|
-
'X-Requested-With': 'XMLHttpRequest'
|
|
15
|
-
}
|
|
16
|
-
};
|
|
17
|
-
class SuHttp {
|
|
18
|
-
constructor() {
|
|
19
|
-
this.httpInterceptorsRequest();
|
|
20
|
-
this.httpInterceptorsResponse();
|
|
21
|
-
}
|
|
22
|
-
router = undefined;
|
|
23
|
-
baseUrl = null;
|
|
24
|
-
/** token过期后,暂存待执行的请求 */
|
|
25
|
-
private static requests = [];
|
|
26
|
-
|
|
27
|
-
/** 防止重复刷新token */
|
|
28
|
-
private static isRefreshing = false;
|
|
29
|
-
|
|
30
|
-
/** 设置router调整 */
|
|
31
|
-
setRouter(router) {
|
|
32
|
-
this.router = router;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
setBaseUrl(baseUrl) {
|
|
36
|
-
this.baseUrl = baseUrl;
|
|
37
|
-
}
|
|
38
|
-
// 初始化配置对象
|
|
39
|
-
private static initConfig: SuHttpRequestConfig = {};
|
|
40
|
-
|
|
41
|
-
// 保存当前Axios实例对象
|
|
42
|
-
private static axiosInstance: AxiosInstance = Axios.create(defaultConfig);
|
|
43
|
-
|
|
44
|
-
/** 重连原始请求 */
|
|
45
|
-
private static retryOriginalRequest(config: SuHttpRequestConfig) {
|
|
46
|
-
return new Promise(resolve => {
|
|
47
|
-
// @ts-ignore
|
|
48
|
-
SuHttp.requests.push((token: string) => {
|
|
49
|
-
config.headers!['Authorization'] = 'Bearer ' + token;
|
|
50
|
-
resolve(config);
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
// 请求拦截
|
|
56
|
-
private httpInterceptorsRequest(): void {
|
|
57
|
-
SuHttp.axiosInstance.interceptors.request.use(
|
|
58
|
-
(config: any) => {
|
|
59
|
-
if (has(config, 'loading') && isRef(config.loading)) {
|
|
60
|
-
config.loading.value = true;
|
|
61
|
-
}
|
|
62
|
-
// 开启进度条动画
|
|
63
|
-
NProgress.start();
|
|
64
|
-
// 优先判断post/get等方法是否传入回掉,否则执行初始化设置等回掉
|
|
65
|
-
if (typeof config.beforeRequestCallback === 'function') {
|
|
66
|
-
config.beforeRequestCallback(config);
|
|
67
|
-
return config;
|
|
68
|
-
}
|
|
69
|
-
if (SuHttp.initConfig.beforeRequestCallback) {
|
|
70
|
-
SuHttp.initConfig.beforeRequestCallback(config);
|
|
71
|
-
return config;
|
|
72
|
-
}
|
|
73
|
-
const whiteList = ['/refreshToken', '/login'];
|
|
74
|
-
if (whiteList.some(v => config.url.indexOf(v) > -1)) return config;
|
|
75
|
-
return new Promise(resolve => {
|
|
76
|
-
const token = cookies.get(kTOKENKEY);
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
const
|
|
80
|
-
const
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
//
|
|
94
|
-
|
|
95
|
-
SuHttp.requests
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
config
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
//
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
//
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
const
|
|
175
|
-
const
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
} else {
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
1
|
+
import Axios, { type AxiosInstance, type AxiosRequestConfig } from 'axios';
|
|
2
|
+
import type { SuHttpError, RequestMethods, SuHttpResponse, SuHttpRequestConfig } from './types.d';
|
|
3
|
+
|
|
4
|
+
import { errorMessage, cookies, NProgress } from '@utogether/utils';
|
|
5
|
+
import { isRef } from 'vue';
|
|
6
|
+
import { has } from 'xe-utils';
|
|
7
|
+
|
|
8
|
+
const kTOKENKEY = 'authorized-token';
|
|
9
|
+
const defaultConfig: AxiosRequestConfig = {
|
|
10
|
+
timeout: 180000,
|
|
11
|
+
headers: {
|
|
12
|
+
Accept: 'application/json, text/plain, */*',
|
|
13
|
+
'Content-Type': 'application/json',
|
|
14
|
+
'X-Requested-With': 'XMLHttpRequest'
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
class SuHttp {
|
|
18
|
+
constructor() {
|
|
19
|
+
this.httpInterceptorsRequest();
|
|
20
|
+
this.httpInterceptorsResponse();
|
|
21
|
+
}
|
|
22
|
+
router = undefined;
|
|
23
|
+
baseUrl = null;
|
|
24
|
+
/** token过期后,暂存待执行的请求 */
|
|
25
|
+
private static requests = [];
|
|
26
|
+
|
|
27
|
+
/** 防止重复刷新token */
|
|
28
|
+
private static isRefreshing = false;
|
|
29
|
+
|
|
30
|
+
/** 设置router调整 */
|
|
31
|
+
setRouter(router) {
|
|
32
|
+
this.router = router;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
setBaseUrl(baseUrl) {
|
|
36
|
+
this.baseUrl = baseUrl;
|
|
37
|
+
}
|
|
38
|
+
// 初始化配置对象
|
|
39
|
+
private static initConfig: SuHttpRequestConfig = {};
|
|
40
|
+
|
|
41
|
+
// 保存当前Axios实例对象
|
|
42
|
+
private static axiosInstance: AxiosInstance = Axios.create(defaultConfig);
|
|
43
|
+
|
|
44
|
+
/** 重连原始请求 */
|
|
45
|
+
private static retryOriginalRequest(config: SuHttpRequestConfig) {
|
|
46
|
+
return new Promise(resolve => {
|
|
47
|
+
// @ts-ignore
|
|
48
|
+
SuHttp.requests.push((token: string) => {
|
|
49
|
+
config.headers!['Authorization'] = 'Bearer ' + token;
|
|
50
|
+
resolve(config);
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// 请求拦截
|
|
56
|
+
private httpInterceptorsRequest(): void {
|
|
57
|
+
SuHttp.axiosInstance.interceptors.request.use(
|
|
58
|
+
(config: any) => {
|
|
59
|
+
if (has(config, 'loading') && isRef(config.loading)) {
|
|
60
|
+
config.loading.value = true;
|
|
61
|
+
}
|
|
62
|
+
// 开启进度条动画
|
|
63
|
+
NProgress.start();
|
|
64
|
+
// 优先判断post/get等方法是否传入回掉,否则执行初始化设置等回掉
|
|
65
|
+
if (typeof config.beforeRequestCallback === 'function') {
|
|
66
|
+
config.beforeRequestCallback(config);
|
|
67
|
+
return config;
|
|
68
|
+
}
|
|
69
|
+
if (SuHttp.initConfig.beforeRequestCallback) {
|
|
70
|
+
SuHttp.initConfig.beforeRequestCallback(config);
|
|
71
|
+
return config;
|
|
72
|
+
}
|
|
73
|
+
const whiteList = ['/refreshToken', '/login'];
|
|
74
|
+
if (whiteList.some(v => config.url.indexOf(v) > -1)) return config;
|
|
75
|
+
return new Promise(resolve => {
|
|
76
|
+
const token = cookies.get(kTOKENKEY);
|
|
77
|
+
// debugger;
|
|
78
|
+
if (token) {
|
|
79
|
+
const data = JSON.parse(token);
|
|
80
|
+
const now = new Date().getTime();
|
|
81
|
+
const expired = data.expires - now <= 0;
|
|
82
|
+
if (expired) {
|
|
83
|
+
if (!SuHttp.isRefreshing) {
|
|
84
|
+
SuHttp.isRefreshing = true;
|
|
85
|
+
// requests.push(() => SuHttp.axiosInstance(config));
|
|
86
|
+
this.get((this.baseUrl || '') + '/uath/refreshToken', {
|
|
87
|
+
refreshToken: data.refreshToken
|
|
88
|
+
})
|
|
89
|
+
.then((res: any) => {
|
|
90
|
+
// 替换token
|
|
91
|
+
this.setToken(res);
|
|
92
|
+
config.headers['Authorization'] = 'Bearer ' + res.access_token;
|
|
93
|
+
// token 刷新后将数组的方法重新执行
|
|
94
|
+
// @ts-ignore
|
|
95
|
+
SuHttp.requests.forEach(cb => cb(res.access_token));
|
|
96
|
+
SuHttp.requests = []; // 重新请求完清空
|
|
97
|
+
})
|
|
98
|
+
.finally(() => {
|
|
99
|
+
SuHttp.isRefreshing = false;
|
|
100
|
+
this.router.push({ name: 'login' });
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
// @ts-ignore
|
|
104
|
+
resolve(SuHttp.retryOriginalRequest(config));
|
|
105
|
+
} else {
|
|
106
|
+
config.headers['Authorization'] = 'Bearer ' + data.accessToken;
|
|
107
|
+
resolve(config);
|
|
108
|
+
}
|
|
109
|
+
} else {
|
|
110
|
+
const sessionKey = cookies.get('kCookies_token') as string;
|
|
111
|
+
if (sessionKey) {
|
|
112
|
+
config.headers['X-Token'] = sessionKey;
|
|
113
|
+
}
|
|
114
|
+
resolve(config);
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
},
|
|
118
|
+
error => {
|
|
119
|
+
return Promise.reject(error);
|
|
120
|
+
}
|
|
121
|
+
);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
private setToken(token) {
|
|
125
|
+
const { access_token, expires_in, refresh_token } = token;
|
|
126
|
+
const cache = {
|
|
127
|
+
accessToken: access_token,
|
|
128
|
+
refreshToken: refresh_token,
|
|
129
|
+
expires: Date.now() + expires_in * 1000
|
|
130
|
+
};
|
|
131
|
+
cookies.set(kTOKENKEY, JSON.stringify(cache));
|
|
132
|
+
// cookies.set(kTOKENKEY, JSON.stringify(cache), { expires: expires_in });
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// 响应拦截
|
|
136
|
+
private httpInterceptorsResponse(): void {
|
|
137
|
+
const instance = SuHttp.axiosInstance;
|
|
138
|
+
instance.interceptors.response.use(
|
|
139
|
+
(response: SuHttpResponse) => {
|
|
140
|
+
const $config = response.config;
|
|
141
|
+
if (has($config, 'loading') && isRef($config.loading)) {
|
|
142
|
+
$config.loading.value = false;
|
|
143
|
+
}
|
|
144
|
+
// 关闭进度条动画
|
|
145
|
+
NProgress.done();
|
|
146
|
+
// 优先判断post/get等方法是否传入回掉,否则执行初始化设置等回掉
|
|
147
|
+
if (typeof $config.beforeResponseCallback === 'function') {
|
|
148
|
+
$config.beforeResponseCallback(response);
|
|
149
|
+
return response.data;
|
|
150
|
+
}
|
|
151
|
+
if (SuHttp.initConfig.beforeResponseCallback) {
|
|
152
|
+
SuHttp.initConfig.beforeResponseCallback(response);
|
|
153
|
+
return response.data;
|
|
154
|
+
}
|
|
155
|
+
return response.data;
|
|
156
|
+
},
|
|
157
|
+
(error: SuHttpError) => {
|
|
158
|
+
const $error = error;
|
|
159
|
+
// @ts-ignore
|
|
160
|
+
if (has(error.config, 'loading') && isRef(error?.config?.loading)) {
|
|
161
|
+
// @ts-ignore
|
|
162
|
+
error.config.loading.value = false;
|
|
163
|
+
}
|
|
164
|
+
$error.isCancelRequest = Axios.isCancel($error);
|
|
165
|
+
// 关闭进度条动画
|
|
166
|
+
NProgress.done();
|
|
167
|
+
// 所有的响应异常 区分来源为取消请求/非取消请求
|
|
168
|
+
return Promise.reject($error);
|
|
169
|
+
}
|
|
170
|
+
);
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
private transformConfigByMethod(params: any, config: SuHttpRequestConfig): SuHttpRequestConfig {
|
|
174
|
+
const { method } = config;
|
|
175
|
+
const methods = ['get'];
|
|
176
|
+
const m = method!.toLocaleLowerCase();
|
|
177
|
+
const props = methods.includes(m) ? 'params' : 'data';
|
|
178
|
+
return {
|
|
179
|
+
...config,
|
|
180
|
+
[props]: params
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
// 通用请求工具函数
|
|
185
|
+
public request<T>(
|
|
186
|
+
method: RequestMethods,
|
|
187
|
+
url: string,
|
|
188
|
+
param?: AxiosRequestConfig,
|
|
189
|
+
axiosConfig?: SuHttpRequestConfig
|
|
190
|
+
): Promise<T> {
|
|
191
|
+
const config = this.transformConfigByMethod(param, {
|
|
192
|
+
method,
|
|
193
|
+
url,
|
|
194
|
+
...axiosConfig
|
|
195
|
+
} as SuHttpRequestConfig);
|
|
196
|
+
// 单独处理自定义请求/响应回掉
|
|
197
|
+
return new Promise((resolve, reject) => {
|
|
198
|
+
SuHttp.axiosInstance
|
|
199
|
+
.request(config)
|
|
200
|
+
.then((res: any) => {
|
|
201
|
+
if (res && res?.code === '0') {
|
|
202
|
+
resolve(res.data);
|
|
203
|
+
} else if (res.code === '500') {
|
|
204
|
+
errorMessage(res.msg, { duration: 8000 });
|
|
205
|
+
if (config.method === 'get') {
|
|
206
|
+
resolve(res);
|
|
207
|
+
} else {
|
|
208
|
+
reject(res.msg);
|
|
209
|
+
}
|
|
210
|
+
} else if (res?.code !== '-1') {
|
|
211
|
+
resolve(res);
|
|
212
|
+
} else {
|
|
213
|
+
const msg = res?.msg || '服务异常';
|
|
214
|
+
errorMessage(msg, { duration: 8000 });
|
|
215
|
+
reject(msg);
|
|
216
|
+
}
|
|
217
|
+
})
|
|
218
|
+
.catch(e => {
|
|
219
|
+
if (e?.code) {
|
|
220
|
+
if (e?.response?.status === 401) {
|
|
221
|
+
// @ts-ignore
|
|
222
|
+
return this.router?.push({ path: '/login' });
|
|
223
|
+
}
|
|
224
|
+
errorMessage(this.getNetworkError(e?.response?.status) || e?.message, { duration: 8000 });
|
|
225
|
+
}
|
|
226
|
+
if (e.config.method === 'get') {
|
|
227
|
+
resolve(e);
|
|
228
|
+
} else {
|
|
229
|
+
reject(e);
|
|
230
|
+
}
|
|
231
|
+
});
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
getNetworkError = code => {
|
|
236
|
+
if (!code) return null;
|
|
237
|
+
const msgMap = {
|
|
238
|
+
400: '错误的请求',
|
|
239
|
+
401: '服务未授权,请重新登录',
|
|
240
|
+
403: '拒绝访问',
|
|
241
|
+
404: '请求错误,未找到该资源',
|
|
242
|
+
408: '请求超时',
|
|
243
|
+
500: '服务器端出差',
|
|
244
|
+
502: '网络超时',
|
|
245
|
+
503: '服务不可用',
|
|
246
|
+
504: '网络超时'
|
|
247
|
+
};
|
|
248
|
+
return msgMap[code];
|
|
249
|
+
};
|
|
250
|
+
|
|
251
|
+
// 单独抽离的post工具函数
|
|
252
|
+
public post<T, P>(url: string, params?: T, config?: SuHttpRequestConfig): Promise<P> {
|
|
253
|
+
// @ts-ignore
|
|
254
|
+
return this.request<P>('post', url, params, config);
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
// 单独抽离的delete工具函数
|
|
258
|
+
public delete<T, P>(url: string, params?: T, config?: SuHttpRequestConfig): Promise<P> {
|
|
259
|
+
// @ts-ignore
|
|
260
|
+
return this.request<P>('delete', url, params, config);
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
// 单独抽离的put工具函数
|
|
264
|
+
public put<T, P>(url: string, params?: T, config?: SuHttpRequestConfig): Promise<P> {
|
|
265
|
+
// @ts-ignore
|
|
266
|
+
return this.request<P>('put', url, params, config);
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
// 单独抽离的get工具函数
|
|
270
|
+
public get<T, P>(url: string, params?: T, config?: SuHttpRequestConfig): Promise<P> {
|
|
271
|
+
for (const key in params) {
|
|
272
|
+
if (!params[key]) delete params[key];
|
|
273
|
+
}
|
|
274
|
+
// @ts-ignore
|
|
275
|
+
return this.request<P>('get', url, params, config);
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
public postRouter<T>(params?: any): Promise<T> {
|
|
279
|
+
return this.request<T>('post', 'route/service', params);
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
export const http = new SuHttp();
|