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