@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,9 +1,9 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
1
|
+
import { decomposeMs } from '../dates/decompose.js';
|
|
2
|
+
import {} from '../logger/index.js';
|
|
3
|
+
import { arrayAverage } from '../math/arrays.js';
|
|
4
4
|
import { Event } from './event.js';
|
|
5
5
|
export class ProgressTracker {
|
|
6
|
-
|
|
6
|
+
logger;
|
|
7
7
|
_firstTimestamp = Date.now();
|
|
8
8
|
_lastTimestamp = null;
|
|
9
9
|
_lastCompleted = null;
|
|
@@ -12,18 +12,13 @@ export class ProgressTracker {
|
|
|
12
12
|
_currentProgress = 0;
|
|
13
13
|
_deltas = [];
|
|
14
14
|
_changed = new Event();
|
|
15
|
-
constructor(
|
|
16
|
-
this.
|
|
15
|
+
constructor(logger) {
|
|
16
|
+
this.logger = logger;
|
|
17
17
|
}
|
|
18
18
|
get changed() { return this._changed.expose(); }
|
|
19
19
|
get total() { return this._total; }
|
|
20
20
|
get completed() { return this._completed; }
|
|
21
21
|
get current() { return this._currentProgress; }
|
|
22
|
-
get logger() {
|
|
23
|
-
return this.log === true
|
|
24
|
-
? logger
|
|
25
|
-
: (this.log || null);
|
|
26
|
-
}
|
|
27
22
|
setTotal(total) {
|
|
28
23
|
this._total = total;
|
|
29
24
|
return this;
|
|
@@ -47,10 +42,10 @@ export class ProgressTracker {
|
|
|
47
42
|
}
|
|
48
43
|
this._currentProgress = Math.floor(completed / (total || 100) * 100);
|
|
49
44
|
const itemsLeft = total - completed;
|
|
50
|
-
const leftProgressTime = itemsLeft * (
|
|
45
|
+
const leftProgressTime = itemsLeft * (arrayAverage(this._deltas, true) || 1000);
|
|
51
46
|
this._lastTimestamp = Date.now();
|
|
52
47
|
const totalElapsedMs = this._lastTimestamp - this._firstTimestamp;
|
|
53
|
-
if (this.
|
|
48
|
+
if (this.logger) {
|
|
54
49
|
const totalElapsed = msToString(totalElapsedMs);
|
|
55
50
|
const totalEstimated = msToString(leftProgressTime);
|
|
56
51
|
this.logger.log(`Progress: ${completed}/${total} ${totalElapsed}/${totalEstimated} => ${this._currentProgress}%`);
|
|
@@ -65,7 +60,7 @@ export class ProgressTracker {
|
|
|
65
60
|
}
|
|
66
61
|
}
|
|
67
62
|
function msToString(ms) {
|
|
68
|
-
const decs =
|
|
63
|
+
const decs = decomposeMs(ms, 'second', 'minute', 'hour');
|
|
69
64
|
const nf = (n) => n.toString().padStart(2, '0');
|
|
70
65
|
return `${nf(decs.hour)}:${nf(decs.minute)}:${nf(decs.second)}`;
|
|
71
66
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"progressTracker.js","sourceRoot":"","sources":["../../../src/observing/progressTracker.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
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,OAAO,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"timer.js","sourceRoot":"","sources":["../../../src/observing/timer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAkC,MAAM,YAAY,CAAC;AASnE;;;;GAIG;AACH,MAAM,OAAO,KAAK;IAiBO;IAhBJ,MAAM,GAAG,IAAI,KAAK,EAAc,CAAC;IACjC,WAAW,GAAG,IAAI,KAAK,EAAc,CAAC;IAE/C,IAAI,GAAW,IAAI,CAAC,GAAG,EAAE,CAAC;IAE1B,QAAQ,GAAW,CAAC,CAAC;IACrB,KAAK,CAAmB;IAExB,SAAS,CAAmB;IAE5B,OAAO,GAA0C,IAAI,CAAC;IAE9D;;;OAGG;IACH,YAAqB,WAAW,IAAI,GAAG,IAAI,EAAE,KAAK,GAAG,IAAI;QAApC,aAAQ,GAAR,QAAQ,CAAc;QACvC,IAAI,KAAK,EAAE,CAAC;YACR,IAAI,CAAC,OAAO,EAAE,CAAC;QACnB,CAAC;IACL,CAAC;IAED,+CAA+C;IAC/C,IAAI,GAAG,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC/B,2FAA2F;IAC3F,IAAI,QAAQ,KAAK,OAAO,IAAI,CAAC,SAAS,IAAI,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACpE,uDAAuD;IACvD,IAAI,OAAO,KAAK,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACvC,2FAA2F;IAC3F,IAAI,IAAI,KAAK,OAAO,IAAI,CAAC,KAAK,IAAI,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAE5D,4DAA4D;IAC5D,IAAI,UAAU,KAAK,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAEtD,mGAAmG;IACnG,YAAY,CAAC,QAAgB;QACzB,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;QACtB,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,EAAE,CAAC,OAAiC;QAChC,OAAO,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC;IAED,GAAG,CAAC,OAAiC;QACjC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC;IAED,4BAA4B;IACrB,OAAO;QACV,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;QAClB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;QAE5B,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;QAE5B,MAAM,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC;YACpB,KAAK,EAAE,IAAI;YACX,OAAO,EAAE,IAAI,CAAC,QAAQ;YACtB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,GAAG,EAAE,IAAI,CAAC,IAAI;SACjB,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,CAAC,SAAS,GAAG,KAAK,EAAE,EAAE;YACjC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,GAAG,GAAG,SAAS,CAAC;YAChC,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC;YAEhB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS;gBACvB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC;gBAC7C,CAAC,CAAC,IAAI,CAAC;YAEX,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;YAEhC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC;gBACtD,IAAI,CAAC,OAAO,EAAE,CAAC;gBACf,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;YACzC,CAAC;QACL,CAAC,CAAC;QAEF,+BAA+B;QAC/B,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1D,MAAM,CAAC,IAAI,CAAC,CAAC;IACjB,CAAC;IAED,uDAAuD;IAChD,OAAO;QACV,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChC,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACxB,CAAC;CACJ"}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { Event } from './event.js';
|
|
2
|
+
import { Getter } from '../types/getter.js';
|
|
3
|
+
import { Loggable } from '../logger/loggable.js';
|
|
4
|
+
export class TransitionObserver extends Loggable {
|
|
5
|
+
reaction;
|
|
6
|
+
_event;
|
|
7
|
+
_getter = null;
|
|
8
|
+
_filter = null;
|
|
9
|
+
_disposer;
|
|
10
|
+
_prev;
|
|
11
|
+
_from;
|
|
12
|
+
_to;
|
|
13
|
+
_cb;
|
|
14
|
+
_fireOnce = false;
|
|
15
|
+
_promise;
|
|
16
|
+
_promiseReject;
|
|
17
|
+
constructor(reaction, getter) {
|
|
18
|
+
super();
|
|
19
|
+
this.reaction = reaction;
|
|
20
|
+
if (getter) {
|
|
21
|
+
this.observe(getter);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
get event() {
|
|
25
|
+
// lazy created just to save up some memory in case it's not needed
|
|
26
|
+
if (!this._event) {
|
|
27
|
+
this._event = new Event().setLogger(this.logger);
|
|
28
|
+
}
|
|
29
|
+
return this._event;
|
|
30
|
+
}
|
|
31
|
+
get currentValue() { return this._prev; }
|
|
32
|
+
get isObserving() { return this._disposer != null; }
|
|
33
|
+
get isPromising() { return this._promiseReject != null; }
|
|
34
|
+
observe(getter) {
|
|
35
|
+
this.dispose();
|
|
36
|
+
this._getter = getter;
|
|
37
|
+
this._prev = this._getter();
|
|
38
|
+
this._disposer = this.reaction(this._getter, this._checkValue);
|
|
39
|
+
return this;
|
|
40
|
+
}
|
|
41
|
+
from(from) {
|
|
42
|
+
this._from = from;
|
|
43
|
+
return this;
|
|
44
|
+
}
|
|
45
|
+
to(to) {
|
|
46
|
+
this._to = to;
|
|
47
|
+
return this;
|
|
48
|
+
}
|
|
49
|
+
filter(filter) {
|
|
50
|
+
this._filter = filter;
|
|
51
|
+
return this;
|
|
52
|
+
}
|
|
53
|
+
cb(cb) {
|
|
54
|
+
if (this.isPromising) {
|
|
55
|
+
throw new Error('Cannot set callback when promise is running');
|
|
56
|
+
}
|
|
57
|
+
this._cb = cb;
|
|
58
|
+
return this;
|
|
59
|
+
}
|
|
60
|
+
forceCall() {
|
|
61
|
+
if (this._cb) {
|
|
62
|
+
this._cb(this._prev);
|
|
63
|
+
}
|
|
64
|
+
return this;
|
|
65
|
+
}
|
|
66
|
+
fireOnce(enable = true) {
|
|
67
|
+
this._fireOnce = enable;
|
|
68
|
+
return this;
|
|
69
|
+
}
|
|
70
|
+
forceCheck() {
|
|
71
|
+
if (!this._getter) {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
return this._checkValue(this._getter());
|
|
75
|
+
}
|
|
76
|
+
andForceCheck() {
|
|
77
|
+
this.forceCheck();
|
|
78
|
+
return this;
|
|
79
|
+
}
|
|
80
|
+
getPromise(timeout = null) {
|
|
81
|
+
if (this._promise == null) {
|
|
82
|
+
if (!this.isObserving) {
|
|
83
|
+
return Promise.reject(new Error('Cannot get promise for disposed TransitionObserver'));
|
|
84
|
+
}
|
|
85
|
+
this._promise = new Promise((resolve, reject) => {
|
|
86
|
+
this._promiseReject = reject;
|
|
87
|
+
let timeoutHandle = null;
|
|
88
|
+
if (timeout) {
|
|
89
|
+
timeoutHandle = setTimeout(() => {
|
|
90
|
+
this._finishPromise(reject, new Error(`TransitionObserver Aborted – timed out after ${timeout}ms`));
|
|
91
|
+
}, timeout);
|
|
92
|
+
}
|
|
93
|
+
this._cb = (v => {
|
|
94
|
+
clearTimeout(timeoutHandle);
|
|
95
|
+
this._finishPromise(resolve, v);
|
|
96
|
+
});
|
|
97
|
+
this.forceCheck();
|
|
98
|
+
});
|
|
99
|
+
this.logger?.log('started a new promise...');
|
|
100
|
+
}
|
|
101
|
+
return this._promise;
|
|
102
|
+
}
|
|
103
|
+
reverse() {
|
|
104
|
+
if (!this._getter) {
|
|
105
|
+
throw new Error('Cannot reverse TransitionObserver without getter being set');
|
|
106
|
+
}
|
|
107
|
+
return new TransitionObserver(this.reaction, this._getter)
|
|
108
|
+
.from(this._to)
|
|
109
|
+
.to(this._from);
|
|
110
|
+
}
|
|
111
|
+
dispose = () => {
|
|
112
|
+
this.logger?.log(' disposing... ');
|
|
113
|
+
if (this._disposer) {
|
|
114
|
+
this._disposer();
|
|
115
|
+
this._disposer = undefined;
|
|
116
|
+
}
|
|
117
|
+
if (this.isPromising) {
|
|
118
|
+
this._finishPromise(this._promiseReject ?? (() => { }), new Error('TransitionObserver Aborted'));
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
_checkValue = (v) => {
|
|
122
|
+
let trigger = false;
|
|
123
|
+
const from = Getter.getValue(this._from);
|
|
124
|
+
const to = Getter.getValue(this._to);
|
|
125
|
+
if (this._filter && !this._filter(v, this._prev)) {
|
|
126
|
+
trigger = false;
|
|
127
|
+
}
|
|
128
|
+
else if (from !== undefined && to !== undefined) {
|
|
129
|
+
// both 'from' and 'two' should be matched
|
|
130
|
+
trigger = this._prev === from && v === to;
|
|
131
|
+
}
|
|
132
|
+
else if (from !== undefined || to !== undefined) {
|
|
133
|
+
// at least one match – 'from' or 'to'
|
|
134
|
+
trigger = (from !== undefined && from === this._prev)
|
|
135
|
+
|| (to !== undefined && to === v);
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
// if both 'from' and 'to' are undefined – trigger for any change
|
|
139
|
+
// this._from === undefined && this._to === undefined;
|
|
140
|
+
trigger = true;
|
|
141
|
+
}
|
|
142
|
+
this.logger?.log('Checked value:', v, ' ==> will trigger:', trigger);
|
|
143
|
+
this._prev = v;
|
|
144
|
+
if (trigger) {
|
|
145
|
+
// will actually trigger only if someone subscribed to the event
|
|
146
|
+
// Use triggerAsync to catch and log all errors
|
|
147
|
+
this._event?.triggerAsync(v);
|
|
148
|
+
if (this._cb) {
|
|
149
|
+
this._cb(v);
|
|
150
|
+
}
|
|
151
|
+
if (this._fireOnce) {
|
|
152
|
+
this.dispose();
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
return trigger;
|
|
156
|
+
};
|
|
157
|
+
_finishPromise(cb, arg) {
|
|
158
|
+
this._promise = null;
|
|
159
|
+
this._promiseReject = null;
|
|
160
|
+
this._cb = null;
|
|
161
|
+
if (cb) {
|
|
162
|
+
cb(arg);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
export function waitFor(reaction, current, toBe) {
|
|
167
|
+
return new TransitionObserver(reaction, current)
|
|
168
|
+
.to(toBe)
|
|
169
|
+
.fireOnce()
|
|
170
|
+
.getPromise();
|
|
171
|
+
}
|
|
172
|
+
//# 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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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { constructDynamic, constructStatic, guardIsStatic, normalizeInput, } from './builder.helpers.js';
|
|
2
|
-
import { combineUrls } from './utils.js';
|
|
2
|
+
import { CombineOptions, combineUrls } from './utils.js';
|
|
3
3
|
/** Tagged template literal to create a path builder */
|
|
4
4
|
export function build(strings, ...params) {
|
|
5
5
|
return constructDynamic(strings, ...params);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"builder.js","sourceRoot":"","sources":["../../../../src/structures/path/builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EACrB,eAAe,EACf,aAAa,EACb,cAAc,GACjB,MAAM,sBAAsB,CAAC;AAY9B,OAAO,
|
|
1
|
+
{"version":3,"file":"builder.js","sourceRoot":"","sources":["../../../../src/structures/path/builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -39,6 +39,10 @@ export function combineUrls(...parts) {
|
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
41
|
let result = _parts.join(separator);
|
|
42
|
+
// edge case: for empty result if both start/end separators requested – add only one
|
|
43
|
+
if (!result && (options?.addStart === true || options?.addTrail === true)) {
|
|
44
|
+
return separator;
|
|
45
|
+
}
|
|
42
46
|
if (options?.addTrail) {
|
|
43
47
|
const char = typeof options.addTrail === 'string'
|
|
44
48
|
? options.addTrail
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/structures/path/utils.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,SAAS,CAAC,GAA8B,EAAE,EAAU;IAChE,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC;QAC5B,OAAO,EAAE,CAAC;IACd,CAAC;IAED,IAAI,KAAK,GAAG,CAAC,EAAE,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC;IAEhC,OAAO,KAAK,GAAG,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE;QACnC,EAAE,KAAK,CAAC;IAEZ,OAAO,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,EAAE;QACrC,EAAE,GAAG,CAAC;IAEV,OAAO,CAAC,KAAK,GAAG,CAAC,IAAI,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC;QAClC,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC;QAC3B,CAAC,CAAC,GAAG,CAAC;AACd,CAAC;AAWD,MAAM,KAAW,cAAc,CAI9B;AAJD,WAAiB,cAAc;IAC3B,SAAgB,KAAK,CAAC,GAAG,OAAmC;QACxD,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,CAAC;IACzC,CAAC;IAFe,oBAAK,QAEpB,CAAA;AACL,CAAC,EAJgB,cAAc,KAAd,cAAc,QAI9B;AAKD,MAAM,UAAU,WAAW,CAAC,GAAG,KAA0C;IACrE,MAAM,OAAO,GAAG,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ;QACxC,CAAC,CAAC,IAAI;QACN,CAAC,CAAC,KAAK,CAAC,CAAC,CAA6B,CAAC;IAE3C,MAAM,SAAS,GAAG,OAAO,EAAE,SAAS,IAAI,GAAG,CAAC;IAC5C,MAAM,UAAU,GAAG,OAAO,EAAE,UAAU,IAAI,GAAG,CAAC;IAE9C,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,IAAI,KAAK,CAAC;IACxC,MAAM,MAAM,GAAa,EAAE,CAAC;IAE5B,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;QACpB,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;YACxB,SAAS;QACb,CAAC;QAED,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,IAAI,GAAG,SAAS,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;QACpC,CAAC;QAED,IAAI,IAAI,EAAE,CAAC;YACP,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC;IACL,CAAC;IAED,IAAI,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAEpC,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;QACpB,MAAM,IAAI,GAAG,OAAO,OAAO,CAAC,QAAQ,KAAK,QAAQ;YAC7C,CAAC,CAAC,OAAO,CAAC,QAAQ;YAClB,CAAC,CAAC,SAAS,CAAC;QAChB,MAAM,IAAI,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;QACpB,MAAM,IAAI,GAAG,OAAO,OAAO,CAAC,QAAQ,KAAK,QAAQ;YAC7C,CAAC,CAAC,OAAO,CAAC,QAAQ;YAClB,CAAC,CAAC,SAAS,CAAC;QAChB,MAAM,GAAG,IAAI,GAAG,MAAM,CAAC;IAC3B,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC"}
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/structures/path/utils.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,SAAS,CAAC,GAA8B,EAAE,EAAU;IAChE,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC;QAC5B,OAAO,EAAE,CAAC;IACd,CAAC;IAED,IAAI,KAAK,GAAG,CAAC,EAAE,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC;IAEhC,OAAO,KAAK,GAAG,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE;QACnC,EAAE,KAAK,CAAC;IAEZ,OAAO,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,EAAE;QACrC,EAAE,GAAG,CAAC;IAEV,OAAO,CAAC,KAAK,GAAG,CAAC,IAAI,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC;QAClC,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC;QAC3B,CAAC,CAAC,GAAG,CAAC;AACd,CAAC;AAWD,MAAM,KAAW,cAAc,CAI9B;AAJD,WAAiB,cAAc;IAC3B,SAAgB,KAAK,CAAC,GAAG,OAAmC;QACxD,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,CAAC;IACzC,CAAC;IAFe,oBAAK,QAEpB,CAAA;AACL,CAAC,EAJgB,cAAc,KAAd,cAAc,QAI9B;AAKD,MAAM,UAAU,WAAW,CAAC,GAAG,KAA0C;IACrE,MAAM,OAAO,GAAG,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ;QACxC,CAAC,CAAC,IAAI;QACN,CAAC,CAAC,KAAK,CAAC,CAAC,CAA6B,CAAC;IAE3C,MAAM,SAAS,GAAG,OAAO,EAAE,SAAS,IAAI,GAAG,CAAC;IAC5C,MAAM,UAAU,GAAG,OAAO,EAAE,UAAU,IAAI,GAAG,CAAC;IAE9C,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,IAAI,KAAK,CAAC;IACxC,MAAM,MAAM,GAAa,EAAE,CAAC;IAE5B,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;QACpB,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;YACxB,SAAS;QACb,CAAC;QAED,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,IAAI,GAAG,SAAS,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;QACpC,CAAC;QAED,IAAI,IAAI,EAAE,CAAC;YACP,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC;IACL,CAAC;IAED,IAAI,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAEpC,oFAAoF;IACpF,IAAI,CAAC,MAAM,IAAI,CAAC,OAAO,EAAE,QAAQ,KAAK,IAAI,IAAI,OAAO,EAAE,QAAQ,KAAK,IAAI,CAAC,EAAE,CAAC;QACxE,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;QACpB,MAAM,IAAI,GAAG,OAAO,OAAO,CAAC,QAAQ,KAAK,QAAQ;YAC7C,CAAC,CAAC,OAAO,CAAC,QAAQ;YAClB,CAAC,CAAC,SAAS,CAAC;QAChB,MAAM,IAAI,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;QACpB,MAAM,IAAI,GAAG,OAAO,OAAO,CAAC,QAAQ,KAAK,QAAQ;YAC7C,CAAC,CAAC,OAAO,CAAC,QAAQ;YAClB,CAAC,CAAC,SAAS,CAAC;QAChB,MAAM,GAAG,IAAI,GAAG,MAAM,CAAC;IAC3B,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ThrottleProcessor } from '../functions/throttle.js';
|
|
2
|
-
import {
|
|
2
|
+
import { Loggable } from '../logger/loggable.js';
|
|
3
3
|
import { Model } from '../models/Model.js';
|
|
4
4
|
export var DeferredGetter;
|
|
5
5
|
(function (DeferredGetter) {
|
|
@@ -18,7 +18,7 @@ const BATCHING_DELAY = 200;
|
|
|
18
18
|
* - batching of fetches.
|
|
19
19
|
* - auto-invalidation of cached items.
|
|
20
20
|
*/
|
|
21
|
-
export class PromiseCache {
|
|
21
|
+
export class PromiseCache extends Loggable {
|
|
22
22
|
fetcher;
|
|
23
23
|
keyAdapter;
|
|
24
24
|
keyParser;
|
|
@@ -30,9 +30,9 @@ export class PromiseCache {
|
|
|
30
30
|
_batch = null;
|
|
31
31
|
_invalidationTimeMs = null;
|
|
32
32
|
_keepInstanceDuringInvalidation = false;
|
|
33
|
-
_logger = null;
|
|
34
33
|
_version = 0;
|
|
35
34
|
constructor(fetcher, keyAdapter, keyParser) {
|
|
35
|
+
super();
|
|
36
36
|
this.fetcher = fetcher;
|
|
37
37
|
this.keyAdapter = keyAdapter;
|
|
38
38
|
this.keyParser = keyParser;
|
|
@@ -66,14 +66,8 @@ export class PromiseCache {
|
|
|
66
66
|
}
|
|
67
67
|
return this.keyAdapter(k);
|
|
68
68
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
this._logger = nameOrLogger;
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
this._logger = createLogger(`[PromiseCache:${nameOrLogger || '?'}]`);
|
|
75
|
-
}
|
|
76
|
-
return this;
|
|
69
|
+
getLoggerName(name) {
|
|
70
|
+
return `[PromiseCache:${name || '?'}]`;
|
|
77
71
|
}
|
|
78
72
|
/**
|
|
79
73
|
* 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.
|
|
@@ -120,7 +114,7 @@ export class PromiseCache {
|
|
|
120
114
|
// make sure current item is hooked here from the cache (required by observers)
|
|
121
115
|
const item = this._itemsCache.get(key);
|
|
122
116
|
if (isInvalid) {
|
|
123
|
-
this.
|
|
117
|
+
this.logger?.log(key, 'item is invalidated');
|
|
124
118
|
}
|
|
125
119
|
return {
|
|
126
120
|
item: (isInvalid && !this._keepInstanceDuringInvalidation) ? undefined : item,
|
|
@@ -134,19 +128,19 @@ export class PromiseCache {
|
|
|
134
128
|
// spin fetch
|
|
135
129
|
this.get(id);
|
|
136
130
|
}
|
|
137
|
-
this.
|
|
131
|
+
this.logger?.log(key, 'getCurrent: returns', item);
|
|
138
132
|
return item;
|
|
139
133
|
}
|
|
140
134
|
get(id) {
|
|
141
135
|
const { item, key, isInvalid } = this._getCurrent(id);
|
|
142
136
|
// return cached item if it's not invalidated
|
|
143
137
|
if (item !== undefined && !isInvalid) {
|
|
144
|
-
this.
|
|
138
|
+
this.logger?.log(key, 'get: item resolved to', item, isInvalid ? '(invalidated)' : '');
|
|
145
139
|
return Promise.resolve(item);
|
|
146
140
|
}
|
|
147
141
|
let promise = this._fetchCache.get(key);
|
|
148
142
|
if (promise != null) {
|
|
149
|
-
this.
|
|
143
|
+
this.logger?.log(key, 'get: item resolved to <promise>');
|
|
150
144
|
return promise;
|
|
151
145
|
}
|
|
152
146
|
this.setStatus(key, true);
|
|
@@ -166,7 +160,7 @@ export class PromiseCache {
|
|
|
166
160
|
return res;
|
|
167
161
|
}
|
|
168
162
|
if (this._fetchCache.get(key) != null) {
|
|
169
|
-
this.
|
|
163
|
+
this.logger?.log(key, 'item\'s <promise> resolved to', res);
|
|
170
164
|
res = this.prepareResult(res);
|
|
171
165
|
this.storeResult(key, res);
|
|
172
166
|
}
|
|
@@ -177,7 +171,7 @@ export class PromiseCache {
|
|
|
177
171
|
this.onFetchComplete(key);
|
|
178
172
|
}
|
|
179
173
|
else {
|
|
180
|
-
this.
|
|
174
|
+
this.logger?.log(key, 'skipping item\'s resolve due to version change ("clear()" has been called)');
|
|
181
175
|
}
|
|
182
176
|
}
|
|
183
177
|
};
|
|
@@ -236,7 +230,7 @@ export class PromiseCache {
|
|
|
236
230
|
}
|
|
237
231
|
/** @override */
|
|
238
232
|
setStatus(key, status) {
|
|
239
|
-
this.
|
|
233
|
+
this.logger?.log(key, 'status update:', status);
|
|
240
234
|
this._itemsStatus.set(key, status);
|
|
241
235
|
}
|
|
242
236
|
/** @override */
|
|
@@ -265,7 +259,7 @@ export class PromiseCache {
|
|
|
265
259
|
/** @pure */
|
|
266
260
|
async tryFetchInBatch(id) {
|
|
267
261
|
const fetchWrap = () => this.fetcher(id).catch(err => {
|
|
268
|
-
this.
|
|
262
|
+
this.logger?.warn('fetcher failed', id, err);
|
|
269
263
|
return null;
|
|
270
264
|
});
|
|
271
265
|
if (!this._batch) {
|
|
@@ -273,7 +267,7 @@ export class PromiseCache {
|
|
|
273
267
|
}
|
|
274
268
|
const res = await this._batch.push(id)
|
|
275
269
|
.catch(err => {
|
|
276
|
-
this.
|
|
270
|
+
this.logger?.warn('batch fetch failed', id, err);
|
|
277
271
|
return null;
|
|
278
272
|
});
|
|
279
273
|
if (!res || !res.result || res.result[res.index] === undefined) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"promiseCache.js","sourceRoot":"","sources":["../../../src/structures/promiseCache.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"promiseCache.js","sourceRoot":"","sources":["../../../src/structures/promiseCache.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Loggable } from '../../logger/loggable.js';
|
|
2
2
|
import { Event } from '../../observing/event.js';
|
|
3
3
|
import { OneTimeLateEvent } from '../../observing/event.late.js';
|
|
4
|
-
export class ParallelQueue {
|
|
4
|
+
export class ParallelQueue extends Loggable {
|
|
5
5
|
_queues = {};
|
|
6
6
|
_inProgress = null;
|
|
7
7
|
_currentIndex = 0;
|
|
8
8
|
_maxIndex = 0;
|
|
9
|
-
_logger = null;
|
|
10
9
|
_beforePriorityRun = new Event();
|
|
11
10
|
_afterPriorityRun = new Event();
|
|
12
11
|
_finished = new OneTimeLateEvent();
|
|
@@ -15,9 +14,8 @@ export class ParallelQueue {
|
|
|
15
14
|
get beforePriorityRun() { return this._beforePriorityRun.expose(); }
|
|
16
15
|
get afterPriorityRun() { return this._afterPriorityRun.expose(); }
|
|
17
16
|
get finished() { return this._finished.expose(); }
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
return this;
|
|
17
|
+
getLoggerName(name) {
|
|
18
|
+
return `[Queue:${name || '?'}]`;
|
|
21
19
|
}
|
|
22
20
|
/** @returns A callback that will try to cancel queued item */
|
|
23
21
|
enqueue(cb, priority) {
|
|
@@ -58,7 +56,7 @@ export class ParallelQueue {
|
|
|
58
56
|
await this.tryStartQueue();
|
|
59
57
|
}
|
|
60
58
|
catch (err) {
|
|
61
|
-
this.
|
|
59
|
+
this.logger?.warn('Failed to process queue:', err);
|
|
62
60
|
return false;
|
|
63
61
|
}
|
|
64
62
|
return true;
|
|
@@ -79,24 +77,24 @@ export class ParallelQueue {
|
|
|
79
77
|
const MAX_ATTEMPTS = 5;
|
|
80
78
|
while ((current = this._queues[this._currentIndex])?.length) {
|
|
81
79
|
if (iterations++ > MAX_ATTEMPTS) {
|
|
82
|
-
this.
|
|
80
|
+
this.logger?.warn('Tried to purge queue for priority =', this._currentIndex, 'for too many times of', MAX_ATTEMPTS, '; totalItems =', totalItems, '; skipping.');
|
|
83
81
|
break;
|
|
84
82
|
}
|
|
85
|
-
this.
|
|
83
|
+
this.logger?.log('Processing priority =', this._currentIndex, '; count =', current.length);
|
|
86
84
|
const items = current.slice();
|
|
87
85
|
current.length = 0;
|
|
88
86
|
totalItems += items.length;
|
|
89
87
|
await Promise.all(items.map((loader, index) => this._executeLoader(loader, this._currentIndex, index)));
|
|
90
88
|
}
|
|
91
89
|
if (!current?.length && iterations === 0) {
|
|
92
|
-
this.
|
|
90
|
+
this.logger?.log('Skipping priority =', this._currentIndex, '; no items');
|
|
93
91
|
}
|
|
94
92
|
await this._afterPriorityRun.triggerAsync(this._currentIndex);
|
|
95
93
|
const next = this._currentIndex + 1;
|
|
96
94
|
if (next > this._maxIndex) {
|
|
97
95
|
// looks like we've finished!
|
|
98
96
|
this._inProgress = false;
|
|
99
|
-
this.
|
|
97
|
+
this.logger?.log('Finished processing at index =', this._currentIndex);
|
|
100
98
|
this._finished.trigger();
|
|
101
99
|
return;
|
|
102
100
|
}
|
|
@@ -108,8 +106,8 @@ export class ParallelQueue {
|
|
|
108
106
|
await l();
|
|
109
107
|
}
|
|
110
108
|
catch (err) {
|
|
111
|
-
this.
|
|
112
|
-
this.
|
|
109
|
+
this.logger?.warn('Failed to process queue item at priority =', priority, ' at index =', index || '?');
|
|
110
|
+
this.logger?.error(err);
|
|
113
111
|
}
|
|
114
112
|
};
|
|
115
113
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parallel.js","sourceRoot":"","sources":["../../../../src/structures/queue/parallel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"parallel.js","sourceRoot":"","sources":["../../../../src/structures/queue/parallel.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,21 +1,23 @@
|
|
|
1
|
-
import { createLogger } from '../logger/shared.js';
|
|
2
1
|
import { combineDisposers } from '../functions/disposer.js';
|
|
3
2
|
import { catchPromise } from '../functions/safe.js';
|
|
4
|
-
|
|
3
|
+
import { Loggable } from '../logger/loggable.js';
|
|
4
|
+
export class SubscribersMap extends Loggable {
|
|
5
5
|
subscribe;
|
|
6
6
|
name;
|
|
7
7
|
/** Unsubscribers map: key => unsub fn */
|
|
8
8
|
_map = new Map();
|
|
9
9
|
/** Timeouts map: key => timeout handle */
|
|
10
10
|
_timeouts = new Map();
|
|
11
|
-
_logger;
|
|
12
11
|
_count = 0;
|
|
13
12
|
constructor(subscribe, name) {
|
|
13
|
+
super();
|
|
14
14
|
this.subscribe = subscribe;
|
|
15
15
|
this.name = name;
|
|
16
|
-
this._logger = createLogger(`[Observers:${this.name || '?'}]`);
|
|
17
16
|
}
|
|
18
17
|
get count() { return this._count; }
|
|
18
|
+
getLoggerName(name) {
|
|
19
|
+
return `[Observers:${name || '?'}]`;
|
|
20
|
+
}
|
|
19
21
|
getIsObserving(key) {
|
|
20
22
|
return this._map.has(key);
|
|
21
23
|
}
|
|
@@ -28,7 +30,7 @@ export class SubscribersMap {
|
|
|
28
30
|
return;
|
|
29
31
|
}
|
|
30
32
|
if (enable) {
|
|
31
|
-
this.
|
|
33
|
+
this.logger?.log('Adding observer for key =', key, clearAfter ? `, clearAfter = ${clearAfter}` : '');
|
|
32
34
|
// this marker will help to determine whether unsubscribe was requested while we were in process of subscribing
|
|
33
35
|
let disabled = false;
|
|
34
36
|
const marker = () => { disabled = true; };
|
|
@@ -48,7 +50,7 @@ export class SubscribersMap {
|
|
|
48
50
|
}
|
|
49
51
|
}
|
|
50
52
|
else {
|
|
51
|
-
this.
|
|
53
|
+
this.logger?.log('Removing observer for key =', key);
|
|
52
54
|
this.refreshTimeout(key, false);
|
|
53
55
|
const unsub = this._map.get(key);
|
|
54
56
|
this._map.delete(key);
|
|
@@ -67,7 +69,7 @@ export class SubscribersMap {
|
|
|
67
69
|
return;
|
|
68
70
|
}
|
|
69
71
|
if (enable && timeout) {
|
|
70
|
-
const t = setTimeout(() => catchPromise(this.enable(key, false), err => this.
|
|
72
|
+
const t = setTimeout(() => catchPromise(this.enable(key, false), err => this.logger?.error('Unexpected error:', err)), timeout);
|
|
71
73
|
this._timeouts.set(key, t);
|
|
72
74
|
}
|
|
73
75
|
}
|