yuang-framework-ui-common 1.0.42 → 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/urlUtils.ts +62 -2
- package/package.json +1 -1
- package/src/views/sso/login/index.vue +1 -31
- 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/urlUtils.ts
CHANGED
@@ -5,7 +5,7 @@
|
|
5
5
|
* @param parameter
|
6
6
|
* @return {string}
|
7
7
|
*/
|
8
|
-
const removeUrlParameter = (url, parameter) => {
|
8
|
+
const removeUrlParameter = (url: string, parameter: string) => {
|
9
9
|
if (!url) {
|
10
10
|
return console.error('参数[url]为空');
|
11
11
|
}
|
@@ -30,4 +30,64 @@ const removeUrlParameter = (url, parameter) => {
|
|
30
30
|
return result;
|
31
31
|
};
|
32
32
|
|
33
|
-
|
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
@@ -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
|
|
@@ -28,37 +29,6 @@
|
|
28
29
|
router.push(ssoRedirectRoutePath);
|
29
30
|
});
|
30
31
|
});
|
31
|
-
|
32
|
-
/**
|
33
|
-
* 删除url中的指定参数
|
34
|
-
* @param url
|
35
|
-
* @param parameter
|
36
|
-
* @return {string}
|
37
|
-
*/
|
38
|
-
const removeUrlParameter = (url, parameter) => {
|
39
|
-
if (!url) {
|
40
|
-
return console.error('参数[url]为空');
|
41
|
-
}
|
42
|
-
if (!parameter) {
|
43
|
-
return console.error('参数[parameter]为空');
|
44
|
-
}
|
45
|
-
let urlObj;
|
46
|
-
let isFullUrl = url.startsWith('http');
|
47
|
-
if (isFullUrl) {
|
48
|
-
urlObj = new URL(url);
|
49
|
-
} else {
|
50
|
-
urlObj = new URL(url, window.location.origin);
|
51
|
-
}
|
52
|
-
urlObj.searchParams.delete(parameter);
|
53
|
-
let result = urlObj.pathname + urlObj.search;
|
54
|
-
if (url.includes('#')) {
|
55
|
-
result += '#' + url.split('#')[1];
|
56
|
-
}
|
57
|
-
if (isFullUrl) {
|
58
|
-
result = urlObj.origin + result;
|
59
|
-
}
|
60
|
-
return result;
|
61
|
-
};
|
62
32
|
</script>
|
63
33
|
|
64
34
|
<style scoped></style>
|
@@ -0,0 +1 @@
|
|
1
|
+
/// <reference types="vite/client" />
|