@zajno/common 2.7.1 → 2.7.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/cjs/api/call.js +5 -5
- package/cjs/api/call.js.map +1 -1
- package/cjs/api/config.js +30 -5
- package/cjs/api/config.js.map +1 -1
- package/cjs/api/index.js +5 -8
- package/cjs/api/index.js.map +1 -1
- package/cjs/api/interceptor.js +1 -1
- package/cjs/api/logging.js +3 -3
- package/cjs/api/logging.js.map +1 -1
- package/cjs/functions/assert.js +2 -4
- package/cjs/functions/assert.js.map +1 -1
- package/cjs/functions/disposer.js +10 -18
- package/cjs/functions/disposer.js.map +1 -1
- package/cjs/functions/throttle.js +8 -17
- package/cjs/functions/throttle.js.map +1 -1
- package/cjs/localization/LocalizationManager.js +9 -0
- package/cjs/localization/LocalizationManager.js.map +1 -1
- package/cjs/localization/index.js +0 -2
- package/cjs/localization/index.js.map +1 -1
- package/cjs/logger/batch.js +23 -3
- package/cjs/logger/batch.js.map +1 -1
- package/cjs/logger/buffered/base.js +52 -0
- package/cjs/logger/buffered/base.js.map +1 -0
- package/cjs/logger/buffered/buffered.logger.js +40 -0
- package/cjs/logger/buffered/buffered.logger.js.map +1 -0
- package/cjs/logger/buffered/buffered.memory.js +71 -0
- package/cjs/logger/buffered/buffered.memory.js.map +1 -0
- package/cjs/logger/buffered/file/buffered.file.js +43 -0
- package/cjs/logger/buffered/file/buffered.file.js.map +1 -0
- package/cjs/logger/buffered/file/index.js +5 -0
- package/cjs/logger/buffered/file/index.js.map +1 -0
- package/cjs/logger/buffered/index.js +7 -0
- package/cjs/logger/buffered/index.js.map +1 -0
- package/cjs/logger/console.js +1 -39
- package/cjs/logger/console.js.map +1 -1
- package/cjs/logger/empty.js +11 -0
- package/cjs/logger/empty.js.map +1 -0
- package/cjs/logger/index.js +5 -7
- package/cjs/logger/index.js.map +1 -1
- package/cjs/logger/loggable.js +39 -0
- package/cjs/logger/loggable.js.map +1 -0
- package/cjs/logger/manager.js +70 -20
- package/cjs/logger/manager.js.map +1 -1
- package/cjs/logger/named.js +15 -12
- package/cjs/logger/named.js.map +1 -1
- package/cjs/logger/provider.js +33 -0
- package/cjs/logger/provider.js.map +1 -0
- package/cjs/logger/proxy.js +3 -7
- package/cjs/logger/proxy.js.map +1 -1
- package/cjs/logger/types.js +9 -0
- package/cjs/logger/types.js.map +1 -0
- package/cjs/math/arrays.js.map +1 -1
- package/cjs/math/object/ops.composite.js.map +1 -1
- package/cjs/models/LogicModel.js +13 -11
- package/cjs/models/LogicModel.js.map +1 -1
- package/cjs/observing/event.js +5 -18
- package/cjs/observing/event.js.map +1 -1
- package/cjs/observing/event.late.js.map +1 -1
- package/cjs/observing/progressTracker.js +8 -15
- package/cjs/observing/progressTracker.js.map +1 -1
- package/cjs/observing/timer.js.map +1 -1
- package/cjs/observing/transition.js +177 -0
- package/cjs/observing/transition.js.map +1 -0
- package/cjs/structures/path/utils.js +4 -0
- package/cjs/structures/path/utils.js.map +1 -1
- package/cjs/structures/promiseCache.js +14 -20
- package/cjs/structures/promiseCache.js.map +1 -1
- package/cjs/structures/queue/parallel.js +11 -13
- package/cjs/structures/queue/parallel.js.map +1 -1
- package/cjs/structures/subscribersMap.js +9 -7
- package/cjs/structures/subscribersMap.js.map +1 -1
- package/cjs/validation/helpers.js +2 -2
- package/cjs/validation/helpers.js.map +1 -1
- package/cjs/validation/index.js +1 -1
- package/cjs/validation/index.js.map +1 -1
- package/cjs/validation/types.js +0 -9
- package/cjs/validation/types.js.map +1 -1
- package/cjs/validation/validationError.js +12 -0
- package/cjs/validation/validationError.js.map +1 -0
- package/esm/api/builder.js +1 -0
- package/esm/api/builder.js.map +1 -1
- package/esm/api/call.config.js +1 -0
- package/esm/api/call.config.js.map +1 -1
- package/esm/api/call.js +6 -5
- package/esm/api/call.js.map +1 -1
- package/esm/api/call.types.js +1 -1
- package/esm/api/call.types.js.map +1 -1
- package/esm/api/config.js +28 -4
- package/esm/api/config.js.map +1 -1
- package/esm/api/endpoint.types.js +1 -1
- package/esm/api/endpoint.types.js.map +1 -1
- package/esm/api/error.js +1 -0
- package/esm/api/error.js.map +1 -1
- package/esm/api/extensions/contentType.js +1 -0
- package/esm/api/extensions/contentType.js.map +1 -1
- package/esm/api/extensions/validation.js +2 -0
- package/esm/api/extensions/validation.js.map +1 -1
- package/esm/api/index.js +3 -3
- package/esm/api/index.js.map +1 -1
- package/esm/api/interceptor.js +1 -1
- package/esm/api/logging.js +4 -3
- package/esm/api/logging.js.map +1 -1
- package/esm/dates/calc.js +1 -0
- package/esm/dates/calc.js.map +1 -1
- package/esm/dates/format.js +1 -0
- package/esm/dates/format.js.map +1 -1
- package/esm/dates/period.js +1 -0
- package/esm/dates/period.js.map +1 -1
- package/esm/fields/update.js +1 -0
- package/esm/fields/update.js.map +1 -1
- package/esm/functions/assert.js +3 -3
- package/esm/functions/assert.js.map +1 -1
- package/esm/functions/disposer.js +11 -17
- package/esm/functions/disposer.js.map +1 -1
- package/esm/functions/throttle.js +7 -15
- package/esm/functions/throttle.js.map +1 -1
- package/esm/localization/LocalizationManager.js +9 -0
- package/esm/localization/LocalizationManager.js.map +1 -1
- package/esm/localization/defaults/ValidationErrorsLocalization.js +2 -0
- package/esm/localization/defaults/ValidationErrorsLocalization.js.map +1 -1
- package/esm/localization/index.js +0 -1
- package/esm/localization/index.js.map +1 -1
- package/esm/logger/batch.js +23 -3
- package/esm/logger/batch.js.map +1 -1
- package/esm/logger/buffered/base.js +48 -0
- package/esm/logger/buffered/base.js.map +1 -0
- package/esm/logger/buffered/buffered.logger.js +36 -0
- package/esm/logger/buffered/buffered.logger.js.map +1 -0
- package/esm/logger/buffered/buffered.memory.js +67 -0
- package/esm/logger/buffered/buffered.memory.js.map +1 -0
- package/esm/logger/buffered/file/buffered.file.js +38 -0
- package/esm/logger/buffered/file/buffered.file.js.map +1 -0
- package/esm/logger/buffered/file/index.js +2 -0
- package/esm/logger/buffered/file/index.js.map +1 -0
- package/esm/logger/buffered/index.js +4 -0
- package/esm/logger/buffered/index.js.map +1 -0
- package/esm/logger/console.js +0 -37
- package/esm/logger/console.js.map +1 -1
- package/esm/logger/empty.js +7 -0
- package/esm/logger/empty.js.map +1 -0
- package/esm/logger/index.js +3 -7
- package/esm/logger/index.js.map +1 -1
- package/esm/logger/loggable.js +35 -0
- package/esm/logger/loggable.js.map +1 -0
- package/esm/logger/manager.js +70 -20
- package/esm/logger/manager.js.map +1 -1
- package/esm/logger/named.js +8 -4
- package/esm/logger/named.js.map +1 -1
- package/esm/logger/provider.js +29 -0
- package/esm/logger/provider.js.map +1 -0
- package/esm/logger/proxy.js +2 -6
- package/esm/logger/proxy.js.map +1 -1
- package/esm/logger/types.js +6 -0
- package/esm/logger/types.js.map +1 -0
- package/esm/math/arrays.js.map +1 -1
- package/esm/math/object/ops.composite.js.map +1 -1
- package/esm/models/LogicModel.js +13 -11
- package/esm/models/LogicModel.js.map +1 -1
- package/esm/observing/event.js +5 -18
- package/esm/observing/event.js.map +1 -1
- package/esm/observing/event.late.js.map +1 -1
- package/esm/observing/progressTracker.js +9 -14
- package/esm/observing/progressTracker.js.map +1 -1
- package/esm/observing/timer.js.map +1 -1
- package/esm/observing/transition.js +172 -0
- package/esm/observing/transition.js.map +1 -0
- package/esm/structures/path/builder.js +1 -1
- package/esm/structures/path/builder.js.map +1 -1
- package/esm/structures/path/utils.js +4 -0
- package/esm/structures/path/utils.js.map +1 -1
- package/esm/structures/promiseCache.js +14 -20
- package/esm/structures/promiseCache.js.map +1 -1
- package/esm/structures/queue/parallel.js +11 -13
- package/esm/structures/queue/parallel.js.map +1 -1
- package/esm/structures/subscribersMap.js +9 -7
- package/esm/structures/subscribersMap.js.map +1 -1
- package/esm/validation/helpers.js +1 -1
- package/esm/validation/helpers.js.map +1 -1
- package/esm/validation/index.js +1 -1
- package/esm/validation/index.js.map +1 -1
- package/esm/validation/types.js +1 -7
- package/esm/validation/types.js.map +1 -1
- package/esm/validation/validationError.js +8 -0
- package/esm/validation/validationError.js.map +1 -0
- package/package.json +13 -1
- package/tsconfig.cjs.tsbuildinfo +1 -1
- package/tsconfig.esm.tsbuildinfo +1 -1
- package/tsconfig.types.tsbuildinfo +1 -1
- package/types/api/builder.d.ts +1 -1
- package/types/api/call.config.d.ts +1 -1
- package/types/api/call.types.d.ts +2 -2
- package/types/api/config.d.ts +11 -4
- package/types/api/endpoint.types.d.ts +1 -1
- package/types/api/extensions/endpointHooks.d.ts +1 -1
- package/types/api/extensions/validation.d.ts +1 -1
- package/types/api/index.d.ts +3 -3
- package/types/api/interceptor.d.ts +1 -1
- package/types/api/logging.d.ts +8 -6
- package/types/functions/assert.d.ts +3 -3
- package/types/functions/disposer.d.ts +7 -6
- package/types/functions/safe.d.ts +1 -1
- package/types/functions/throttle.d.ts +4 -5
- package/types/localization/LocalizationManager.d.ts +7 -0
- package/types/localization/LocalizedValidationErrors.d.ts +1 -1
- package/types/localization/index.d.ts +1 -1
- package/types/logger/batch.d.ts +3 -2
- package/types/logger/buffered/base.d.ts +23 -0
- package/types/logger/buffered/buffered.logger.d.ts +8 -0
- package/types/logger/buffered/buffered.memory.d.ts +19 -0
- package/types/logger/buffered/file/buffered.file.d.ts +9 -0
- package/types/logger/buffered/file/index.d.ts +1 -0
- package/types/logger/buffered/index.d.ts +3 -0
- package/types/logger/console.d.ts +1 -13
- package/types/logger/empty.d.ts +3 -0
- package/types/logger/index.d.ts +6 -10
- package/types/logger/loggable.d.ts +13 -0
- package/types/logger/manager.d.ts +31 -7
- package/types/logger/named.d.ts +4 -3
- package/types/logger/provider.d.ts +11 -0
- package/types/logger/proxy.d.ts +1 -2
- package/types/logger/types.d.ts +21 -0
- package/types/math/arrays.d.ts +1 -1
- package/types/math/object/helpers.d.ts +2 -2
- package/types/math/object/math.composite.d.ts +3 -3
- package/types/math/object/math.d.ts +2 -2
- package/types/math/object/ops.composite.d.ts +3 -3
- package/types/math/object/ops.d.ts +2 -2
- package/types/math/object/types.d.ts +1 -1
- package/types/models/LogicModel.d.ts +4 -4
- package/types/models/Model.d.ts +1 -1
- package/types/observing/event.d.ts +3 -6
- package/types/observing/event.late.d.ts +1 -1
- package/types/observing/progressTracker.d.ts +3 -4
- package/types/observing/timer.d.ts +2 -2
- package/types/observing/transition.d.ts +40 -0
- package/types/structures/path/builder.d.ts +1 -1
- package/types/structures/path/utils.d.ts +1 -1
- package/types/structures/promiseCache.d.ts +4 -5
- package/types/structures/promiseProxy.d.ts +1 -1
- package/types/structures/queue/parallel.d.ts +3 -3
- package/types/structures/subscribersMap.d.ts +4 -3
- package/types/types/deep.d.ts +1 -1
- package/types/types/functions.d.ts +1 -1
- package/types/types/ident.d.ts +0 -1
- package/types/validation/helpers.d.ts +2 -2
- package/types/validation/index.d.ts +2 -1
- package/types/validation/types.d.ts +1 -5
- package/types/validation/validationError.d.ts +5 -0
- package/types/validation/wrappers.d.ts +1 -1
- package/cjs/logger/abstractions.js +0 -3
- package/cjs/logger/abstractions.js.map +0 -1
- package/cjs/logger/file.js +0 -65
- package/cjs/logger/file.js.map +0 -1
- package/cjs/logger/shared.js +0 -18
- package/cjs/logger/shared.js.map +0 -1
- package/esm/logger/abstractions.js +0 -2
- package/esm/logger/abstractions.js.map +0 -1
- package/esm/logger/file.js +0 -60
- package/esm/logger/file.js.map +0 -1
- package/esm/logger/shared.js +0 -15
- package/esm/logger/shared.js.map +0 -1
- package/types/logger/abstractions.d.ts +0 -10
- package/types/logger/file.d.ts +0 -15
- package/types/logger/shared.d.ts +0 -15
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ops.composite.js","sourceRoot":"","sources":["../../../../src/math/object/ops.composite.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"ops.composite.js","sourceRoot":"","sources":["../../../../src/math/object/ops.composite.ts"],"names":[],"mappings":";;;AAGA,6CAAqD;AAErD,MAAa,kBAAkB;IAClB,KAAK,CAAc;IAEX,IAAI,CAAe;IAEpC,YAAY,QAAwB;QAEhC,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;aAC/B,GAAG,CAAC,IAAI,CAAC,EAAE;YACR,MAAM,MAAM,GAAe;gBACvB,GAAG,EAAE,IAAI,CAAC,CAAC,CAAS;gBACpB,GAAG,EAAE,IAAI,CAAC,CAAC,CAAwB;aACtC,CAAC;YACF,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED,OAAO,CAAC,CAAkB;QACtB,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAA,2BAAc,EAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAClF,CAAC;IAED,QAAQ;QACJ,OAAO,IAAA,kBAAK,EAAC,IAAI,CAAC,IAAI,EAAE,EAAsB,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC3E,CAAC;IAED,KAAK,CAAC,CAAkB;QACpB,OAAO,IAAA,kBAAK,EAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC/B,CAAC;IAED,OAAO,CAAC,CAAkB;QACtB,OAAO,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAA,2BAAc,EAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACzF,CAAC;IAED,QAAQ,CAAC,CAAkB,EAAE,CAAkB;QAC3C,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACX,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAC5C,IAAA,2BAAc,EAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAC3B,IAAA,2BAAc,EAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAC9B,CAAC,CAAC;IACP,CAAC;IAED,MAAM,CAAC,EAAK,EAAE,KAAsB;QAChC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACrB,MAAM,GAAG,GAAG,IAAA,2BAAc,EAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;YAC5C,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;gBACpB,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;YACvB,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;CACJ;AAxDD,gDAwDC"}
|
package/cjs/models/LogicModel.js
CHANGED
|
@@ -4,17 +4,19 @@ exports.ActionResult = exports.LogicModel = void 0;
|
|
|
4
4
|
const Loading_js_1 = require("./Loading.js");
|
|
5
5
|
const index_js_1 = require("../types/index.js");
|
|
6
6
|
const promiseExtended_js_1 = require("../structures/promiseExtended.js");
|
|
7
|
-
const
|
|
8
|
-
class LogicModel {
|
|
7
|
+
const loggable_js_1 = require("../logger/loggable.js");
|
|
8
|
+
class LogicModel extends loggable_js_1.Loggable {
|
|
9
9
|
_loading;
|
|
10
10
|
get isLoading() { return this._loading.isLoading; }
|
|
11
|
-
logger;
|
|
12
11
|
_namedRunners = new Map();
|
|
13
12
|
_runningActionNames = new Set();
|
|
14
|
-
constructor(
|
|
15
|
-
|
|
13
|
+
constructor(useFirstInit = true) {
|
|
14
|
+
super();
|
|
16
15
|
this._loading = this.pureConstructLoadingModel(useFirstInit);
|
|
17
16
|
}
|
|
17
|
+
getLoggerName(name) {
|
|
18
|
+
return `[${name || this.constructor.name}]`;
|
|
19
|
+
}
|
|
18
20
|
pureConstructLoadingModel(useFirstInit) {
|
|
19
21
|
return new Loading_js_1.LoadingModel(useFirstInit);
|
|
20
22
|
}
|
|
@@ -22,7 +24,7 @@ class LogicModel {
|
|
|
22
24
|
const started = Date.now();
|
|
23
25
|
const name = options.name;
|
|
24
26
|
if (name && !options.noLogs) {
|
|
25
|
-
this.logger
|
|
27
|
+
this.logger?.log(`runAction "${name}" started...`);
|
|
26
28
|
}
|
|
27
29
|
const runner = async () => {
|
|
28
30
|
const { exclusive = false, noLoading = false, join } = options;
|
|
@@ -32,13 +34,13 @@ class LogicModel {
|
|
|
32
34
|
if (existingRunner != null) {
|
|
33
35
|
if (join === 'cancel') {
|
|
34
36
|
if (!options.noLogs) {
|
|
35
|
-
this.logger
|
|
37
|
+
this.logger?.warn(`runAction "${name}" has been skipped because another instance of it is in progress`);
|
|
36
38
|
}
|
|
37
39
|
return undefined;
|
|
38
40
|
}
|
|
39
41
|
else if (join === 'merge') {
|
|
40
42
|
if (!options.noLogs) {
|
|
41
|
-
this.logger
|
|
43
|
+
this.logger?.log(`runAction "${name}" merging with existing instance...`);
|
|
42
44
|
}
|
|
43
45
|
return existingRunner;
|
|
44
46
|
}
|
|
@@ -57,7 +59,7 @@ class LogicModel {
|
|
|
57
59
|
if (exclusive === 'throw') {
|
|
58
60
|
throw new Loading_js_1.ExclusiveLoadingError(message, storedName);
|
|
59
61
|
}
|
|
60
|
-
this.logger
|
|
62
|
+
this.logger?.warn(message);
|
|
61
63
|
return undefined;
|
|
62
64
|
}
|
|
63
65
|
result = resultWithLoading.result;
|
|
@@ -66,7 +68,7 @@ class LogicModel {
|
|
|
66
68
|
result = await worker();
|
|
67
69
|
}
|
|
68
70
|
if (name && !options.noLogs) {
|
|
69
|
-
this.logger
|
|
71
|
+
this.logger?.log(`runAction "${storedName}" succeed in ${Date.now() - started}ms`);
|
|
70
72
|
}
|
|
71
73
|
return result;
|
|
72
74
|
}
|
|
@@ -88,7 +90,7 @@ class LogicModel {
|
|
|
88
90
|
};
|
|
89
91
|
return ActionResult.expectExclusive(promiseExtended_js_1.PromiseExtended.run(runner))
|
|
90
92
|
.onError(data => {
|
|
91
|
-
this.logger
|
|
93
|
+
this.logger?.error(...formatError({
|
|
92
94
|
name,
|
|
93
95
|
err: data.source,
|
|
94
96
|
errorCtx,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LogicModel.js","sourceRoot":"","sources":["../../../src/models/LogicModel.ts"],"names":[],"mappings":";;;AAAA,6CAAgF;AAChF,
|
|
1
|
+
{"version":3,"file":"LogicModel.js","sourceRoot":"","sources":["../../../src/models/LogicModel.ts"],"names":[],"mappings":"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"}
|
package/cjs/observing/event.js
CHANGED
|
@@ -3,26 +3,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.Event = void 0;
|
|
4
4
|
exports.oneTimeSubscription = oneTimeSubscription;
|
|
5
5
|
const arrays_js_1 = require("../async/arrays.js");
|
|
6
|
-
const shared_js_1 = require("../logger/shared.js");
|
|
7
6
|
const safe_js_1 = require("../functions/safe.js");
|
|
8
|
-
|
|
7
|
+
const loggable_js_1 = require("../logger/loggable.js");
|
|
8
|
+
class Event extends loggable_js_1.Loggable {
|
|
9
9
|
_handlers = [];
|
|
10
|
-
_logger = null;
|
|
11
|
-
constructor(withDefaultLogger = true) {
|
|
12
|
-
if (withDefaultLogger) {
|
|
13
|
-
this.withLogger('');
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
10
|
get isEmpty() { return this._handlers.length === 0; }
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
this._logger = null;
|
|
20
|
-
return this;
|
|
21
|
-
}
|
|
22
|
-
this._logger = typeof loggerOrName === 'string'
|
|
23
|
-
? (0, shared_js_1.createLogger)(`[Event:${loggerOrName || '?'}]`)
|
|
24
|
-
: loggerOrName;
|
|
25
|
-
return this;
|
|
11
|
+
getLoggerName(name) {
|
|
12
|
+
return `[Event:${name || '?'}]`;
|
|
26
13
|
}
|
|
27
14
|
/** Clears handlers list */
|
|
28
15
|
resetHandlers = () => {
|
|
@@ -80,7 +67,7 @@ class Event {
|
|
|
80
67
|
return this;
|
|
81
68
|
}
|
|
82
69
|
logError(data, cb, err) {
|
|
83
|
-
this.
|
|
70
|
+
this.logger?.error(`type:${typeof data} Handler ${cb.name} thrown an exception: `, err);
|
|
84
71
|
}
|
|
85
72
|
}
|
|
86
73
|
exports.Event = Event;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event.js","sourceRoot":"","sources":["../../../src/observing/event.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"event.js","sourceRoot":"","sources":["../../../src/observing/event.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event.late.js","sourceRoot":"","sources":["../../../src/observing/event.late.ts"],"names":[],"mappings":";;;AAAA,kDAAoD;AACpD,
|
|
1
|
+
{"version":3,"file":"event.late.js","sourceRoot":"","sources":["../../../src/observing/event.late.ts"],"names":[],"mappings":";;;AAAA,kDAAoD;AACpD,yCAAsD;AAEtD;;;;;;;GAOG;AACH,MAAa,gBAA0B,SAAQ,gBAAQ;IAE3C,cAAc,GAAkB,SAAS,CAAC;IAC1C,UAAU,GAAG,KAAK,CAAC;IAE3B,OAAO,CAAC,IAAQ;QACZ,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED,YAAY,CAAC,IAAQ;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO,OAAO,CAAC,OAAO,CAAC,EAAa,CAAC,CAAC;QAC1C,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,OAAO,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,EAAE,CAAC,OAAwB;QACvB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAA,sBAAY,EACR,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC;YACF,iEAAiE;QACrE,CAAC;QAED,OAAO,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAED,qFAAqF;IACrF,KAAK,GAAG,GAAG,EAAE;QACT,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IACpC,CAAC,CAAC;CACL;AA3CD,4CA2CC"}
|
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ProgressTracker = void 0;
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
const MathHelpers = tslib_1.__importStar(require("../math/index.js"));
|
|
7
|
-
const shared_js_1 = tslib_1.__importDefault(require("../logger/shared.js"));
|
|
4
|
+
const decompose_js_1 = require("../dates/decompose.js");
|
|
5
|
+
const arrays_js_1 = require("../math/arrays.js");
|
|
8
6
|
const event_js_1 = require("./event.js");
|
|
9
7
|
class ProgressTracker {
|
|
10
|
-
|
|
8
|
+
logger;
|
|
11
9
|
_firstTimestamp = Date.now();
|
|
12
10
|
_lastTimestamp = null;
|
|
13
11
|
_lastCompleted = null;
|
|
@@ -16,18 +14,13 @@ class ProgressTracker {
|
|
|
16
14
|
_currentProgress = 0;
|
|
17
15
|
_deltas = [];
|
|
18
16
|
_changed = new event_js_1.Event();
|
|
19
|
-
constructor(
|
|
20
|
-
this.
|
|
17
|
+
constructor(logger) {
|
|
18
|
+
this.logger = logger;
|
|
21
19
|
}
|
|
22
20
|
get changed() { return this._changed.expose(); }
|
|
23
21
|
get total() { return this._total; }
|
|
24
22
|
get completed() { return this._completed; }
|
|
25
23
|
get current() { return this._currentProgress; }
|
|
26
|
-
get logger() {
|
|
27
|
-
return this.log === true
|
|
28
|
-
? shared_js_1.default
|
|
29
|
-
: (this.log || null);
|
|
30
|
-
}
|
|
31
24
|
setTotal(total) {
|
|
32
25
|
this._total = total;
|
|
33
26
|
return this;
|
|
@@ -51,10 +44,10 @@ class ProgressTracker {
|
|
|
51
44
|
}
|
|
52
45
|
this._currentProgress = Math.floor(completed / (total || 100) * 100);
|
|
53
46
|
const itemsLeft = total - completed;
|
|
54
|
-
const leftProgressTime = itemsLeft * (
|
|
47
|
+
const leftProgressTime = itemsLeft * ((0, arrays_js_1.arrayAverage)(this._deltas, true) || 1000);
|
|
55
48
|
this._lastTimestamp = Date.now();
|
|
56
49
|
const totalElapsedMs = this._lastTimestamp - this._firstTimestamp;
|
|
57
|
-
if (this.
|
|
50
|
+
if (this.logger) {
|
|
58
51
|
const totalElapsed = msToString(totalElapsedMs);
|
|
59
52
|
const totalEstimated = msToString(leftProgressTime);
|
|
60
53
|
this.logger.log(`Progress: ${completed}/${total} ${totalElapsed}/${totalEstimated} => ${this._currentProgress}%`);
|
|
@@ -70,7 +63,7 @@ class ProgressTracker {
|
|
|
70
63
|
}
|
|
71
64
|
exports.ProgressTracker = ProgressTracker;
|
|
72
65
|
function msToString(ms) {
|
|
73
|
-
const decs =
|
|
66
|
+
const decs = (0, decompose_js_1.decomposeMs)(ms, 'second', 'minute', 'hour');
|
|
74
67
|
const nf = (n) => n.toString().padStart(2, '0');
|
|
75
68
|
return `${nf(decs.hour)}:${nf(decs.minute)}:${nf(decs.second)}`;
|
|
76
69
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"progressTracker.js","sourceRoot":"","sources":["../../../src/observing/progressTracker.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"progressTracker.js","sourceRoot":"","sources":["../../../src/observing/progressTracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"timer.js","sourceRoot":"","sources":["../../../src/observing/timer.ts"],"names":[],"mappings":";;;AAEA,
|
|
1
|
+
{"version":3,"file":"timer.js","sourceRoot":"","sources":["../../../src/observing/timer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TransitionObserver = void 0;
|
|
4
|
+
exports.waitFor = waitFor;
|
|
5
|
+
const event_js_1 = require("./event.js");
|
|
6
|
+
const getter_js_1 = require("../types/getter.js");
|
|
7
|
+
const loggable_js_1 = require("../logger/loggable.js");
|
|
8
|
+
class TransitionObserver extends loggable_js_1.Loggable {
|
|
9
|
+
reaction;
|
|
10
|
+
_event;
|
|
11
|
+
_getter = null;
|
|
12
|
+
_filter = null;
|
|
13
|
+
_disposer;
|
|
14
|
+
_prev;
|
|
15
|
+
_from;
|
|
16
|
+
_to;
|
|
17
|
+
_cb;
|
|
18
|
+
_fireOnce = false;
|
|
19
|
+
_promise;
|
|
20
|
+
_promiseReject;
|
|
21
|
+
constructor(reaction, getter) {
|
|
22
|
+
super();
|
|
23
|
+
this.reaction = reaction;
|
|
24
|
+
if (getter) {
|
|
25
|
+
this.observe(getter);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
get event() {
|
|
29
|
+
// lazy created just to save up some memory in case it's not needed
|
|
30
|
+
if (!this._event) {
|
|
31
|
+
this._event = new event_js_1.Event().setLogger(this.logger);
|
|
32
|
+
}
|
|
33
|
+
return this._event;
|
|
34
|
+
}
|
|
35
|
+
get currentValue() { return this._prev; }
|
|
36
|
+
get isObserving() { return this._disposer != null; }
|
|
37
|
+
get isPromising() { return this._promiseReject != null; }
|
|
38
|
+
observe(getter) {
|
|
39
|
+
this.dispose();
|
|
40
|
+
this._getter = getter;
|
|
41
|
+
this._prev = this._getter();
|
|
42
|
+
this._disposer = this.reaction(this._getter, this._checkValue);
|
|
43
|
+
return this;
|
|
44
|
+
}
|
|
45
|
+
from(from) {
|
|
46
|
+
this._from = from;
|
|
47
|
+
return this;
|
|
48
|
+
}
|
|
49
|
+
to(to) {
|
|
50
|
+
this._to = to;
|
|
51
|
+
return this;
|
|
52
|
+
}
|
|
53
|
+
filter(filter) {
|
|
54
|
+
this._filter = filter;
|
|
55
|
+
return this;
|
|
56
|
+
}
|
|
57
|
+
cb(cb) {
|
|
58
|
+
if (this.isPromising) {
|
|
59
|
+
throw new Error('Cannot set callback when promise is running');
|
|
60
|
+
}
|
|
61
|
+
this._cb = cb;
|
|
62
|
+
return this;
|
|
63
|
+
}
|
|
64
|
+
forceCall() {
|
|
65
|
+
if (this._cb) {
|
|
66
|
+
this._cb(this._prev);
|
|
67
|
+
}
|
|
68
|
+
return this;
|
|
69
|
+
}
|
|
70
|
+
fireOnce(enable = true) {
|
|
71
|
+
this._fireOnce = enable;
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
forceCheck() {
|
|
75
|
+
if (!this._getter) {
|
|
76
|
+
return false;
|
|
77
|
+
}
|
|
78
|
+
return this._checkValue(this._getter());
|
|
79
|
+
}
|
|
80
|
+
andForceCheck() {
|
|
81
|
+
this.forceCheck();
|
|
82
|
+
return this;
|
|
83
|
+
}
|
|
84
|
+
getPromise(timeout = null) {
|
|
85
|
+
if (this._promise == null) {
|
|
86
|
+
if (!this.isObserving) {
|
|
87
|
+
return Promise.reject(new Error('Cannot get promise for disposed TransitionObserver'));
|
|
88
|
+
}
|
|
89
|
+
this._promise = new Promise((resolve, reject) => {
|
|
90
|
+
this._promiseReject = reject;
|
|
91
|
+
let timeoutHandle = null;
|
|
92
|
+
if (timeout) {
|
|
93
|
+
timeoutHandle = setTimeout(() => {
|
|
94
|
+
this._finishPromise(reject, new Error(`TransitionObserver Aborted – timed out after ${timeout}ms`));
|
|
95
|
+
}, timeout);
|
|
96
|
+
}
|
|
97
|
+
this._cb = (v => {
|
|
98
|
+
clearTimeout(timeoutHandle);
|
|
99
|
+
this._finishPromise(resolve, v);
|
|
100
|
+
});
|
|
101
|
+
this.forceCheck();
|
|
102
|
+
});
|
|
103
|
+
this.logger?.log('started a new promise...');
|
|
104
|
+
}
|
|
105
|
+
return this._promise;
|
|
106
|
+
}
|
|
107
|
+
reverse() {
|
|
108
|
+
if (!this._getter) {
|
|
109
|
+
throw new Error('Cannot reverse TransitionObserver without getter being set');
|
|
110
|
+
}
|
|
111
|
+
return new TransitionObserver(this.reaction, this._getter)
|
|
112
|
+
.from(this._to)
|
|
113
|
+
.to(this._from);
|
|
114
|
+
}
|
|
115
|
+
dispose = () => {
|
|
116
|
+
this.logger?.log(' disposing... ');
|
|
117
|
+
if (this._disposer) {
|
|
118
|
+
this._disposer();
|
|
119
|
+
this._disposer = undefined;
|
|
120
|
+
}
|
|
121
|
+
if (this.isPromising) {
|
|
122
|
+
this._finishPromise(this._promiseReject ?? (() => { }), new Error('TransitionObserver Aborted'));
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
_checkValue = (v) => {
|
|
126
|
+
let trigger = false;
|
|
127
|
+
const from = getter_js_1.Getter.getValue(this._from);
|
|
128
|
+
const to = getter_js_1.Getter.getValue(this._to);
|
|
129
|
+
if (this._filter && !this._filter(v, this._prev)) {
|
|
130
|
+
trigger = false;
|
|
131
|
+
}
|
|
132
|
+
else if (from !== undefined && to !== undefined) {
|
|
133
|
+
// both 'from' and 'two' should be matched
|
|
134
|
+
trigger = this._prev === from && v === to;
|
|
135
|
+
}
|
|
136
|
+
else if (from !== undefined || to !== undefined) {
|
|
137
|
+
// at least one match – 'from' or 'to'
|
|
138
|
+
trigger = (from !== undefined && from === this._prev)
|
|
139
|
+
|| (to !== undefined && to === v);
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
// if both 'from' and 'to' are undefined – trigger for any change
|
|
143
|
+
// this._from === undefined && this._to === undefined;
|
|
144
|
+
trigger = true;
|
|
145
|
+
}
|
|
146
|
+
this.logger?.log('Checked value:', v, ' ==> will trigger:', trigger);
|
|
147
|
+
this._prev = v;
|
|
148
|
+
if (trigger) {
|
|
149
|
+
// will actually trigger only if someone subscribed to the event
|
|
150
|
+
// Use triggerAsync to catch and log all errors
|
|
151
|
+
this._event?.triggerAsync(v);
|
|
152
|
+
if (this._cb) {
|
|
153
|
+
this._cb(v);
|
|
154
|
+
}
|
|
155
|
+
if (this._fireOnce) {
|
|
156
|
+
this.dispose();
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
return trigger;
|
|
160
|
+
};
|
|
161
|
+
_finishPromise(cb, arg) {
|
|
162
|
+
this._promise = null;
|
|
163
|
+
this._promiseReject = null;
|
|
164
|
+
this._cb = null;
|
|
165
|
+
if (cb) {
|
|
166
|
+
cb(arg);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
exports.TransitionObserver = TransitionObserver;
|
|
171
|
+
function waitFor(reaction, current, toBe) {
|
|
172
|
+
return new TransitionObserver(reaction, current)
|
|
173
|
+
.to(toBe)
|
|
174
|
+
.fireOnce()
|
|
175
|
+
.getPromise();
|
|
176
|
+
}
|
|
177
|
+
//# sourceMappingURL=transition.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transition.js","sourceRoot":"","sources":["../../../src/observing/transition.ts"],"names":[],"mappings":"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"}
|
|
@@ -44,6 +44,10 @@ function combineUrls(...parts) {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
let result = _parts.join(separator);
|
|
47
|
+
// edge case: for empty result if both start/end separators requested – add only one
|
|
48
|
+
if (!result && (options?.addStart === true || options?.addTrail === true)) {
|
|
49
|
+
return separator;
|
|
50
|
+
}
|
|
47
51
|
if (options?.addTrail) {
|
|
48
52
|
const char = typeof options.addTrail === 'string'
|
|
49
53
|
? options.addTrail
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/structures/path/utils.ts"],"names":[],"mappings":";;;AAEA,8BAgBC;AAoBD,
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/structures/path/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.PromiseCache = exports.DeferredGetter = void 0;
|
|
4
4
|
const throttle_js_1 = require("../functions/throttle.js");
|
|
5
|
-
const
|
|
5
|
+
const loggable_js_1 = require("../logger/loggable.js");
|
|
6
6
|
const Model_js_1 = require("../models/Model.js");
|
|
7
7
|
var DeferredGetter;
|
|
8
8
|
(function (DeferredGetter) {
|
|
@@ -21,7 +21,7 @@ const BATCHING_DELAY = 200;
|
|
|
21
21
|
* - batching of fetches.
|
|
22
22
|
* - auto-invalidation of cached items.
|
|
23
23
|
*/
|
|
24
|
-
class PromiseCache {
|
|
24
|
+
class PromiseCache extends loggable_js_1.Loggable {
|
|
25
25
|
fetcher;
|
|
26
26
|
keyAdapter;
|
|
27
27
|
keyParser;
|
|
@@ -33,9 +33,9 @@ class PromiseCache {
|
|
|
33
33
|
_batch = null;
|
|
34
34
|
_invalidationTimeMs = null;
|
|
35
35
|
_keepInstanceDuringInvalidation = false;
|
|
36
|
-
_logger = null;
|
|
37
36
|
_version = 0;
|
|
38
37
|
constructor(fetcher, keyAdapter, keyParser) {
|
|
38
|
+
super();
|
|
39
39
|
this.fetcher = fetcher;
|
|
40
40
|
this.keyAdapter = keyAdapter;
|
|
41
41
|
this.keyParser = keyParser;
|
|
@@ -69,14 +69,8 @@ class PromiseCache {
|
|
|
69
69
|
}
|
|
70
70
|
return this.keyAdapter(k);
|
|
71
71
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
this._logger = nameOrLogger;
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
this._logger = (0, shared_js_1.createLogger)(`[PromiseCache:${nameOrLogger || '?'}]`);
|
|
78
|
-
}
|
|
79
|
-
return this;
|
|
72
|
+
getLoggerName(name) {
|
|
73
|
+
return `[PromiseCache:${name || '?'}]`;
|
|
80
74
|
}
|
|
81
75
|
/**
|
|
82
76
|
* Provide a fetcher function that takes multiple ids and returns multiple results at once. Will be called with a slight delay to allow multiple ids to be collected.
|
|
@@ -123,7 +117,7 @@ class PromiseCache {
|
|
|
123
117
|
// make sure current item is hooked here from the cache (required by observers)
|
|
124
118
|
const item = this._itemsCache.get(key);
|
|
125
119
|
if (isInvalid) {
|
|
126
|
-
this.
|
|
120
|
+
this.logger?.log(key, 'item is invalidated');
|
|
127
121
|
}
|
|
128
122
|
return {
|
|
129
123
|
item: (isInvalid && !this._keepInstanceDuringInvalidation) ? undefined : item,
|
|
@@ -137,19 +131,19 @@ class PromiseCache {
|
|
|
137
131
|
// spin fetch
|
|
138
132
|
this.get(id);
|
|
139
133
|
}
|
|
140
|
-
this.
|
|
134
|
+
this.logger?.log(key, 'getCurrent: returns', item);
|
|
141
135
|
return item;
|
|
142
136
|
}
|
|
143
137
|
get(id) {
|
|
144
138
|
const { item, key, isInvalid } = this._getCurrent(id);
|
|
145
139
|
// return cached item if it's not invalidated
|
|
146
140
|
if (item !== undefined && !isInvalid) {
|
|
147
|
-
this.
|
|
141
|
+
this.logger?.log(key, 'get: item resolved to', item, isInvalid ? '(invalidated)' : '');
|
|
148
142
|
return Promise.resolve(item);
|
|
149
143
|
}
|
|
150
144
|
let promise = this._fetchCache.get(key);
|
|
151
145
|
if (promise != null) {
|
|
152
|
-
this.
|
|
146
|
+
this.logger?.log(key, 'get: item resolved to <promise>');
|
|
153
147
|
return promise;
|
|
154
148
|
}
|
|
155
149
|
this.setStatus(key, true);
|
|
@@ -169,7 +163,7 @@ class PromiseCache {
|
|
|
169
163
|
return res;
|
|
170
164
|
}
|
|
171
165
|
if (this._fetchCache.get(key) != null) {
|
|
172
|
-
this.
|
|
166
|
+
this.logger?.log(key, 'item\'s <promise> resolved to', res);
|
|
173
167
|
res = this.prepareResult(res);
|
|
174
168
|
this.storeResult(key, res);
|
|
175
169
|
}
|
|
@@ -180,7 +174,7 @@ class PromiseCache {
|
|
|
180
174
|
this.onFetchComplete(key);
|
|
181
175
|
}
|
|
182
176
|
else {
|
|
183
|
-
this.
|
|
177
|
+
this.logger?.log(key, 'skipping item\'s resolve due to version change ("clear()" has been called)');
|
|
184
178
|
}
|
|
185
179
|
}
|
|
186
180
|
};
|
|
@@ -239,7 +233,7 @@ class PromiseCache {
|
|
|
239
233
|
}
|
|
240
234
|
/** @override */
|
|
241
235
|
setStatus(key, status) {
|
|
242
|
-
this.
|
|
236
|
+
this.logger?.log(key, 'status update:', status);
|
|
243
237
|
this._itemsStatus.set(key, status);
|
|
244
238
|
}
|
|
245
239
|
/** @override */
|
|
@@ -268,7 +262,7 @@ class PromiseCache {
|
|
|
268
262
|
/** @pure */
|
|
269
263
|
async tryFetchInBatch(id) {
|
|
270
264
|
const fetchWrap = () => this.fetcher(id).catch(err => {
|
|
271
|
-
this.
|
|
265
|
+
this.logger?.warn('fetcher failed', id, err);
|
|
272
266
|
return null;
|
|
273
267
|
});
|
|
274
268
|
if (!this._batch) {
|
|
@@ -276,7 +270,7 @@ class PromiseCache {
|
|
|
276
270
|
}
|
|
277
271
|
const res = await this._batch.push(id)
|
|
278
272
|
.catch(err => {
|
|
279
|
-
this.
|
|
273
|
+
this.logger?.warn('batch fetch failed', id, err);
|
|
280
274
|
return null;
|
|
281
275
|
});
|
|
282
276
|
if (!res || !res.result || res.result[res.index] === undefined) {
|