yuang-framework-ui-common 1.0.41 → 1.0.43
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/lib/utils/htmlUtils.ts +117 -0
- package/lib/utils/objectUtils.ts +12 -0
- package/lib/utils/ssoUtils.ts +27 -0
- package/lib/utils/urlUtils.ts +93 -0
- package/package.json +1 -1
- package/src/shims-vue.d.ts +3 -0
- package/src/views/sso/login/index.vue +2 -11
- package/src/vite-env.d.ts +1 -0
@@ -0,0 +1,117 @@
|
|
1
|
+
|
2
|
+
/**
|
3
|
+
* 加载脚本
|
4
|
+
* @param src
|
5
|
+
* @param callback
|
6
|
+
*/
|
7
|
+
const loadScript = (src, callback) => {
|
8
|
+
if (!src) {
|
9
|
+
console.error("[src]为空");
|
10
|
+
return;
|
11
|
+
}
|
12
|
+
var script = document.createElement('script') as any,
|
13
|
+
head = document.getElementsByTagName('head')[0];
|
14
|
+
script.type = 'text/javascript';
|
15
|
+
script.charset = 'UTF-8';
|
16
|
+
script.src = src;
|
17
|
+
if (script.addEventListener) {
|
18
|
+
script.addEventListener('load', function () {
|
19
|
+
callback && callback();
|
20
|
+
}, false);
|
21
|
+
} else if (script.attachEvent) {
|
22
|
+
script.attachEvent('onreadystatechange', function () {
|
23
|
+
var target = window.event.srcElement as any;
|
24
|
+
if (target.readyState == 'loaded') {
|
25
|
+
callback && callback();
|
26
|
+
}
|
27
|
+
});
|
28
|
+
}
|
29
|
+
head.appendChild(script);
|
30
|
+
}
|
31
|
+
|
32
|
+
|
33
|
+
/**
|
34
|
+
* 加载样式
|
35
|
+
* @param src
|
36
|
+
* @param callback
|
37
|
+
*/
|
38
|
+
const loadLink = (href: string, callback) => {
|
39
|
+
if (!href) {
|
40
|
+
console.error("[href]为空");
|
41
|
+
return;
|
42
|
+
}
|
43
|
+
var link = document.createElement('link') as any,
|
44
|
+
head = document.getElementsByTagName('head')[0];
|
45
|
+
link.rel = 'stylesheet';
|
46
|
+
link.charset = 'UTF-8';
|
47
|
+
link.href = href;
|
48
|
+
if (link.addEventListener) {
|
49
|
+
link.addEventListener('load', function () {
|
50
|
+
callback && callback();
|
51
|
+
}, false);
|
52
|
+
} else if (link.attachEvent) {
|
53
|
+
link.attachEvent('onreadystatechange', function () {
|
54
|
+
var target = window.event.srcElement as any;
|
55
|
+
if (target.readyState == 'loaded') {
|
56
|
+
callback && callback();
|
57
|
+
}
|
58
|
+
});
|
59
|
+
}
|
60
|
+
head.appendChild(link);
|
61
|
+
}
|
62
|
+
|
63
|
+
/**
|
64
|
+
* 加载iframe
|
65
|
+
* @param src
|
66
|
+
* @param callback
|
67
|
+
*/
|
68
|
+
const loadIframe = (src: string, callback) => {
|
69
|
+
if (!src) {
|
70
|
+
console.error("[src]为空");
|
71
|
+
return;
|
72
|
+
}
|
73
|
+
|
74
|
+
var iframe = document.createElement('iframe') as any,
|
75
|
+
head = document.getElementsByTagName('head')[0];
|
76
|
+
iframe.charset = 'UTF-8';
|
77
|
+
iframe.src = src;
|
78
|
+
if (iframe.addEventListener) {
|
79
|
+
iframe.addEventListener('load', function () {
|
80
|
+
callback && callback();
|
81
|
+
}, false);
|
82
|
+
} else if (iframe.attachEvent) {
|
83
|
+
iframe.attachEvent('onreadystatechange', function () {
|
84
|
+
var target = window.event.srcElement as any;
|
85
|
+
if (target.readyState == 'loaded') {
|
86
|
+
callback && callback();
|
87
|
+
}
|
88
|
+
});
|
89
|
+
}
|
90
|
+
head.appendChild(iframe);
|
91
|
+
}
|
92
|
+
|
93
|
+
/**
|
94
|
+
* 获取文件存储大小,单位:byte字节
|
95
|
+
* @param url
|
96
|
+
* @returns {Promise<unknown>}
|
97
|
+
*/
|
98
|
+
const getFileSize = (url: string) => {
|
99
|
+
return new Promise(function (resolve, reject) {
|
100
|
+
const xhr = new XMLHttpRequest();
|
101
|
+
xhr.open("HEAD", url);
|
102
|
+
xhr.onreadystatechange = function () {
|
103
|
+
if (this.readyState == this.DONE) {
|
104
|
+
if (this.status == 200) {
|
105
|
+
const size = xhr.getResponseHeader("Content-Length");
|
106
|
+
resolve(size);
|
107
|
+
} else {
|
108
|
+
reject("Failed to get file size.");
|
109
|
+
}
|
110
|
+
}
|
111
|
+
};
|
112
|
+
xhr.send();
|
113
|
+
});
|
114
|
+
}
|
115
|
+
|
116
|
+
|
117
|
+
export { loadScript, loadLink, loadIframe, getFileSize };
|
package/lib/utils/objectUtils.ts
CHANGED
@@ -46,8 +46,20 @@ const typeOf = (obj) => {
|
|
46
46
|
return Object.prototype.toString.call(obj).slice(8, -1);
|
47
47
|
};
|
48
48
|
|
49
|
+
|
50
|
+
/**
|
51
|
+
* 是否Promise对象
|
52
|
+
* @param obj
|
53
|
+
* @returns {boolean}
|
54
|
+
*/
|
55
|
+
const isPromise = (obj) => {
|
56
|
+
return obj && Object.prototype.toString.call(obj) ==="[object Promise]";
|
57
|
+
}
|
58
|
+
|
49
59
|
export {
|
50
60
|
shallowClone,
|
51
61
|
deepClone,
|
52
62
|
typeOf,
|
63
|
+
|
64
|
+
isPromise
|
53
65
|
}
|
package/lib/utils/ssoUtils.ts
CHANGED
@@ -119,6 +119,30 @@ const setSsoAccessToken = (param: any) => {
|
|
119
119
|
}
|
120
120
|
|
121
121
|
|
122
|
+
|
123
|
+
const getSsoCookieAccessToken = () => {
|
124
|
+
let ssoAccessToken = Cookies.get(ssoAccessTokenCookieKey);
|
125
|
+
return ssoAccessToken;
|
126
|
+
}
|
127
|
+
|
128
|
+
|
129
|
+
const setSsoCookieAccessToken = (param: any) => {
|
130
|
+
if (!param.ssoAccessToken) {
|
131
|
+
throw new Error('参数[ssoAccessToken]为空');
|
132
|
+
}
|
133
|
+
if (!param.ssoExpiresIn) {
|
134
|
+
throw new Error('参数[ssoExpiresIn]为空');
|
135
|
+
}
|
136
|
+
if (!param.ssoRefreshToken) {
|
137
|
+
throw new Error('参数[ssoRefreshToken]为空');
|
138
|
+
}
|
139
|
+
if (!param.ssoRefreshExpiresIn) {
|
140
|
+
throw new Error('参数[ssoRefreshExpiresIn]为空');
|
141
|
+
}
|
142
|
+
Cookies.set(ssoAccessTokenCookieKey, param.ssoAccessToken);
|
143
|
+
}
|
144
|
+
|
145
|
+
|
122
146
|
const clearSsoAccessToken = () => {
|
123
147
|
Cookies.remove(ssoAccessTokenCookieKey);
|
124
148
|
|
@@ -144,6 +168,9 @@ export {
|
|
144
168
|
getSsoAccessToken,
|
145
169
|
setSsoAccessToken,
|
146
170
|
|
171
|
+
getSsoCookieAccessToken,
|
172
|
+
setSsoCookieAccessToken,
|
173
|
+
|
147
174
|
clearSsoAccessToken,
|
148
175
|
|
149
176
|
logoutSso,
|
@@ -0,0 +1,93 @@
|
|
1
|
+
|
2
|
+
/**
|
3
|
+
* 删除url中的指定参数
|
4
|
+
* @param url
|
5
|
+
* @param parameter
|
6
|
+
* @return {string}
|
7
|
+
*/
|
8
|
+
const removeUrlParameter = (url: string, parameter: string) => {
|
9
|
+
if (!url) {
|
10
|
+
return console.error('参数[url]为空');
|
11
|
+
}
|
12
|
+
if (!parameter) {
|
13
|
+
return console.error('参数[parameter]为空');
|
14
|
+
}
|
15
|
+
let urlObj;
|
16
|
+
let isFullUrl = url.startsWith('http');
|
17
|
+
if (isFullUrl) {
|
18
|
+
urlObj = new URL(url);
|
19
|
+
} else {
|
20
|
+
urlObj = new URL(url, window.location.origin);
|
21
|
+
}
|
22
|
+
urlObj.searchParams.delete(parameter);
|
23
|
+
let result = urlObj.pathname + urlObj.search;
|
24
|
+
if (url.includes('#')) {
|
25
|
+
result += '#' + url.split('#')[1];
|
26
|
+
}
|
27
|
+
if (isFullUrl) {
|
28
|
+
result = urlObj.origin + result;
|
29
|
+
}
|
30
|
+
return result;
|
31
|
+
};
|
32
|
+
|
33
|
+
|
34
|
+
|
35
|
+
/**
|
36
|
+
* 获取url的参数
|
37
|
+
* @param name 参数名
|
38
|
+
* @param url,如果不传递,就使用当前url
|
39
|
+
* @returns {string|null}
|
40
|
+
*/
|
41
|
+
const getParameter = (name: string, url: string) => {
|
42
|
+
url = url || window.location.search;
|
43
|
+
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
|
44
|
+
var r = url.substr(1).match(reg);
|
45
|
+
if (r != null) return decodeURIComponent(r[2]);
|
46
|
+
return null;
|
47
|
+
}
|
48
|
+
|
49
|
+
/**
|
50
|
+
* 获取url的map集合
|
51
|
+
* @param url,如果不传递,就使用当前url
|
52
|
+
* @returns {map|null}
|
53
|
+
*/
|
54
|
+
const getParameterMap = (url: string) => {
|
55
|
+
url = url || window.location.search;
|
56
|
+
|
57
|
+
let arrObj = url.split("?") as any;
|
58
|
+
let params = Object.create(null);
|
59
|
+
if (arrObj.length > 1) {
|
60
|
+
arrObj = arrObj[1].split("&");
|
61
|
+
arrObj.forEach((item: any) => {
|
62
|
+
item = item.split("=");
|
63
|
+
params[item[0]] = decodeURIComponent(item[1]);
|
64
|
+
})
|
65
|
+
}
|
66
|
+
return params;
|
67
|
+
}
|
68
|
+
|
69
|
+
|
70
|
+
/**
|
71
|
+
* 获取平台基础url
|
72
|
+
* @param url
|
73
|
+
* @returns {string}
|
74
|
+
*/
|
75
|
+
const getBaseUrl = (url: string) => {
|
76
|
+
url = url || location.href;
|
77
|
+
let arr = url.split('/');
|
78
|
+
if (arr.length > 3) {
|
79
|
+
var baseUrl = '';
|
80
|
+
for (let i = 0; i < arr.length; i++) {
|
81
|
+
if (i <= 3) {
|
82
|
+
baseUrl += arr[i] + '/';
|
83
|
+
}
|
84
|
+
}
|
85
|
+
if (baseUrl) {
|
86
|
+
return baseUrl.substring(0, baseUrl.length - 1);
|
87
|
+
}
|
88
|
+
} else {
|
89
|
+
console.error('地址存在问题');
|
90
|
+
}
|
91
|
+
};
|
92
|
+
|
93
|
+
export { removeUrlParameter, getParameter, getParameterMap, getBaseUrl };
|
package/package.json
CHANGED
package/src/shims-vue.d.ts
CHANGED
@@ -7,6 +7,7 @@
|
|
7
7
|
import { useRouter } from 'vue-router';
|
8
8
|
|
9
9
|
import { getSsoLoginUrl, setSsoAccessToken } from '../../../../lib/utils/ssoUtils';
|
10
|
+
import { removeUrlParameter } from '../../../../lib/utils/urlUtils';
|
10
11
|
|
11
12
|
const router = useRouter();
|
12
13
|
|
@@ -24,20 +25,10 @@
|
|
24
25
|
setSsoAccessToken(res.data.data);
|
25
26
|
let ssoRedirectRoutePath = router.currentRoute.value.query.ssoRedirectRoutePath as string;
|
26
27
|
ssoRedirectRoutePath = (ssoRedirectRoutePath && decodeURIComponent(ssoRedirectRoutePath)) || ('/sso/login/login-success' as any);
|
28
|
+
ssoRedirectRoutePath = removeUrlParameter(ssoRedirectRoutePath, 'ssoAuthCode');
|
27
29
|
router.push(ssoRedirectRoutePath);
|
28
30
|
});
|
29
31
|
});
|
30
|
-
|
31
|
-
const removeParameter = (url: string, parameter: string) => {
|
32
|
-
// 使用正则表达式匹配参数
|
33
|
-
const regex = new RegExp('[?&]' + parameter + '=[^&]*&?');
|
34
|
-
const newUrl = url.replace(regex, (match, offset, string) => {
|
35
|
-
offset;
|
36
|
-
string;
|
37
|
-
return match.includes('&') ? '&' : '';
|
38
|
-
});
|
39
|
-
return newUrl;
|
40
|
-
}
|
41
32
|
</script>
|
42
33
|
|
43
34
|
<style scoped></style>
|
@@ -0,0 +1 @@
|
|
1
|
+
/// <reference types="vite/client" />
|