@galacean/effects-plugin-alipay-downgrade 0.0.1-alpha.0
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/README.md +20 -0
- package/dist/alipay-downgrade-plugin.d.ts +8 -0
- package/dist/downgrade-vfx-item.d.ts +6 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.js +532 -0
- package/dist/index.js.map +1 -0
- package/dist/index.min.js +9 -0
- package/dist/index.min.js.map +1 -0
- package/dist/index.mjs +522 -0
- package/dist/index.mjs.map +1 -0
- package/dist/native-log.d.ts +13 -0
- package/dist/utils.d.ts +24 -0
- package/package.json +46 -0
package/README.md
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
# 支付宝降级插件
|
|
2
|
+
|
|
3
|
+
## 本地开发
|
|
4
|
+
|
|
5
|
+
### 开始开发
|
|
6
|
+
|
|
7
|
+
``` bash
|
|
8
|
+
# demo
|
|
9
|
+
pnpm --filter @galacean/effects-plugin-alipay-downgrade dev
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
> 浏览器打开:http://localhost:8081/demo/
|
|
13
|
+
|
|
14
|
+
### 单测
|
|
15
|
+
|
|
16
|
+
``` bash
|
|
17
|
+
# 同上
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
> 浏览器打开:http://localhost:8081/test/
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Player, SceneLoadOptions, spec } from '@galacean/effects';
|
|
2
|
+
import { AbstractPlugin } from '@galacean/effects';
|
|
3
|
+
export declare class AlipayDowngradePlugin extends AbstractPlugin {
|
|
4
|
+
static currentBizId: string;
|
|
5
|
+
static glLostOccurred: boolean;
|
|
6
|
+
static onPlayerCreated(player: Player): Promise<void>;
|
|
7
|
+
static processRawJSON(json: spec.JSONScene, options?: SceneLoadOptions): Promise<undefined>;
|
|
8
|
+
}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export * from './utils';
|
|
2
|
+
export * from './native-log';
|
|
3
|
+
/**
|
|
4
|
+
*
|
|
5
|
+
*/
|
|
6
|
+
export interface AlipayDowngradeOptions {
|
|
7
|
+
/**
|
|
8
|
+
* 发生 gl lost 时,是否忽略
|
|
9
|
+
* @default false - 不忽略,将不再允许任何播放器创建,会全部走降级逻辑
|
|
10
|
+
*/
|
|
11
|
+
ignoreGLLost?: boolean;
|
|
12
|
+
/**
|
|
13
|
+
* 禁用压后台的时候自动暂停播放器
|
|
14
|
+
* @default false
|
|
15
|
+
*/
|
|
16
|
+
autoPause?: boolean;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* 支付宝端内统一降级方案,传入降级 ID,每次加载场景前都会自动调用降级
|
|
20
|
+
* - 如果要为某个 json 单独配置降级 ID,可以使用 `player.loadScene(url, { pluginData: { alipayBizId: '#bizId#' }})`
|
|
21
|
+
* @param bizId - 降级 ID,如果为 `mock-pass` 将 mock 不降级场景,如果为 `mock-fail` 将 mock 降级场景,业务请不要使用这两个字符串
|
|
22
|
+
* @param options - 优化策略
|
|
23
|
+
*/
|
|
24
|
+
export declare function setAlipayDowngradeBizId(bizId: string, options?: AlipayDowngradeOptions): void;
|
|
25
|
+
/**
|
|
26
|
+
*
|
|
27
|
+
* @returns
|
|
28
|
+
*/
|
|
29
|
+
export declare function getAlipayDowngradeBizId(): string;
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,532 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Name: @galacean/effects-plugin-alipay-downgrade
|
|
3
|
+
* Description: Galacean Effects player downgrade plugin for Alipay
|
|
4
|
+
* Author: Ant Group CO., Ltd.
|
|
5
|
+
* Contributors: 燃然,意绮
|
|
6
|
+
* Version: v0.0.1-alpha.0
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
'use strict';
|
|
10
|
+
|
|
11
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
12
|
+
|
|
13
|
+
var effects = require('@galacean/effects');
|
|
14
|
+
|
|
15
|
+
/******************************************************************************
|
|
16
|
+
Copyright (c) Microsoft Corporation.
|
|
17
|
+
|
|
18
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
19
|
+
purpose with or without fee is hereby granted.
|
|
20
|
+
|
|
21
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
22
|
+
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
23
|
+
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
24
|
+
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
25
|
+
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
26
|
+
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
27
|
+
PERFORMANCE OF THIS SOFTWARE.
|
|
28
|
+
***************************************************************************** */
|
|
29
|
+
/* global Reflect, Promise, SuppressedError, Symbol */
|
|
30
|
+
|
|
31
|
+
var extendStatics = function(d, b) {
|
|
32
|
+
extendStatics = Object.setPrototypeOf ||
|
|
33
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
34
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
35
|
+
return extendStatics(d, b);
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
function __extends(d, b) {
|
|
39
|
+
if (typeof b !== "function" && b !== null)
|
|
40
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
41
|
+
extendStatics(d, b);
|
|
42
|
+
function __() { this.constructor = d; }
|
|
43
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function __awaiter(thisArg, _arguments, P, generator) {
|
|
47
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
48
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
49
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
50
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
51
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
52
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
function __generator(thisArg, body) {
|
|
57
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
58
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
59
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
60
|
+
function step(op) {
|
|
61
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
62
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
63
|
+
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;
|
|
64
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
65
|
+
switch (op[0]) {
|
|
66
|
+
case 0: case 1: t = op; break;
|
|
67
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
68
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
69
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
70
|
+
default:
|
|
71
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
72
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
73
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
74
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
75
|
+
if (t[2]) _.ops.pop();
|
|
76
|
+
_.trys.pop(); continue;
|
|
77
|
+
}
|
|
78
|
+
op = body.call(thisArg, _);
|
|
79
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
80
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
function __read(o, n) {
|
|
85
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
86
|
+
if (!m) return o;
|
|
87
|
+
var i = m.call(o), r, ar = [], e;
|
|
88
|
+
try {
|
|
89
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
90
|
+
}
|
|
91
|
+
catch (error) { e = { error: error }; }
|
|
92
|
+
finally {
|
|
93
|
+
try {
|
|
94
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
95
|
+
}
|
|
96
|
+
finally { if (e) throw e.error; }
|
|
97
|
+
}
|
|
98
|
+
return ar;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
function __spreadArray(to, from, pack) {
|
|
102
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
103
|
+
if (ar || !(i in from)) {
|
|
104
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
105
|
+
ar[i] = from[i];
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
|
|
112
|
+
var e = new Error(message);
|
|
113
|
+
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
114
|
+
};
|
|
115
|
+
|
|
116
|
+
var DEVICE_PERFORMANCE_LOW = 'low';
|
|
117
|
+
var DEVICE_PERFORMANCE_MIDDLE = 'middle';
|
|
118
|
+
var DEVICE_PERFORMANCE_HIGH = 'high';
|
|
119
|
+
var devicePending;
|
|
120
|
+
var devicePerformance;
|
|
121
|
+
var deviceName = 'DESKTOP_DEBUG';
|
|
122
|
+
var isIOS = false;
|
|
123
|
+
function getDeviceName() {
|
|
124
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
125
|
+
return __generator(this, function (_a) {
|
|
126
|
+
if (!devicePending) {
|
|
127
|
+
devicePending = getSystemInfo().then(function (info) {
|
|
128
|
+
var performance = info.performance, platform = info.platform, _a = info.model, model = _a === void 0 ? 'UNKNOWN_DEVICE' : _a;
|
|
129
|
+
if (!devicePerformance) {
|
|
130
|
+
devicePerformance = performance;
|
|
131
|
+
}
|
|
132
|
+
isIOS = platform === 'iOS';
|
|
133
|
+
deviceName = model;
|
|
134
|
+
if (/iPhone(\d+),/.test(deviceName) && !devicePerformance) {
|
|
135
|
+
var gen = +RegExp.$1;
|
|
136
|
+
// https://gist.github.com/adamawolf/3048717 device code
|
|
137
|
+
if (gen <= 9) { // iphone 7,iphone 7p
|
|
138
|
+
devicePerformance = DEVICE_PERFORMANCE_LOW;
|
|
139
|
+
}
|
|
140
|
+
else if (gen < 10) {
|
|
141
|
+
devicePerformance = DEVICE_PERFORMANCE_MIDDLE;
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
devicePerformance = DEVICE_PERFORMANCE_HIGH;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
if (deviceName.indexOf(info.brand) === 0) {
|
|
148
|
+
deviceName = deviceName.replace(info.brand, '').trim();
|
|
149
|
+
}
|
|
150
|
+
return deviceName;
|
|
151
|
+
}, function (e) {
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
return [2 /*return*/, devicePending.then(function () { return deviceName; }, function () { return deviceName; })];
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
function getRenderLevelByDevice(renderLevel) {
|
|
159
|
+
if (renderLevel === 'auto' || !renderLevel) {
|
|
160
|
+
if (devicePerformance === DEVICE_PERFORMANCE_HIGH) {
|
|
161
|
+
return effects.spec.RenderLevel.S;
|
|
162
|
+
}
|
|
163
|
+
else if (devicePerformance === DEVICE_PERFORMANCE_MIDDLE) {
|
|
164
|
+
return effects.spec.RenderLevel.A;
|
|
165
|
+
}
|
|
166
|
+
else if (devicePerformance === DEVICE_PERFORMANCE_LOW) {
|
|
167
|
+
return effects.spec.RenderLevel.B;
|
|
168
|
+
}
|
|
169
|
+
return isIOS ? effects.spec.RenderLevel.S : effects.spec.RenderLevel.B;
|
|
170
|
+
}
|
|
171
|
+
return /[ABS]/.test(renderLevel) ? renderLevel : effects.spec.RenderLevel.S;
|
|
172
|
+
}
|
|
173
|
+
function resetDevicePending() {
|
|
174
|
+
devicePending = undefined;
|
|
175
|
+
}
|
|
176
|
+
var mockIdPass = 'mock-pass';
|
|
177
|
+
var mockIdFail = 'mock-fail';
|
|
178
|
+
/**
|
|
179
|
+
*
|
|
180
|
+
* @param bizId
|
|
181
|
+
* @param options
|
|
182
|
+
* @returns
|
|
183
|
+
*/
|
|
184
|
+
function checkDowngrade(bizId, options) {
|
|
185
|
+
if (options === void 0) { options = {}; }
|
|
186
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
187
|
+
var ap, now_1;
|
|
188
|
+
return __generator(this, function (_a) {
|
|
189
|
+
if (bizId === mockIdFail || bizId === mockIdPass) {
|
|
190
|
+
return [2 /*return*/, Promise.resolve({ downgrade: bizId === mockIdFail, reason: 'mock' })];
|
|
191
|
+
}
|
|
192
|
+
ap = window.AlipayJSBridge;
|
|
193
|
+
if (ap) {
|
|
194
|
+
now_1 = performance.now();
|
|
195
|
+
return [2 /*return*/, getDeviceName().then(function () {
|
|
196
|
+
return new Promise(function (resolve) {
|
|
197
|
+
var _a;
|
|
198
|
+
var techPoint = ['mars'];
|
|
199
|
+
var tc = options.techPoint;
|
|
200
|
+
if (tc) {
|
|
201
|
+
techPoint.push.apply(techPoint, __spreadArray([], __read(tc), false));
|
|
202
|
+
}
|
|
203
|
+
var callBridge = (_a = options.callBridge) !== null && _a !== void 0 ? _a : ap.call;
|
|
204
|
+
callBridge('getDowngradeResult', {
|
|
205
|
+
bizId: bizId,
|
|
206
|
+
scene: 0,
|
|
207
|
+
ext: {
|
|
208
|
+
techPoint: techPoint,
|
|
209
|
+
},
|
|
210
|
+
}, function (result) {
|
|
211
|
+
var reason = undefined;
|
|
212
|
+
console.info("downgrade time: ".concat(performance.now() - now_1, "ms"));
|
|
213
|
+
if (!result.error) {
|
|
214
|
+
try {
|
|
215
|
+
var ret = effects.isString(result) ? JSON.parse(result) : result;
|
|
216
|
+
if ('downgradeResultType' in ret) {
|
|
217
|
+
reason = ret.downgradeResultType;
|
|
218
|
+
}
|
|
219
|
+
else if ('resultType' in ret) {
|
|
220
|
+
reason = ret.resultType;
|
|
221
|
+
}
|
|
222
|
+
if (result.context) {
|
|
223
|
+
var deviceInfo = result.context.deviceInfo;
|
|
224
|
+
if (deviceInfo) {
|
|
225
|
+
var level = deviceInfo.deviceLevel;
|
|
226
|
+
if (level === DEVICE_PERFORMANCE_HIGH || level === DEVICE_PERFORMANCE_LOW) {
|
|
227
|
+
devicePerformance = level;
|
|
228
|
+
}
|
|
229
|
+
else if (level === 'medium') {
|
|
230
|
+
devicePerformance = DEVICE_PERFORMANCE_MIDDLE;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
catch (ex) {
|
|
236
|
+
console.error(ex);
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
else {
|
|
240
|
+
// 无权调用的情况下不降级
|
|
241
|
+
resolve({ downgrade: result.error !== 4, reason: 'api error:' + result.error });
|
|
242
|
+
}
|
|
243
|
+
if (reason === undefined) {
|
|
244
|
+
resolve({ downgrade: true, reason: 'call downgrade fail' });
|
|
245
|
+
}
|
|
246
|
+
else {
|
|
247
|
+
resolve({ reason: reason, downgrade: reason === 1 });
|
|
248
|
+
}
|
|
249
|
+
});
|
|
250
|
+
});
|
|
251
|
+
})];
|
|
252
|
+
}
|
|
253
|
+
return [2 /*return*/, Promise.resolve({ downgrade: false, reason: 'no AP env' })];
|
|
254
|
+
});
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
function getSystemInfo() {
|
|
258
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
259
|
+
return __generator(this, function (_a) {
|
|
260
|
+
return [2 /*return*/, new Promise(function (resolve, reject) {
|
|
261
|
+
var ap = window.AlipayJSBridge;
|
|
262
|
+
if (ap) {
|
|
263
|
+
ap.call('getSystemInfo', function (e) {
|
|
264
|
+
if (e.error) {
|
|
265
|
+
reject(e);
|
|
266
|
+
}
|
|
267
|
+
else {
|
|
268
|
+
resolve(e);
|
|
269
|
+
}
|
|
270
|
+
});
|
|
271
|
+
}
|
|
272
|
+
else {
|
|
273
|
+
reject('no ap');
|
|
274
|
+
}
|
|
275
|
+
})];
|
|
276
|
+
});
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
var AlipayDowngradePlugin = /** @class */ (function (_super) {
|
|
281
|
+
__extends(AlipayDowngradePlugin, _super);
|
|
282
|
+
function AlipayDowngradePlugin() {
|
|
283
|
+
return _super !== null && _super.apply(this, arguments) || this;
|
|
284
|
+
}
|
|
285
|
+
AlipayDowngradePlugin.onPlayerCreated = function (player) {
|
|
286
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
287
|
+
var result;
|
|
288
|
+
return __generator(this, function (_a) {
|
|
289
|
+
switch (_a.label) {
|
|
290
|
+
case 0:
|
|
291
|
+
if (AlipayDowngradePlugin.glLostOccurred) {
|
|
292
|
+
console.warn('gl lost happened, new player will be destroyed.');
|
|
293
|
+
return [2 /*return*/, player.dispose()];
|
|
294
|
+
}
|
|
295
|
+
if (!AlipayDowngradePlugin.currentBizId) return [3 /*break*/, 2];
|
|
296
|
+
return [4 /*yield*/, checkDowngrade(AlipayDowngradePlugin.currentBizId)];
|
|
297
|
+
case 1:
|
|
298
|
+
result = _a.sent();
|
|
299
|
+
if (result.downgrade) {
|
|
300
|
+
console.warn('automatically destroy downgraded player.');
|
|
301
|
+
player.dispose();
|
|
302
|
+
}
|
|
303
|
+
_a.label = 2;
|
|
304
|
+
case 2: return [2 /*return*/];
|
|
305
|
+
}
|
|
306
|
+
});
|
|
307
|
+
});
|
|
308
|
+
};
|
|
309
|
+
AlipayDowngradePlugin.processRawJSON = function (json, options) {
|
|
310
|
+
var _a, _b;
|
|
311
|
+
if (options === void 0) { options = {}; }
|
|
312
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
313
|
+
var result;
|
|
314
|
+
return __generator(this, function (_c) {
|
|
315
|
+
switch (_c.label) {
|
|
316
|
+
case 0:
|
|
317
|
+
if (AlipayDowngradePlugin.glLostOccurred) {
|
|
318
|
+
return [2 /*return*/, Promise.reject('gl lost happened')];
|
|
319
|
+
}
|
|
320
|
+
return [4 /*yield*/, checkDowngrade((_b = (_a = options.pluginData) === null || _a === void 0 ? void 0 : _a['alipayBizId']) !== null && _b !== void 0 ? _b : AlipayDowngradePlugin.currentBizId)];
|
|
321
|
+
case 1:
|
|
322
|
+
result = _c.sent();
|
|
323
|
+
if (result.downgrade) {
|
|
324
|
+
throw new Error("downgraded, reason: ".concat(result.reason));
|
|
325
|
+
}
|
|
326
|
+
if (!options.renderLevel) {
|
|
327
|
+
options.renderLevel = getRenderLevelByDevice(options.renderLevel);
|
|
328
|
+
}
|
|
329
|
+
return [2 /*return*/];
|
|
330
|
+
}
|
|
331
|
+
});
|
|
332
|
+
});
|
|
333
|
+
};
|
|
334
|
+
AlipayDowngradePlugin.currentBizId = '';
|
|
335
|
+
AlipayDowngradePlugin.glLostOccurred = false;
|
|
336
|
+
return AlipayDowngradePlugin;
|
|
337
|
+
}(effects.AbstractPlugin));
|
|
338
|
+
|
|
339
|
+
var DowngradeVFXItem = /** @class */ (function (_super) {
|
|
340
|
+
__extends(DowngradeVFXItem, _super);
|
|
341
|
+
function DowngradeVFXItem() {
|
|
342
|
+
return _super !== null && _super.apply(this, arguments) || this;
|
|
343
|
+
}
|
|
344
|
+
return DowngradeVFXItem;
|
|
345
|
+
}(effects.VFXItem));
|
|
346
|
+
|
|
347
|
+
/**
|
|
348
|
+
* 将日志写到 native 容器的日志中,便于线上问题排查。
|
|
349
|
+
* 打印的日志可以通过海纳上捞取用户本地日志获得。
|
|
350
|
+
*
|
|
351
|
+
* @example
|
|
352
|
+
* ``` ts
|
|
353
|
+
* // 普通日志,使用方法和console日志一样。
|
|
354
|
+
* nativeLog.log('this is native log from h5.');
|
|
355
|
+
* // 错误日志
|
|
356
|
+
* nativeLog.error('this is native log from h5, error:', error);
|
|
357
|
+
* ```
|
|
358
|
+
*/
|
|
359
|
+
var prefix = '[Galacean Effects Player]';
|
|
360
|
+
function inspectLogger() {
|
|
361
|
+
var info = console.info;
|
|
362
|
+
var warn = console.warn;
|
|
363
|
+
var error = console.error;
|
|
364
|
+
console.error = function (msg) {
|
|
365
|
+
var args = [];
|
|
366
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
367
|
+
args[_i - 1] = arguments[_i];
|
|
368
|
+
}
|
|
369
|
+
error.apply(console, __spreadArray([prefix, msg], __read(args), false));
|
|
370
|
+
nativeLogger.apply(void 0, __spreadArray(['error', msg], __read(args), false));
|
|
371
|
+
};
|
|
372
|
+
console.info = function (msg) {
|
|
373
|
+
var args = [];
|
|
374
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
375
|
+
args[_i - 1] = arguments[_i];
|
|
376
|
+
}
|
|
377
|
+
info.apply(console, __spreadArray([prefix, msg], __read(args), false));
|
|
378
|
+
nativeLogger.apply(void 0, __spreadArray(['info', msg], __read(args), false));
|
|
379
|
+
};
|
|
380
|
+
console.warn = function (msg) {
|
|
381
|
+
var args = [];
|
|
382
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
383
|
+
args[_i - 1] = arguments[_i];
|
|
384
|
+
}
|
|
385
|
+
warn.apply(console, __spreadArray([prefix, msg], __read(args), false));
|
|
386
|
+
nativeLogger.apply(void 0, __spreadArray(['warn', msg], __read(args), false));
|
|
387
|
+
};
|
|
388
|
+
}
|
|
389
|
+
function nativeLogger(type, msg) {
|
|
390
|
+
var args = [];
|
|
391
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
392
|
+
args[_i - 2] = arguments[_i];
|
|
393
|
+
}
|
|
394
|
+
if (effects.isAndroid()) {
|
|
395
|
+
androidLogger.apply(void 0, __spreadArray([type, "".concat(prefix, " ").concat(msg)], __read(args), false));
|
|
396
|
+
}
|
|
397
|
+
else if (effects.isIOS()) {
|
|
398
|
+
iOSLogger.apply(void 0, __spreadArray([type, msg], __read(args), false));
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
function iOSLogger(type, msg) {
|
|
402
|
+
var args = [];
|
|
403
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
404
|
+
args[_i - 2] = arguments[_i];
|
|
405
|
+
}
|
|
406
|
+
try {
|
|
407
|
+
var ap = window.AlipayJSBridge;
|
|
408
|
+
var content = formatMessage.apply(void 0, __spreadArray([type, msg], __read(args), false));
|
|
409
|
+
ap === null || ap === void 0 ? void 0 : ap.call('H5APLog', {
|
|
410
|
+
content: content,
|
|
411
|
+
});
|
|
412
|
+
}
|
|
413
|
+
catch (e) {
|
|
414
|
+
console.error(e);
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
// Android H5 容器支持 console 日志直接写入 aplog
|
|
418
|
+
function androidLogger(type, msg) {
|
|
419
|
+
var args = [];
|
|
420
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
421
|
+
args[_i - 2] = arguments[_i];
|
|
422
|
+
}
|
|
423
|
+
try {
|
|
424
|
+
var ap = window.AlipayJSBridge;
|
|
425
|
+
ap === null || ap === void 0 ? void 0 : ap.call('localLog', {
|
|
426
|
+
'anr_info': 'mars',
|
|
427
|
+
'message': msg + args.join(''),
|
|
428
|
+
'level': type,
|
|
429
|
+
});
|
|
430
|
+
}
|
|
431
|
+
catch (e) {
|
|
432
|
+
console.error(e);
|
|
433
|
+
}
|
|
434
|
+
}
|
|
435
|
+
function formatMessage(level, msg) {
|
|
436
|
+
var args = [];
|
|
437
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
438
|
+
args[_i - 2] = arguments[_i];
|
|
439
|
+
}
|
|
440
|
+
var result = [
|
|
441
|
+
'<MARS_PLAYER>',
|
|
442
|
+
"(".concat(level, "):"),
|
|
443
|
+
msg,
|
|
444
|
+
];
|
|
445
|
+
args.forEach(function (i) {
|
|
446
|
+
result.push(i + '');
|
|
447
|
+
});
|
|
448
|
+
return result.join(' ');
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
var registered = false;
|
|
452
|
+
/**
|
|
453
|
+
* 支付宝端内统一降级方案,传入降级 ID,每次加载场景前都会自动调用降级
|
|
454
|
+
* - 如果要为某个 json 单独配置降级 ID,可以使用 `player.loadScene(url, { pluginData: { alipayBizId: '#bizId#' }})`
|
|
455
|
+
* @param bizId - 降级 ID,如果为 `mock-pass` 将 mock 不降级场景,如果为 `mock-fail` 将 mock 降级场景,业务请不要使用这两个字符串
|
|
456
|
+
* @param options - 优化策略
|
|
457
|
+
*/
|
|
458
|
+
function setAlipayDowngradeBizId(bizId, options) {
|
|
459
|
+
if (options === void 0) { options = {}; }
|
|
460
|
+
var ignoreGLLost = options.ignoreGLLost, autoPause = options.autoPause;
|
|
461
|
+
var downgradeWhenGLLost = ignoreGLLost !== true;
|
|
462
|
+
AlipayDowngradePlugin.currentBizId = bizId;
|
|
463
|
+
if (registered) {
|
|
464
|
+
return;
|
|
465
|
+
}
|
|
466
|
+
effects.registerPlugin('alipay-downgrade', AlipayDowngradePlugin, DowngradeVFXItem, true);
|
|
467
|
+
window.addEventListener('unload', function () {
|
|
468
|
+
effects.getActivePlayers().forEach(function (player) { return player.dispose(); });
|
|
469
|
+
});
|
|
470
|
+
window.addEventListener('webglcontextlost', function (e) {
|
|
471
|
+
if (effects.isCanvasUsedByPlayer(e.target)) {
|
|
472
|
+
AlipayDowngradePlugin.glLostOccurred = true;
|
|
473
|
+
console.error('webgl lost occur');
|
|
474
|
+
if (downgradeWhenGLLost) {
|
|
475
|
+
console.warn('webgl lost occur, all players will be downgraded from now on');
|
|
476
|
+
effects.disableAllPlayer(true);
|
|
477
|
+
effects.getActivePlayers().forEach(function (player) { return player.dispose(); });
|
|
478
|
+
}
|
|
479
|
+
}
|
|
480
|
+
}, true);
|
|
481
|
+
if (autoPause) {
|
|
482
|
+
document.addEventListener('pause', pauseAllActivePlayers);
|
|
483
|
+
document.addEventListener('resume', resumePausedPlayers);
|
|
484
|
+
}
|
|
485
|
+
registered = true;
|
|
486
|
+
inspectLogger();
|
|
487
|
+
void getDeviceName();
|
|
488
|
+
}
|
|
489
|
+
/**
|
|
490
|
+
*
|
|
491
|
+
* @returns
|
|
492
|
+
*/
|
|
493
|
+
function getAlipayDowngradeBizId() {
|
|
494
|
+
return AlipayDowngradePlugin.currentBizId;
|
|
495
|
+
}
|
|
496
|
+
var internalPaused = Symbol('@@_inter_pause');
|
|
497
|
+
function pauseAllActivePlayers(e) {
|
|
498
|
+
if (e.target === document) {
|
|
499
|
+
console.debug('auto pause all players with data offloaded');
|
|
500
|
+
var players = effects.getActivePlayers();
|
|
501
|
+
players.forEach(function (player) {
|
|
502
|
+
if (!player.paused) {
|
|
503
|
+
player.pause({ offloadTexture: true });
|
|
504
|
+
// @ts-expect-error
|
|
505
|
+
player[internalPaused] = true;
|
|
506
|
+
}
|
|
507
|
+
});
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
function resumePausedPlayers(e) {
|
|
511
|
+
if (e.target === document) {
|
|
512
|
+
console.debug('auto resume all players');
|
|
513
|
+
var players = effects.getActivePlayers();
|
|
514
|
+
players.forEach(function (player) {
|
|
515
|
+
// @ts-expect-error
|
|
516
|
+
if (player[internalPaused]) {
|
|
517
|
+
void player.resume();
|
|
518
|
+
// @ts-expect-error
|
|
519
|
+
player[internalPaused] = false;
|
|
520
|
+
}
|
|
521
|
+
});
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
|
|
525
|
+
exports.checkDowngrade = checkDowngrade;
|
|
526
|
+
exports.getAlipayDowngradeBizId = getAlipayDowngradeBizId;
|
|
527
|
+
exports.getDeviceName = getDeviceName;
|
|
528
|
+
exports.getRenderLevelByDevice = getRenderLevelByDevice;
|
|
529
|
+
exports.inspectLogger = inspectLogger;
|
|
530
|
+
exports.resetDevicePending = resetDevicePending;
|
|
531
|
+
exports.setAlipayDowngradeBizId = setAlipayDowngradeBizId;
|
|
532
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Name: @galacean/effects-plugin-alipay-downgrade
|
|
3
|
+
* Description: Galacean Effects player downgrade plugin for Alipay
|
|
4
|
+
* Author: Ant Group CO., Ltd.
|
|
5
|
+
* Contributors: 燃然,意绮
|
|
6
|
+
* Version: v0.0.1-alpha.0
|
|
7
|
+
*/
|
|
8
|
+
!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports,require("@galacean/effects")):"function"==typeof define&&define.amd?define(["exports","@galacean/effects"],n):n(((e="undefined"!=typeof globalThis?globalThis:e||self).ge=e.ge||{},e.ge.alipayDowngradePlugin={}),e.ge)}(this,(function(e,n){"use strict";var r=function(e,n){return r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,n){e.__proto__=n}||function(e,n){for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])},r(e,n)};function o(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Class extends value "+String(n)+" is not a constructor or null");function o(){this.constructor=e}r(e,n),e.prototype=null===n?Object.create(n):(o.prototype=n.prototype,new o)}function t(e,n,r,o){return new(r||(r=Promise))((function(t,i){function a(e){try{l(o.next(e))}catch(e){i(e)}}function c(e){try{l(o.throw(e))}catch(e){i(e)}}function l(e){var n;e.done?t(e.value):(n=e.value,n instanceof r?n:new r((function(e){e(n)}))).then(a,c)}l((o=o.apply(e,n||[])).next())}))}function i(e,n){var r,o,t,i,a={label:0,sent:function(){if(1&t[0])throw t[1];return t[1]},trys:[],ops:[]};return i={next:c(0),throw:c(1),return:c(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function c(c){return function(l){return function(c){if(r)throw new TypeError("Generator is already executing.");for(;i&&(i=0,c[0]&&(a=0)),a;)try{if(r=1,o&&(t=2&c[0]?o.return:c[0]?o.throw||((t=o.return)&&t.call(o),0):o.next)&&!(t=t.call(o,c[1])).done)return t;switch(o=0,t&&(c=[2&c[0],t.value]),c[0]){case 0:case 1:t=c;break;case 4:return a.label++,{value:c[1],done:!1};case 5:a.label++,o=c[1],c=[0];continue;case 7:c=a.ops.pop(),a.trys.pop();continue;default:if(!(t=a.trys,(t=t.length>0&&t[t.length-1])||6!==c[0]&&2!==c[0])){a=0;continue}if(3===c[0]&&(!t||c[1]>t[0]&&c[1]<t[3])){a.label=c[1];break}if(6===c[0]&&a.label<t[1]){a.label=t[1],t=c;break}if(t&&a.label<t[2]){a.label=t[2],a.ops.push(c);break}t[2]&&a.ops.pop(),a.trys.pop();continue}c=n.call(e,a)}catch(e){c=[6,e],o=0}finally{r=t=0}if(5&c[0])throw c[1];return{value:c[0]?c[1]:void 0,done:!0}}([c,l])}}}function a(e,n){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var o,t,i=r.call(e),a=[];try{for(;(void 0===n||n-- >0)&&!(o=i.next()).done;)a.push(o.value)}catch(e){t={error:e}}finally{try{o&&!o.done&&(r=i.return)&&r.call(i)}finally{if(t)throw t.error}}return a}function c(e,n,r){if(r||2===arguments.length)for(var o,t=0,i=n.length;t<i;t++)!o&&t in n||(o||(o=Array.prototype.slice.call(n,0,t)),o[t]=n[t]);return e.concat(o||Array.prototype.slice.call(n))}"function"==typeof SuppressedError&&SuppressedError;var l,u,s="low",d="middle",f="high",p="DESKTOP_DEBUG",v=!1;function y(){return t(this,void 0,void 0,(function(){return i(this,(function(e){return l||(l=function(){return t(this,void 0,void 0,(function(){return i(this,(function(e){return[2,new Promise((function(e,n){var r=window.AlipayJSBridge;r?r.call("getSystemInfo",(function(r){r.error?n(r):e(r)})):n("no ap")}))]}))}))}().then((function(e){var n=e.performance,r=e.platform,o=e.model;if(u||(u=n),v="iOS"===r,/iPhone(\d+),/.test(p=void 0===o?"UNKNOWN_DEVICE":o)&&!u){var t=+RegExp.$1;u=t<=9?s:t<10?d:f}return 0===p.indexOf(e.brand)&&(p=p.replace(e.brand,"").trim()),p}),(function(e){}))),[2,l.then((function(){return p}),(function(){return p}))]}))}))}function g(e){return"auto"!==e&&e?/[ABS]/.test(e)?e:n.spec.RenderLevel.S:u===f?n.spec.RenderLevel.S:u===d?n.spec.RenderLevel.A:u===s?n.spec.RenderLevel.B:v?n.spec.RenderLevel.S:n.spec.RenderLevel.B}var h="mock-fail";function w(e,r){return void 0===r&&(r={}),t(this,void 0,void 0,(function(){var o,t;return i(this,(function(i){return e===h||"mock-pass"===e?[2,Promise.resolve({downgrade:e===h,reason:"mock"})]:(o=window.AlipayJSBridge)?(t=performance.now(),[2,y().then((function(){return new Promise((function(i){var l,p=["mars"],v=r.techPoint;v&&p.push.apply(p,c([],a(v),!1)),(null!==(l=r.callBridge)&&void 0!==l?l:o.call)("getDowngradeResult",{bizId:e,scene:0,ext:{techPoint:p}},(function(e){var r=void 0;if(console.info("downgrade time: ".concat(performance.now()-t,"ms")),e.error)i({downgrade:4!==e.error,reason:"api error:"+e.error});else try{var o=n.isString(e)?JSON.parse(e):e;if("downgradeResultType"in o?r=o.downgradeResultType:"resultType"in o&&(r=o.resultType),e.context){var a=e.context.deviceInfo;if(a){var c=a.deviceLevel;c===f||c===s?u=c:"medium"===c&&(u=d)}}}catch(e){console.error(e)}i(void 0===r?{downgrade:!0,reason:"call downgrade fail"}:{reason:r,downgrade:1===r})}))}))}))]):[2,Promise.resolve({downgrade:!1,reason:"no AP env"})]}))}))}var m=function(e){function n(){return null!==e&&e.apply(this,arguments)||this}return o(n,e),n.onPlayerCreated=function(e){return t(this,void 0,void 0,(function(){return i(this,(function(r){switch(r.label){case 0:return n.glLostOccurred?(console.warn("gl lost happened, new player will be destroyed."),[2,e.dispose()]):n.currentBizId?[4,w(n.currentBizId)]:[3,2];case 1:r.sent().downgrade&&(console.warn("automatically destroy downgraded player."),e.dispose()),r.label=2;case 2:return[2]}}))}))},n.processRawJSON=function(e,r){var o,a;return void 0===r&&(r={}),t(this,void 0,void 0,(function(){var e;return i(this,(function(t){switch(t.label){case 0:return n.glLostOccurred?[2,Promise.reject("gl lost happened")]:[4,w(null!==(a=null===(o=r.pluginData)||void 0===o?void 0:o.alipayBizId)&&void 0!==a?a:n.currentBizId)];case 1:if((e=t.sent()).downgrade)throw new Error("downgraded, reason: ".concat(e.reason));return r.renderLevel||(r.renderLevel=g(r.renderLevel)),[2]}}))}))},n.currentBizId="",n.glLostOccurred=!1,n}(n.AbstractPlugin),b=function(e){function n(){return null!==e&&e.apply(this,arguments)||this}return o(n,e),n}(n.VFXItem),P="[Galacean Effects Player]";function L(){var e=console.info,n=console.warn,r=console.error;console.error=function(e){for(var n=[],o=1;o<arguments.length;o++)n[o-1]=arguments[o];r.apply(console,c([P,e],a(n),!1)),S.apply(void 0,c(["error",e],a(n),!1))},console.info=function(n){for(var r=[],o=1;o<arguments.length;o++)r[o-1]=arguments[o];e.apply(console,c([P,n],a(r),!1)),S.apply(void 0,c(["info",n],a(r),!1))},console.warn=function(e){for(var r=[],o=1;o<arguments.length;o++)r[o-1]=arguments[o];n.apply(console,c([P,e],a(r),!1)),S.apply(void 0,c(["warn",e],a(r),!1))}}function S(e,r){for(var o=[],t=2;t<arguments.length;t++)o[t-2]=arguments[t];n.isAndroid()?E.apply(void 0,c([e,"".concat(P," ").concat(r)],a(o),!1)):n.isIOS()&&A.apply(void 0,c([e,r],a(o),!1))}function A(e,n){for(var r=[],o=2;o<arguments.length;o++)r[o-2]=arguments[o];try{var t=window.AlipayJSBridge,i=B.apply(void 0,c([e,n],a(r),!1));null==t||t.call("H5APLog",{content:i})}catch(e){console.error(e)}}function E(e,n){for(var r=[],o=2;o<arguments.length;o++)r[o-2]=arguments[o];try{var t=window.AlipayJSBridge;null==t||t.call("localLog",{anr_info:"mars",message:n+r.join(""),level:e})}catch(e){console.error(e)}}function B(e,n){for(var r=[],o=2;o<arguments.length;o++)r[o-2]=arguments[o];var t=["<MARS_PLAYER>","(".concat(e,"):"),n];return r.forEach((function(e){t.push(e+"")})),t.join(" ")}var x=!1;var O=Symbol("@@_inter_pause");function _(e){e.target===document&&(console.debug("auto pause all players with data offloaded"),n.getActivePlayers().forEach((function(e){e.paused||(e.pause({offloadTexture:!0}),e[O]=!0)})))}function I(e){e.target===document&&(console.debug("auto resume all players"),n.getActivePlayers().forEach((function(e){e[O]&&(e.resume(),e[O]=!1)})))}e.checkDowngrade=w,e.getAlipayDowngradeBizId=function(){return m.currentBizId},e.getDeviceName=y,e.getRenderLevelByDevice=g,e.inspectLogger=L,e.resetDevicePending=function(){l=void 0},e.setAlipayDowngradeBizId=function(e,r){void 0===r&&(r={});var o=r.ignoreGLLost,t=r.autoPause,i=!0!==o;m.currentBizId=e,x||(n.registerPlugin("alipay-downgrade",m,b,!0),window.addEventListener("unload",(function(){n.getActivePlayers().forEach((function(e){return e.dispose()}))})),window.addEventListener("webglcontextlost",(function(e){n.isCanvasUsedByPlayer(e.target)&&(m.glLostOccurred=!0,console.error("webgl lost occur"),i&&(console.warn("webgl lost occur, all players will be downgraded from now on"),n.disableAllPlayer(!0),n.getActivePlayers().forEach((function(e){return e.dispose()}))))}),!0),t&&(document.addEventListener("pause",_),document.addEventListener("resume",I)),x=!0,L(),y())},Object.defineProperty(e,"__esModule",{value:!0})}));
|
|
9
|
+
//# sourceMappingURL=index.min.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.min.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1,522 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Name: @galacean/effects-plugin-alipay-downgrade
|
|
3
|
+
* Description: Galacean Effects player downgrade plugin for Alipay
|
|
4
|
+
* Author: Ant Group CO., Ltd.
|
|
5
|
+
* Contributors: 燃然,意绮
|
|
6
|
+
* Version: v0.0.1-alpha.0
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import { spec, isString, AbstractPlugin, VFXItem, isAndroid, isIOS as isIOS$1, registerPlugin, getActivePlayers, isCanvasUsedByPlayer, disableAllPlayer } from '@galacean/effects';
|
|
10
|
+
|
|
11
|
+
/******************************************************************************
|
|
12
|
+
Copyright (c) Microsoft Corporation.
|
|
13
|
+
|
|
14
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
15
|
+
purpose with or without fee is hereby granted.
|
|
16
|
+
|
|
17
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
18
|
+
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
19
|
+
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
20
|
+
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
21
|
+
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
22
|
+
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
23
|
+
PERFORMANCE OF THIS SOFTWARE.
|
|
24
|
+
***************************************************************************** */
|
|
25
|
+
/* global Reflect, Promise, SuppressedError, Symbol */
|
|
26
|
+
|
|
27
|
+
var extendStatics = function(d, b) {
|
|
28
|
+
extendStatics = Object.setPrototypeOf ||
|
|
29
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
30
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
31
|
+
return extendStatics(d, b);
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
function __extends(d, b) {
|
|
35
|
+
if (typeof b !== "function" && b !== null)
|
|
36
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
37
|
+
extendStatics(d, b);
|
|
38
|
+
function __() { this.constructor = d; }
|
|
39
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function __awaiter(thisArg, _arguments, P, generator) {
|
|
43
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
44
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
45
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
46
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
47
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
48
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function __generator(thisArg, body) {
|
|
53
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
54
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
55
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
56
|
+
function step(op) {
|
|
57
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
58
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
59
|
+
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;
|
|
60
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
61
|
+
switch (op[0]) {
|
|
62
|
+
case 0: case 1: t = op; break;
|
|
63
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
64
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
65
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
66
|
+
default:
|
|
67
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
68
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
69
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
70
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
71
|
+
if (t[2]) _.ops.pop();
|
|
72
|
+
_.trys.pop(); continue;
|
|
73
|
+
}
|
|
74
|
+
op = body.call(thisArg, _);
|
|
75
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
76
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
function __read(o, n) {
|
|
81
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
82
|
+
if (!m) return o;
|
|
83
|
+
var i = m.call(o), r, ar = [], e;
|
|
84
|
+
try {
|
|
85
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
86
|
+
}
|
|
87
|
+
catch (error) { e = { error: error }; }
|
|
88
|
+
finally {
|
|
89
|
+
try {
|
|
90
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
91
|
+
}
|
|
92
|
+
finally { if (e) throw e.error; }
|
|
93
|
+
}
|
|
94
|
+
return ar;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
function __spreadArray(to, from, pack) {
|
|
98
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
99
|
+
if (ar || !(i in from)) {
|
|
100
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
101
|
+
ar[i] = from[i];
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
|
|
108
|
+
var e = new Error(message);
|
|
109
|
+
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
var DEVICE_PERFORMANCE_LOW = 'low';
|
|
113
|
+
var DEVICE_PERFORMANCE_MIDDLE = 'middle';
|
|
114
|
+
var DEVICE_PERFORMANCE_HIGH = 'high';
|
|
115
|
+
var devicePending;
|
|
116
|
+
var devicePerformance;
|
|
117
|
+
var deviceName = 'DESKTOP_DEBUG';
|
|
118
|
+
var isIOS = false;
|
|
119
|
+
function getDeviceName() {
|
|
120
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
121
|
+
return __generator(this, function (_a) {
|
|
122
|
+
if (!devicePending) {
|
|
123
|
+
devicePending = getSystemInfo().then(function (info) {
|
|
124
|
+
var performance = info.performance, platform = info.platform, _a = info.model, model = _a === void 0 ? 'UNKNOWN_DEVICE' : _a;
|
|
125
|
+
if (!devicePerformance) {
|
|
126
|
+
devicePerformance = performance;
|
|
127
|
+
}
|
|
128
|
+
isIOS = platform === 'iOS';
|
|
129
|
+
deviceName = model;
|
|
130
|
+
if (/iPhone(\d+),/.test(deviceName) && !devicePerformance) {
|
|
131
|
+
var gen = +RegExp.$1;
|
|
132
|
+
// https://gist.github.com/adamawolf/3048717 device code
|
|
133
|
+
if (gen <= 9) { // iphone 7,iphone 7p
|
|
134
|
+
devicePerformance = DEVICE_PERFORMANCE_LOW;
|
|
135
|
+
}
|
|
136
|
+
else if (gen < 10) {
|
|
137
|
+
devicePerformance = DEVICE_PERFORMANCE_MIDDLE;
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
devicePerformance = DEVICE_PERFORMANCE_HIGH;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
if (deviceName.indexOf(info.brand) === 0) {
|
|
144
|
+
deviceName = deviceName.replace(info.brand, '').trim();
|
|
145
|
+
}
|
|
146
|
+
return deviceName;
|
|
147
|
+
}, function (e) {
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
return [2 /*return*/, devicePending.then(function () { return deviceName; }, function () { return deviceName; })];
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
function getRenderLevelByDevice(renderLevel) {
|
|
155
|
+
if (renderLevel === 'auto' || !renderLevel) {
|
|
156
|
+
if (devicePerformance === DEVICE_PERFORMANCE_HIGH) {
|
|
157
|
+
return spec.RenderLevel.S;
|
|
158
|
+
}
|
|
159
|
+
else if (devicePerformance === DEVICE_PERFORMANCE_MIDDLE) {
|
|
160
|
+
return spec.RenderLevel.A;
|
|
161
|
+
}
|
|
162
|
+
else if (devicePerformance === DEVICE_PERFORMANCE_LOW) {
|
|
163
|
+
return spec.RenderLevel.B;
|
|
164
|
+
}
|
|
165
|
+
return isIOS ? spec.RenderLevel.S : spec.RenderLevel.B;
|
|
166
|
+
}
|
|
167
|
+
return /[ABS]/.test(renderLevel) ? renderLevel : spec.RenderLevel.S;
|
|
168
|
+
}
|
|
169
|
+
function resetDevicePending() {
|
|
170
|
+
devicePending = undefined;
|
|
171
|
+
}
|
|
172
|
+
var mockIdPass = 'mock-pass';
|
|
173
|
+
var mockIdFail = 'mock-fail';
|
|
174
|
+
/**
|
|
175
|
+
*
|
|
176
|
+
* @param bizId
|
|
177
|
+
* @param options
|
|
178
|
+
* @returns
|
|
179
|
+
*/
|
|
180
|
+
function checkDowngrade(bizId, options) {
|
|
181
|
+
if (options === void 0) { options = {}; }
|
|
182
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
183
|
+
var ap, now_1;
|
|
184
|
+
return __generator(this, function (_a) {
|
|
185
|
+
if (bizId === mockIdFail || bizId === mockIdPass) {
|
|
186
|
+
return [2 /*return*/, Promise.resolve({ downgrade: bizId === mockIdFail, reason: 'mock' })];
|
|
187
|
+
}
|
|
188
|
+
ap = window.AlipayJSBridge;
|
|
189
|
+
if (ap) {
|
|
190
|
+
now_1 = performance.now();
|
|
191
|
+
return [2 /*return*/, getDeviceName().then(function () {
|
|
192
|
+
return new Promise(function (resolve) {
|
|
193
|
+
var _a;
|
|
194
|
+
var techPoint = ['mars'];
|
|
195
|
+
var tc = options.techPoint;
|
|
196
|
+
if (tc) {
|
|
197
|
+
techPoint.push.apply(techPoint, __spreadArray([], __read(tc), false));
|
|
198
|
+
}
|
|
199
|
+
var callBridge = (_a = options.callBridge) !== null && _a !== void 0 ? _a : ap.call;
|
|
200
|
+
callBridge('getDowngradeResult', {
|
|
201
|
+
bizId: bizId,
|
|
202
|
+
scene: 0,
|
|
203
|
+
ext: {
|
|
204
|
+
techPoint: techPoint,
|
|
205
|
+
},
|
|
206
|
+
}, function (result) {
|
|
207
|
+
var reason = undefined;
|
|
208
|
+
console.info("downgrade time: ".concat(performance.now() - now_1, "ms"));
|
|
209
|
+
if (!result.error) {
|
|
210
|
+
try {
|
|
211
|
+
var ret = isString(result) ? JSON.parse(result) : result;
|
|
212
|
+
if ('downgradeResultType' in ret) {
|
|
213
|
+
reason = ret.downgradeResultType;
|
|
214
|
+
}
|
|
215
|
+
else if ('resultType' in ret) {
|
|
216
|
+
reason = ret.resultType;
|
|
217
|
+
}
|
|
218
|
+
if (result.context) {
|
|
219
|
+
var deviceInfo = result.context.deviceInfo;
|
|
220
|
+
if (deviceInfo) {
|
|
221
|
+
var level = deviceInfo.deviceLevel;
|
|
222
|
+
if (level === DEVICE_PERFORMANCE_HIGH || level === DEVICE_PERFORMANCE_LOW) {
|
|
223
|
+
devicePerformance = level;
|
|
224
|
+
}
|
|
225
|
+
else if (level === 'medium') {
|
|
226
|
+
devicePerformance = DEVICE_PERFORMANCE_MIDDLE;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
catch (ex) {
|
|
232
|
+
console.error(ex);
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
else {
|
|
236
|
+
// 无权调用的情况下不降级
|
|
237
|
+
resolve({ downgrade: result.error !== 4, reason: 'api error:' + result.error });
|
|
238
|
+
}
|
|
239
|
+
if (reason === undefined) {
|
|
240
|
+
resolve({ downgrade: true, reason: 'call downgrade fail' });
|
|
241
|
+
}
|
|
242
|
+
else {
|
|
243
|
+
resolve({ reason: reason, downgrade: reason === 1 });
|
|
244
|
+
}
|
|
245
|
+
});
|
|
246
|
+
});
|
|
247
|
+
})];
|
|
248
|
+
}
|
|
249
|
+
return [2 /*return*/, Promise.resolve({ downgrade: false, reason: 'no AP env' })];
|
|
250
|
+
});
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
function getSystemInfo() {
|
|
254
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
255
|
+
return __generator(this, function (_a) {
|
|
256
|
+
return [2 /*return*/, new Promise(function (resolve, reject) {
|
|
257
|
+
var ap = window.AlipayJSBridge;
|
|
258
|
+
if (ap) {
|
|
259
|
+
ap.call('getSystemInfo', function (e) {
|
|
260
|
+
if (e.error) {
|
|
261
|
+
reject(e);
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
resolve(e);
|
|
265
|
+
}
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
else {
|
|
269
|
+
reject('no ap');
|
|
270
|
+
}
|
|
271
|
+
})];
|
|
272
|
+
});
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
var AlipayDowngradePlugin = /** @class */ (function (_super) {
|
|
277
|
+
__extends(AlipayDowngradePlugin, _super);
|
|
278
|
+
function AlipayDowngradePlugin() {
|
|
279
|
+
return _super !== null && _super.apply(this, arguments) || this;
|
|
280
|
+
}
|
|
281
|
+
AlipayDowngradePlugin.onPlayerCreated = function (player) {
|
|
282
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
283
|
+
var result;
|
|
284
|
+
return __generator(this, function (_a) {
|
|
285
|
+
switch (_a.label) {
|
|
286
|
+
case 0:
|
|
287
|
+
if (AlipayDowngradePlugin.glLostOccurred) {
|
|
288
|
+
console.warn('gl lost happened, new player will be destroyed.');
|
|
289
|
+
return [2 /*return*/, player.dispose()];
|
|
290
|
+
}
|
|
291
|
+
if (!AlipayDowngradePlugin.currentBizId) return [3 /*break*/, 2];
|
|
292
|
+
return [4 /*yield*/, checkDowngrade(AlipayDowngradePlugin.currentBizId)];
|
|
293
|
+
case 1:
|
|
294
|
+
result = _a.sent();
|
|
295
|
+
if (result.downgrade) {
|
|
296
|
+
console.warn('automatically destroy downgraded player.');
|
|
297
|
+
player.dispose();
|
|
298
|
+
}
|
|
299
|
+
_a.label = 2;
|
|
300
|
+
case 2: return [2 /*return*/];
|
|
301
|
+
}
|
|
302
|
+
});
|
|
303
|
+
});
|
|
304
|
+
};
|
|
305
|
+
AlipayDowngradePlugin.processRawJSON = function (json, options) {
|
|
306
|
+
var _a, _b;
|
|
307
|
+
if (options === void 0) { options = {}; }
|
|
308
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
309
|
+
var result;
|
|
310
|
+
return __generator(this, function (_c) {
|
|
311
|
+
switch (_c.label) {
|
|
312
|
+
case 0:
|
|
313
|
+
if (AlipayDowngradePlugin.glLostOccurred) {
|
|
314
|
+
return [2 /*return*/, Promise.reject('gl lost happened')];
|
|
315
|
+
}
|
|
316
|
+
return [4 /*yield*/, checkDowngrade((_b = (_a = options.pluginData) === null || _a === void 0 ? void 0 : _a['alipayBizId']) !== null && _b !== void 0 ? _b : AlipayDowngradePlugin.currentBizId)];
|
|
317
|
+
case 1:
|
|
318
|
+
result = _c.sent();
|
|
319
|
+
if (result.downgrade) {
|
|
320
|
+
throw new Error("downgraded, reason: ".concat(result.reason));
|
|
321
|
+
}
|
|
322
|
+
if (!options.renderLevel) {
|
|
323
|
+
options.renderLevel = getRenderLevelByDevice(options.renderLevel);
|
|
324
|
+
}
|
|
325
|
+
return [2 /*return*/];
|
|
326
|
+
}
|
|
327
|
+
});
|
|
328
|
+
});
|
|
329
|
+
};
|
|
330
|
+
AlipayDowngradePlugin.currentBizId = '';
|
|
331
|
+
AlipayDowngradePlugin.glLostOccurred = false;
|
|
332
|
+
return AlipayDowngradePlugin;
|
|
333
|
+
}(AbstractPlugin));
|
|
334
|
+
|
|
335
|
+
var DowngradeVFXItem = /** @class */ (function (_super) {
|
|
336
|
+
__extends(DowngradeVFXItem, _super);
|
|
337
|
+
function DowngradeVFXItem() {
|
|
338
|
+
return _super !== null && _super.apply(this, arguments) || this;
|
|
339
|
+
}
|
|
340
|
+
return DowngradeVFXItem;
|
|
341
|
+
}(VFXItem));
|
|
342
|
+
|
|
343
|
+
/**
|
|
344
|
+
* 将日志写到 native 容器的日志中,便于线上问题排查。
|
|
345
|
+
* 打印的日志可以通过海纳上捞取用户本地日志获得。
|
|
346
|
+
*
|
|
347
|
+
* @example
|
|
348
|
+
* ``` ts
|
|
349
|
+
* // 普通日志,使用方法和console日志一样。
|
|
350
|
+
* nativeLog.log('this is native log from h5.');
|
|
351
|
+
* // 错误日志
|
|
352
|
+
* nativeLog.error('this is native log from h5, error:', error);
|
|
353
|
+
* ```
|
|
354
|
+
*/
|
|
355
|
+
var prefix = '[Galacean Effects Player]';
|
|
356
|
+
function inspectLogger() {
|
|
357
|
+
var info = console.info;
|
|
358
|
+
var warn = console.warn;
|
|
359
|
+
var error = console.error;
|
|
360
|
+
console.error = function (msg) {
|
|
361
|
+
var args = [];
|
|
362
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
363
|
+
args[_i - 1] = arguments[_i];
|
|
364
|
+
}
|
|
365
|
+
error.apply(console, __spreadArray([prefix, msg], __read(args), false));
|
|
366
|
+
nativeLogger.apply(void 0, __spreadArray(['error', msg], __read(args), false));
|
|
367
|
+
};
|
|
368
|
+
console.info = function (msg) {
|
|
369
|
+
var args = [];
|
|
370
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
371
|
+
args[_i - 1] = arguments[_i];
|
|
372
|
+
}
|
|
373
|
+
info.apply(console, __spreadArray([prefix, msg], __read(args), false));
|
|
374
|
+
nativeLogger.apply(void 0, __spreadArray(['info', msg], __read(args), false));
|
|
375
|
+
};
|
|
376
|
+
console.warn = function (msg) {
|
|
377
|
+
var args = [];
|
|
378
|
+
for (var _i = 1; _i < arguments.length; _i++) {
|
|
379
|
+
args[_i - 1] = arguments[_i];
|
|
380
|
+
}
|
|
381
|
+
warn.apply(console, __spreadArray([prefix, msg], __read(args), false));
|
|
382
|
+
nativeLogger.apply(void 0, __spreadArray(['warn', msg], __read(args), false));
|
|
383
|
+
};
|
|
384
|
+
}
|
|
385
|
+
function nativeLogger(type, msg) {
|
|
386
|
+
var args = [];
|
|
387
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
388
|
+
args[_i - 2] = arguments[_i];
|
|
389
|
+
}
|
|
390
|
+
if (isAndroid()) {
|
|
391
|
+
androidLogger.apply(void 0, __spreadArray([type, "".concat(prefix, " ").concat(msg)], __read(args), false));
|
|
392
|
+
}
|
|
393
|
+
else if (isIOS$1()) {
|
|
394
|
+
iOSLogger.apply(void 0, __spreadArray([type, msg], __read(args), false));
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
function iOSLogger(type, msg) {
|
|
398
|
+
var args = [];
|
|
399
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
400
|
+
args[_i - 2] = arguments[_i];
|
|
401
|
+
}
|
|
402
|
+
try {
|
|
403
|
+
var ap = window.AlipayJSBridge;
|
|
404
|
+
var content = formatMessage.apply(void 0, __spreadArray([type, msg], __read(args), false));
|
|
405
|
+
ap === null || ap === void 0 ? void 0 : ap.call('H5APLog', {
|
|
406
|
+
content: content,
|
|
407
|
+
});
|
|
408
|
+
}
|
|
409
|
+
catch (e) {
|
|
410
|
+
console.error(e);
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
// Android H5 容器支持 console 日志直接写入 aplog
|
|
414
|
+
function androidLogger(type, msg) {
|
|
415
|
+
var args = [];
|
|
416
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
417
|
+
args[_i - 2] = arguments[_i];
|
|
418
|
+
}
|
|
419
|
+
try {
|
|
420
|
+
var ap = window.AlipayJSBridge;
|
|
421
|
+
ap === null || ap === void 0 ? void 0 : ap.call('localLog', {
|
|
422
|
+
'anr_info': 'mars',
|
|
423
|
+
'message': msg + args.join(''),
|
|
424
|
+
'level': type,
|
|
425
|
+
});
|
|
426
|
+
}
|
|
427
|
+
catch (e) {
|
|
428
|
+
console.error(e);
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
function formatMessage(level, msg) {
|
|
432
|
+
var args = [];
|
|
433
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
434
|
+
args[_i - 2] = arguments[_i];
|
|
435
|
+
}
|
|
436
|
+
var result = [
|
|
437
|
+
'<MARS_PLAYER>',
|
|
438
|
+
"(".concat(level, "):"),
|
|
439
|
+
msg,
|
|
440
|
+
];
|
|
441
|
+
args.forEach(function (i) {
|
|
442
|
+
result.push(i + '');
|
|
443
|
+
});
|
|
444
|
+
return result.join(' ');
|
|
445
|
+
}
|
|
446
|
+
|
|
447
|
+
var registered = false;
|
|
448
|
+
/**
|
|
449
|
+
* 支付宝端内统一降级方案,传入降级 ID,每次加载场景前都会自动调用降级
|
|
450
|
+
* - 如果要为某个 json 单独配置降级 ID,可以使用 `player.loadScene(url, { pluginData: { alipayBizId: '#bizId#' }})`
|
|
451
|
+
* @param bizId - 降级 ID,如果为 `mock-pass` 将 mock 不降级场景,如果为 `mock-fail` 将 mock 降级场景,业务请不要使用这两个字符串
|
|
452
|
+
* @param options - 优化策略
|
|
453
|
+
*/
|
|
454
|
+
function setAlipayDowngradeBizId(bizId, options) {
|
|
455
|
+
if (options === void 0) { options = {}; }
|
|
456
|
+
var ignoreGLLost = options.ignoreGLLost, autoPause = options.autoPause;
|
|
457
|
+
var downgradeWhenGLLost = ignoreGLLost !== true;
|
|
458
|
+
AlipayDowngradePlugin.currentBizId = bizId;
|
|
459
|
+
if (registered) {
|
|
460
|
+
return;
|
|
461
|
+
}
|
|
462
|
+
registerPlugin('alipay-downgrade', AlipayDowngradePlugin, DowngradeVFXItem, true);
|
|
463
|
+
window.addEventListener('unload', function () {
|
|
464
|
+
getActivePlayers().forEach(function (player) { return player.dispose(); });
|
|
465
|
+
});
|
|
466
|
+
window.addEventListener('webglcontextlost', function (e) {
|
|
467
|
+
if (isCanvasUsedByPlayer(e.target)) {
|
|
468
|
+
AlipayDowngradePlugin.glLostOccurred = true;
|
|
469
|
+
console.error('webgl lost occur');
|
|
470
|
+
if (downgradeWhenGLLost) {
|
|
471
|
+
console.warn('webgl lost occur, all players will be downgraded from now on');
|
|
472
|
+
disableAllPlayer(true);
|
|
473
|
+
getActivePlayers().forEach(function (player) { return player.dispose(); });
|
|
474
|
+
}
|
|
475
|
+
}
|
|
476
|
+
}, true);
|
|
477
|
+
if (autoPause) {
|
|
478
|
+
document.addEventListener('pause', pauseAllActivePlayers);
|
|
479
|
+
document.addEventListener('resume', resumePausedPlayers);
|
|
480
|
+
}
|
|
481
|
+
registered = true;
|
|
482
|
+
inspectLogger();
|
|
483
|
+
void getDeviceName();
|
|
484
|
+
}
|
|
485
|
+
/**
|
|
486
|
+
*
|
|
487
|
+
* @returns
|
|
488
|
+
*/
|
|
489
|
+
function getAlipayDowngradeBizId() {
|
|
490
|
+
return AlipayDowngradePlugin.currentBizId;
|
|
491
|
+
}
|
|
492
|
+
var internalPaused = Symbol('@@_inter_pause');
|
|
493
|
+
function pauseAllActivePlayers(e) {
|
|
494
|
+
if (e.target === document) {
|
|
495
|
+
console.debug('auto pause all players with data offloaded');
|
|
496
|
+
var players = getActivePlayers();
|
|
497
|
+
players.forEach(function (player) {
|
|
498
|
+
if (!player.paused) {
|
|
499
|
+
player.pause({ offloadTexture: true });
|
|
500
|
+
// @ts-expect-error
|
|
501
|
+
player[internalPaused] = true;
|
|
502
|
+
}
|
|
503
|
+
});
|
|
504
|
+
}
|
|
505
|
+
}
|
|
506
|
+
function resumePausedPlayers(e) {
|
|
507
|
+
if (e.target === document) {
|
|
508
|
+
console.debug('auto resume all players');
|
|
509
|
+
var players = getActivePlayers();
|
|
510
|
+
players.forEach(function (player) {
|
|
511
|
+
// @ts-expect-error
|
|
512
|
+
if (player[internalPaused]) {
|
|
513
|
+
void player.resume();
|
|
514
|
+
// @ts-expect-error
|
|
515
|
+
player[internalPaused] = false;
|
|
516
|
+
}
|
|
517
|
+
});
|
|
518
|
+
}
|
|
519
|
+
}
|
|
520
|
+
|
|
521
|
+
export { checkDowngrade, getAlipayDowngradeBizId, getDeviceName, getRenderLevelByDevice, inspectLogger, resetDevicePending, setAlipayDowngradeBizId };
|
|
522
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 将日志写到 native 容器的日志中,便于线上问题排查。
|
|
3
|
+
* 打印的日志可以通过海纳上捞取用户本地日志获得。
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ``` ts
|
|
7
|
+
* // 普通日志,使用方法和console日志一样。
|
|
8
|
+
* nativeLog.log('this is native log from h5.');
|
|
9
|
+
* // 错误日志
|
|
10
|
+
* nativeLog.error('this is native log from h5, error:', error);
|
|
11
|
+
* ```
|
|
12
|
+
*/
|
|
13
|
+
export declare function inspectLogger(): void;
|
package/dist/utils.d.ts
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { spec } from '@galacean/effects';
|
|
2
|
+
declare global {
|
|
3
|
+
interface Window {
|
|
4
|
+
AlipayJSBridge: any;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
export declare function getDeviceName(): Promise<string>;
|
|
8
|
+
export declare function getRenderLevelByDevice(renderLevel?: spec.RenderLevel | 'auto'): spec.RenderLevel;
|
|
9
|
+
export declare function resetDevicePending(): void;
|
|
10
|
+
interface DowngradeResult {
|
|
11
|
+
downgrade: boolean;
|
|
12
|
+
reason: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
*
|
|
16
|
+
* @param bizId
|
|
17
|
+
* @param options
|
|
18
|
+
* @returns
|
|
19
|
+
*/
|
|
20
|
+
export declare function checkDowngrade(bizId?: string, options?: {
|
|
21
|
+
techPoint?: string[];
|
|
22
|
+
callBridge?: (a: string, option: any, cb: (res: any) => void) => void;
|
|
23
|
+
}): Promise<DowngradeResult>;
|
|
24
|
+
export {};
|
package/package.json
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@galacean/effects-plugin-alipay-downgrade",
|
|
3
|
+
"version": "0.0.1-alpha.0",
|
|
4
|
+
"description": "Galacean Effects player downgrade plugin for Alipay",
|
|
5
|
+
"module": "./dist/index.mjs",
|
|
6
|
+
"main": "./dist/index.js",
|
|
7
|
+
"brower": "./dist/index.min.js",
|
|
8
|
+
"types": "./dist/index.d.ts",
|
|
9
|
+
"files": [
|
|
10
|
+
"dist"
|
|
11
|
+
],
|
|
12
|
+
"exports": {
|
|
13
|
+
".": {
|
|
14
|
+
"import": "./dist/index.mjs",
|
|
15
|
+
"require": "./dist/index.js",
|
|
16
|
+
"types": "./dist/index.d.ts"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"contributors": [
|
|
20
|
+
{
|
|
21
|
+
"name": "燃然"
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
"name": "意绮"
|
|
25
|
+
}
|
|
26
|
+
],
|
|
27
|
+
"author": "Ant Group CO., Ltd.",
|
|
28
|
+
"license": "MIT",
|
|
29
|
+
"publishConfig": {
|
|
30
|
+
"access": "public",
|
|
31
|
+
"registry": "https://registry.npmjs.org"
|
|
32
|
+
},
|
|
33
|
+
"devDependencies": {
|
|
34
|
+
"@galacean/effects": "0.0.1-alpha.0"
|
|
35
|
+
},
|
|
36
|
+
"scripts": {
|
|
37
|
+
"dev": "vite",
|
|
38
|
+
"preview": "concurrently -k \"vite build -w\" \"sleep 6 && vite preview\"",
|
|
39
|
+
"prebuild": "pnpm clean",
|
|
40
|
+
"build": "pnpm build:declaration && pnpm build:module",
|
|
41
|
+
"build:module": "rollup -c",
|
|
42
|
+
"build:declaration": "tsc -d --declarationDir dist --emitDeclarationOnly",
|
|
43
|
+
"build:demo": "rimraf dist && vite build",
|
|
44
|
+
"clean": "rimraf dist && rimraf '*+(.tsbuildinfo)'"
|
|
45
|
+
}
|
|
46
|
+
}
|