@antglobal/create-sdk-loader 1.0.1 → 1.0.3
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/main.d.ts +8 -1
- package/lib/main.js +142 -53
- package/package.json +1 -1
package/lib/main.d.ts
CHANGED
|
@@ -37,5 +37,12 @@ interface LoaderConfig<Config, ClassType> {
|
|
|
37
37
|
}
|
|
38
38
|
export declare function createInstance<Config, ClassType extends InitType<ClassType>>(ClassConstructor: new (config: Config) => ClassType, config: Config): Promise<ClassType>;
|
|
39
39
|
export declare function createLoader<Config, ClassType extends InitType<ClassType>>(loadConfig: LoaderConfig<Config, ClassType>): (config: Config) => Promise<ClassType>;
|
|
40
|
-
|
|
40
|
+
/**
|
|
41
|
+
* 加载远程脚本并获取指定的类
|
|
42
|
+
*/
|
|
43
|
+
export declare function loadScriptClass<ClassType extends InitType<ClassType>, Params = any, SDKConstructor = new (config: Params) => ClassType>(url: string, globalName: string | (() => SDKConstructor)): Promise<SDKConstructor>;
|
|
44
|
+
/**
|
|
45
|
+
* 加载远程脚本并获取指定的全局变量
|
|
46
|
+
*/
|
|
47
|
+
export declare function loadScript<T>(url: string, globalName: string | (() => T)): Promise<T>;
|
|
41
48
|
export {};
|
package/lib/main.js
CHANGED
|
@@ -1,66 +1,151 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __extends = (this && this.__extends) || (function () {
|
|
3
|
+
var extendStatics = function (d, b) {
|
|
4
|
+
extendStatics = Object.setPrototypeOf ||
|
|
5
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
+
return extendStatics(d, b);
|
|
8
|
+
};
|
|
9
|
+
return function (d, b) {
|
|
10
|
+
if (typeof b !== "function" && b !== null)
|
|
11
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
+
extendStatics(d, b);
|
|
13
|
+
function __() { this.constructor = d; }
|
|
14
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
+
};
|
|
16
|
+
})();
|
|
17
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
18
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
19
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
20
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
21
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
22
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
23
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
27
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
28
|
+
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
29
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
30
|
+
function step(op) {
|
|
31
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
32
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
33
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
34
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
35
|
+
switch (op[0]) {
|
|
36
|
+
case 0: case 1: t = op; break;
|
|
37
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
38
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
39
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
40
|
+
default:
|
|
41
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
42
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
43
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
44
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
45
|
+
if (t[2]) _.ops.pop();
|
|
46
|
+
_.trys.pop(); continue;
|
|
47
|
+
}
|
|
48
|
+
op = body.call(thisArg, _);
|
|
49
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
50
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
7
51
|
}
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
|
|
52
|
+
};
|
|
53
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
54
|
+
exports.createInstance = createInstance;
|
|
55
|
+
exports.createLoader = createLoader;
|
|
56
|
+
exports.loadScriptClass = loadScriptClass;
|
|
57
|
+
exports.loadScript = loadScript;
|
|
58
|
+
var LoaderError = /** @class */ (function (_super) {
|
|
59
|
+
__extends(LoaderError, _super);
|
|
60
|
+
function LoaderError(code, message) {
|
|
61
|
+
var _this = _super.call(this, message) || this;
|
|
62
|
+
Object.defineProperty(_this, "code", {
|
|
63
|
+
enumerable: true,
|
|
64
|
+
configurable: true,
|
|
65
|
+
writable: true,
|
|
66
|
+
value: void 0
|
|
67
|
+
});
|
|
68
|
+
_this.name = 'LoaderError';
|
|
69
|
+
_this.code = code;
|
|
70
|
+
return _this;
|
|
71
|
+
}
|
|
72
|
+
return LoaderError;
|
|
73
|
+
}(Error));
|
|
74
|
+
function createInstance(ClassConstructor, config) {
|
|
75
|
+
var instance = new ClassConstructor(config);
|
|
11
76
|
return instance.init();
|
|
12
77
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
return
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
78
|
+
function createLoader(loadConfig) {
|
|
79
|
+
var _this = this;
|
|
80
|
+
var sdkURL = loadConfig.sdkURL, globalName = loadConfig.globalName, _a = loadConfig.timeout, timeout = _a === void 0 ? 20000 : _a, onLoadComplete = loadConfig.onLoadComplete, onError = loadConfig.onError, onLoadStart = loadConfig.onLoadStart, onInitialized = loadConfig.onInitialized;
|
|
81
|
+
return function (config) {
|
|
82
|
+
onLoadStart === null || onLoadStart === void 0 ? void 0 : onLoadStart();
|
|
83
|
+
var _loadScriptClass = createTimeout(function () { return loadScriptClass(sdkURL, globalName); }, timeout);
|
|
84
|
+
return _loadScriptClass()
|
|
85
|
+
.then(function (RemoteClass) { return __awaiter(_this, void 0, void 0, function () {
|
|
86
|
+
var instance, e_1;
|
|
87
|
+
return __generator(this, function (_a) {
|
|
88
|
+
switch (_a.label) {
|
|
89
|
+
case 0:
|
|
90
|
+
onLoadComplete === null || onLoadComplete === void 0 ? void 0 : onLoadComplete();
|
|
91
|
+
if (!RemoteClass) {
|
|
92
|
+
throw new LoaderError('NO_REMOTE_CLASS', "No variables ".concat(globalName, " were found. Cannot be initialized the Class ").concat(globalName));
|
|
93
|
+
}
|
|
94
|
+
_a.label = 1;
|
|
95
|
+
case 1:
|
|
96
|
+
_a.trys.push([1, 3, , 4]);
|
|
97
|
+
return [4 /*yield*/, createInstance(RemoteClass, config)];
|
|
98
|
+
case 2:
|
|
99
|
+
instance = _a.sent();
|
|
100
|
+
onInitialized === null || onInitialized === void 0 ? void 0 : onInitialized(instance, window.location.href);
|
|
101
|
+
return [2 /*return*/, instance];
|
|
102
|
+
case 3:
|
|
103
|
+
e_1 = _a.sent();
|
|
104
|
+
throw new LoaderError('INIT_ERROR', "Initialize Class ".concat(globalName, " failed: ").concat(e_1.message));
|
|
105
|
+
case 4: return [2 /*return*/];
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}); })
|
|
109
|
+
.catch(function (e) {
|
|
110
|
+
onError === null || onError === void 0 ? void 0 : onError(e);
|
|
35
111
|
return Promise.reject(e);
|
|
36
112
|
});
|
|
37
113
|
};
|
|
38
114
|
}
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
115
|
+
/**
|
|
116
|
+
* 加载远程脚本并获取指定的类
|
|
117
|
+
*/
|
|
118
|
+
function loadScriptClass(url, globalName) {
|
|
119
|
+
return loadScript(url, globalName);
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* 加载远程脚本并获取指定的全局变量
|
|
123
|
+
*/
|
|
124
|
+
function loadScript(url, globalName) {
|
|
125
|
+
var getRemoteClass = function () {
|
|
126
|
+
if (typeof globalName === 'function') {
|
|
127
|
+
return globalName();
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
var className = window[globalName];
|
|
131
|
+
return (className === null || className === void 0 ? void 0 : className.default) || className;
|
|
132
|
+
}
|
|
133
|
+
};
|
|
134
|
+
return new Promise(function (resolve, reject) {
|
|
135
|
+
var RemoteClass = getRemoteClass();
|
|
51
136
|
if (RemoteClass) {
|
|
52
137
|
return resolve(RemoteClass);
|
|
53
138
|
}
|
|
54
|
-
|
|
55
|
-
|
|
139
|
+
var existedScript = document.querySelector("script[src=\"".concat(url, "\"]"));
|
|
140
|
+
var script = existedScript || document.createElement('script');
|
|
56
141
|
script.src = url;
|
|
57
142
|
script.async = true;
|
|
58
|
-
script.addEventListener('load', ()
|
|
143
|
+
script.addEventListener('load', function () {
|
|
59
144
|
// There is must use getRemoteClass
|
|
60
145
|
resolve(getRemoteClass());
|
|
61
146
|
});
|
|
62
|
-
script.addEventListener('error', (e)
|
|
63
|
-
reject(new LoaderError('LOAD_ERROR',
|
|
147
|
+
script.addEventListener('error', function (e) {
|
|
148
|
+
reject(new LoaderError('LOAD_ERROR', "Load script ".concat(url, " failed: ").concat(e.message)));
|
|
64
149
|
});
|
|
65
150
|
if (!existedScript) {
|
|
66
151
|
document.head.appendChild(script);
|
|
@@ -68,14 +153,18 @@ export function loadScript(url, globalName) {
|
|
|
68
153
|
});
|
|
69
154
|
}
|
|
70
155
|
function createTimeout(fn, t) {
|
|
71
|
-
return (
|
|
156
|
+
return function () {
|
|
157
|
+
var _args = [];
|
|
158
|
+
for (var _i = 0; _i < arguments.length; _i++) {
|
|
159
|
+
_args[_i] = arguments[_i];
|
|
160
|
+
}
|
|
72
161
|
return Promise.race([
|
|
73
|
-
new Promise((_r, reject)
|
|
74
|
-
setTimeout(()
|
|
75
|
-
reject(new LoaderError('LOAD_TIMEOUT',
|
|
162
|
+
new Promise(function (_r, reject) {
|
|
163
|
+
setTimeout(function () {
|
|
164
|
+
reject(new LoaderError('LOAD_TIMEOUT', "Load timeout: ".concat(t)));
|
|
76
165
|
}, t);
|
|
77
166
|
}),
|
|
78
|
-
fn(
|
|
167
|
+
fn.apply(void 0, _args)
|
|
79
168
|
]);
|
|
80
169
|
};
|
|
81
170
|
}
|