@angular/core 17.0.0-next.6 → 17.0.0-next.8
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/esm2022/primitives/signals/index.mjs +15 -0
- package/esm2022/primitives/signals/src/computed.mjs +92 -0
- package/esm2022/primitives/signals/src/equality.mjs +14 -0
- package/esm2022/primitives/signals/src/errors.mjs +18 -0
- package/esm2022/primitives/signals/src/graph.mjs +291 -0
- package/esm2022/primitives/signals/src/signal.mjs +78 -0
- package/esm2022/primitives/signals/src/watch.mjs +82 -0
- package/esm2022/primitives/signals/src/weak_ref.mjs +11 -0
- package/esm2022/rxjs-interop/src/to_signal.mjs +45 -14
- package/esm2022/src/application_init.mjs +50 -2
- package/esm2022/src/application_ref.mjs +7 -2
- package/esm2022/src/application_tokens.mjs +16 -1
- package/esm2022/src/core_private_export.mjs +4 -4
- package/esm2022/src/core_reactivity_export_internal.mjs +6 -2
- package/esm2022/src/core_render3_private_export.mjs +2 -2
- package/esm2022/src/errors.mjs +1 -1
- package/esm2022/src/image_performance_warning.mjs +154 -0
- package/esm2022/src/linker/compiler.mjs +1 -1
- package/esm2022/src/metadata/directives.mjs +1 -1
- package/esm2022/src/render3/after_render_hooks.mjs +5 -1
- package/esm2022/src/render3/assert.mjs +16 -1
- package/esm2022/src/render3/component_ref.mjs +12 -3
- package/esm2022/src/render3/debug/framework_injector_profiler.mjs +33 -4
- package/esm2022/src/render3/debug/injector_profiler.mjs +1 -1
- package/esm2022/src/render3/debug/set_debug_info.mjs +20 -0
- package/esm2022/src/render3/definition.mjs +2 -1
- package/esm2022/src/render3/deps_tracker/api.mjs +1 -1
- package/esm2022/src/render3/deps_tracker/deps_tracker.mjs +13 -2
- package/esm2022/src/render3/features/host_directives_feature.mjs +3 -8
- package/esm2022/src/render3/hooks.mjs +5 -5
- package/esm2022/src/render3/index.mjs +3 -2
- package/esm2022/src/render3/instructions/change_detection.mjs +31 -14
- package/esm2022/src/render3/instructions/control_flow.mjs +75 -63
- package/esm2022/src/render3/instructions/defer.mjs +410 -60
- package/esm2022/src/render3/instructions/defer_events.mjs +28 -8
- package/esm2022/src/render3/instructions/shared.mjs +5 -4
- package/esm2022/src/render3/interfaces/container.mjs +5 -4
- package/esm2022/src/render3/interfaces/defer.mjs +13 -6
- package/esm2022/src/render3/interfaces/definition.mjs +1 -1
- package/esm2022/src/render3/interfaces/view.mjs +5 -4
- package/esm2022/src/render3/jit/environment.mjs +3 -1
- package/esm2022/src/render3/list_reconciliation.mjs +257 -0
- package/esm2022/src/render3/node_manipulation.mjs +4 -6
- package/esm2022/src/render3/pipe.mjs +4 -4
- package/esm2022/src/render3/reactive_lview_consumer.mjs +2 -2
- package/esm2022/src/render3/reactivity/api.mjs +15 -0
- package/esm2022/src/render3/reactivity/asserts.mjs +26 -0
- package/esm2022/src/render3/reactivity/computed.mjs +19 -0
- package/esm2022/src/render3/reactivity/effect.mjs +7 -6
- package/esm2022/src/render3/reactivity/signal.mjs +32 -0
- package/esm2022/src/render3/reactivity/untracked.mjs +24 -0
- package/esm2022/src/render3/util/global_utils.mjs +3 -2
- package/esm2022/src/render3/util/injector_discovery_utils.mjs +70 -9
- package/esm2022/src/render3/util/stringify_utils.mjs +28 -1
- package/esm2022/src/render3/util/view_utils.mjs +41 -25
- package/esm2022/src/render3/view_ref.mjs +13 -2
- package/esm2022/src/util/stringify.mjs +16 -1
- package/esm2022/src/version.mjs +1 -1
- package/esm2022/testing/src/logger.mjs +3 -3
- package/fesm2022/core.mjs +15104 -14010
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/primitives/signals.mjs +539 -0
- package/fesm2022/primitives/signals.mjs.map +1 -0
- package/fesm2022/rxjs-interop.mjs +45 -14
- package/fesm2022/rxjs-interop.mjs.map +1 -1
- package/fesm2022/testing.mjs +1 -1
- package/index.d.ts +171 -167
- package/package.json +7 -1
- package/primitives/signals/index.d.ts +281 -0
- package/rxjs-interop/index.d.ts +15 -101
- package/schematics/collection.json +12 -2
- package/schematics/migrations/block-template-entities/bundle.js +1192 -610
- package/schematics/migrations/block-template-entities/bundle.js.map +4 -4
- package/schematics/migrations/compiler-options/bundle.js +582 -0
- package/schematics/migrations/compiler-options/bundle.js.map +7 -0
- package/schematics/migrations/transfer-state/bundle.js +592 -0
- package/schematics/migrations/transfer-state/bundle.js.map +7 -0
- package/schematics/migrations.json +10 -0
- package/schematics/ng-generate/control-flow-migration/bundle.js +24097 -0
- package/schematics/ng-generate/control-flow-migration/bundle.js.map +7 -0
- package/schematics/ng-generate/control-flow-migration/schema.json +7 -0
- package/schematics/ng-generate/standalone-migration/bundle.js +2470 -1627
- package/schematics/ng-generate/standalone-migration/bundle.js.map +4 -4
- package/testing/index.d.ts +1 -1
- package/esm2022/src/signals/index.mjs +0 -16
- package/esm2022/src/signals/src/api.mjs +0 -39
- package/esm2022/src/signals/src/computed.mjs +0 -95
- package/esm2022/src/signals/src/errors.mjs +0 -18
- package/esm2022/src/signals/src/graph.mjs +0 -280
- package/esm2022/src/signals/src/signal.mjs +0 -92
- package/esm2022/src/signals/src/untracked.mjs +0 -26
- package/esm2022/src/signals/src/watch.mjs +0 -81
- package/esm2022/src/signals/src/weak_ref.mjs +0 -11
|
@@ -5,16 +5,18 @@
|
|
|
5
5
|
* Use of this source code is governed by an MIT-style license that can be
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
|
-
import { InjectionToken, ɵɵdefineInjectable } from '../../di';
|
|
8
|
+
import { inject, InjectionToken, ɵɵdefineInjectable } from '../../di';
|
|
9
9
|
import { findMatchingDehydratedView } from '../../hydration/views';
|
|
10
10
|
import { populateDehydratedViewsInLContainer } from '../../linker/view_container_ref';
|
|
11
|
+
import { arrayInsert2, arraySplice } from '../../util/array_utils';
|
|
11
12
|
import { assertDefined, assertElement, assertEqual, throwError } from '../../util/assert';
|
|
13
|
+
import { NgZone } from '../../zone';
|
|
12
14
|
import { afterRender } from '../after_render_hooks';
|
|
13
15
|
import { assertIndexInDeclRange, assertLContainer, assertLView, assertTNodeForLView } from '../assert';
|
|
14
16
|
import { bindingUpdated } from '../bindings';
|
|
15
17
|
import { getComponentDef, getDirectiveDef, getPipeDef } from '../definition';
|
|
16
18
|
import { CONTAINER_HEADER_OFFSET } from '../interfaces/container';
|
|
17
|
-
import { DEFER_BLOCK_STATE, DeferBlockBehavior, DeferBlockInternalState, DeferBlockState, DeferDependenciesLoadingState } from '../interfaces/defer';
|
|
19
|
+
import { DEFER_BLOCK_STATE, DeferBlockBehavior, DeferBlockInternalState, DeferBlockState, DeferDependenciesLoadingState, LOADING_AFTER_CLEANUP_FN, LOADING_AFTER_SLOT, MINIMUM_SLOT, NEXT_DEFER_BLOCK_STATE, STATE_IS_FROZEN_UNTIL } from '../interfaces/defer';
|
|
18
20
|
import { isDestroyed, isLContainer, isLView } from '../interfaces/type_checks';
|
|
19
21
|
import { FLAGS, HEADER_OFFSET, INJECTOR, PARENT, TVIEW } from '../interfaces/view';
|
|
20
22
|
import { getCurrentTNode, getLView, getSelectedTNode, getTView, nextBindingIndex } from '../state';
|
|
@@ -22,6 +24,7 @@ import { isPlatformBrowser } from '../util/misc_utils';
|
|
|
22
24
|
import { getConstant, getNativeByIndex, getTNode, removeLViewOnDestroy, storeLViewOnDestroy, walkUpViews } from '../util/view_utils';
|
|
23
25
|
import { addLViewToLContainer, createAndRenderEmbeddedLView, removeLViewFromLContainer, shouldAddViewToDom } from '../view_manipulation';
|
|
24
26
|
import { onHover, onInteraction, onViewport } from './defer_events';
|
|
27
|
+
import { markViewDirty } from './mark_view_dirty';
|
|
25
28
|
import { ɵɵtemplate } from './template';
|
|
26
29
|
/**
|
|
27
30
|
* Returns whether defer blocks should be triggered.
|
|
@@ -36,6 +39,33 @@ function shouldTriggerDeferBlock(injector) {
|
|
|
36
39
|
}
|
|
37
40
|
return isPlatformBrowser(injector);
|
|
38
41
|
}
|
|
42
|
+
/**
|
|
43
|
+
* Reference to the timer-based scheduler implementation of defer block state
|
|
44
|
+
* rendering method. It's used to make timer-based scheduling tree-shakable.
|
|
45
|
+
* If `minimum` or `after` parameters are used, compiler generates an extra
|
|
46
|
+
* argument for the `ɵɵdefer` instruction, which references a timer-based
|
|
47
|
+
* implementation.
|
|
48
|
+
*/
|
|
49
|
+
let applyDeferBlockStateWithSchedulingImpl = null;
|
|
50
|
+
/**
|
|
51
|
+
* Enables timer-related scheduling if `after` or `minimum` parameters are setup
|
|
52
|
+
* on the `@loading` or `@placeholder` blocks.
|
|
53
|
+
*/
|
|
54
|
+
export function ɵɵdeferEnableTimerScheduling(tView, tDetails, placeholderConfigIndex, loadingConfigIndex) {
|
|
55
|
+
const tViewConsts = tView.consts;
|
|
56
|
+
if (placeholderConfigIndex != null) {
|
|
57
|
+
tDetails.placeholderBlockConfig =
|
|
58
|
+
getConstant(tViewConsts, placeholderConfigIndex);
|
|
59
|
+
}
|
|
60
|
+
if (loadingConfigIndex != null) {
|
|
61
|
+
tDetails.loadingBlockConfig =
|
|
62
|
+
getConstant(tViewConsts, loadingConfigIndex);
|
|
63
|
+
}
|
|
64
|
+
// Enable implementation that supports timer-based scheduling.
|
|
65
|
+
if (applyDeferBlockStateWithSchedulingImpl === null) {
|
|
66
|
+
applyDeferBlockStateWithSchedulingImpl = applyDeferBlockStateWithScheduling;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
39
69
|
/**
|
|
40
70
|
* Creates runtime data structures for defer blocks.
|
|
41
71
|
*
|
|
@@ -47,34 +77,32 @@ function shouldTriggerDeferBlock(injector) {
|
|
|
47
77
|
* @param errorTmplIndex Index of the template with the error block content.
|
|
48
78
|
* @param loadingConfigIndex Index in the constants array of the configuration of the loading.
|
|
49
79
|
* block.
|
|
50
|
-
* @param
|
|
80
|
+
* @param placeholderConfigIndex Index in the constants array of the configuration of the
|
|
51
81
|
* placeholder block.
|
|
82
|
+
* @param enableTimerScheduling Function that enables timer-related scheduling if `after`
|
|
83
|
+
* or `minimum` parameters are setup on the `@loading` or `@placeholder` blocks.
|
|
52
84
|
*
|
|
53
85
|
* @codeGenApi
|
|
54
86
|
*/
|
|
55
|
-
export function ɵɵdefer(index, primaryTmplIndex, dependencyResolverFn, loadingTmplIndex, placeholderTmplIndex, errorTmplIndex, loadingConfigIndex, placeholderConfigIndex) {
|
|
87
|
+
export function ɵɵdefer(index, primaryTmplIndex, dependencyResolverFn, loadingTmplIndex, placeholderTmplIndex, errorTmplIndex, loadingConfigIndex, placeholderConfigIndex, enableTimerScheduling) {
|
|
56
88
|
const lView = getLView();
|
|
57
89
|
const tView = getTView();
|
|
58
|
-
const tViewConsts = tView.consts;
|
|
59
90
|
const adjustedIndex = index + HEADER_OFFSET;
|
|
60
91
|
ɵɵtemplate(index, null, 0, 0);
|
|
61
92
|
if (tView.firstCreatePass) {
|
|
62
|
-
const
|
|
93
|
+
const tDetails = {
|
|
63
94
|
primaryTmplIndex,
|
|
64
95
|
loadingTmplIndex: loadingTmplIndex ?? null,
|
|
65
96
|
placeholderTmplIndex: placeholderTmplIndex ?? null,
|
|
66
97
|
errorTmplIndex: errorTmplIndex ?? null,
|
|
67
|
-
placeholderBlockConfig:
|
|
68
|
-
|
|
69
|
-
null,
|
|
70
|
-
loadingBlockConfig: loadingConfigIndex != null ?
|
|
71
|
-
getConstant(tViewConsts, loadingConfigIndex) :
|
|
72
|
-
null,
|
|
98
|
+
placeholderBlockConfig: null,
|
|
99
|
+
loadingBlockConfig: null,
|
|
73
100
|
dependencyResolverFn: dependencyResolverFn ?? null,
|
|
74
101
|
loadingState: DeferDependenciesLoadingState.NOT_STARTED,
|
|
75
102
|
loadingPromise: null,
|
|
76
103
|
};
|
|
77
|
-
|
|
104
|
+
enableTimerScheduling?.(tView, tDetails, placeholderConfigIndex, loadingConfigIndex);
|
|
105
|
+
setTDeferBlockDetails(tView, adjustedIndex, tDetails);
|
|
78
106
|
}
|
|
79
107
|
const tNode = getCurrentTNode();
|
|
80
108
|
const lContainer = lView[adjustedIndex];
|
|
@@ -83,8 +111,12 @@ export function ɵɵdefer(index, primaryTmplIndex, dependencyResolverFn, loading
|
|
|
83
111
|
// In client-only mode, this function is a noop.
|
|
84
112
|
populateDehydratedViewsInLContainer(lContainer, tNode, lView);
|
|
85
113
|
// Init instance-specific defer details and store it.
|
|
86
|
-
const lDetails = [
|
|
87
|
-
|
|
114
|
+
const lDetails = [
|
|
115
|
+
null,
|
|
116
|
+
DeferBlockInternalState.Initial,
|
|
117
|
+
null,
|
|
118
|
+
null // LOADING_AFTER_CLEANUP_FN
|
|
119
|
+
];
|
|
88
120
|
setLDeferBlockDetails(lView, adjustedIndex, lDetails);
|
|
89
121
|
}
|
|
90
122
|
/**
|
|
@@ -136,37 +168,14 @@ export function ɵɵdeferPrefetchWhen(rawValue) {
|
|
|
136
168
|
* @codeGenApi
|
|
137
169
|
*/
|
|
138
170
|
export function ɵɵdeferOnIdle() {
|
|
139
|
-
|
|
140
|
-
const tNode = getCurrentTNode();
|
|
141
|
-
renderPlaceholder(lView, tNode);
|
|
142
|
-
onIdle(() => triggerDeferBlock(lView, tNode), lView, true /* withLViewCleanup */);
|
|
171
|
+
scheduleDelayedTrigger(onIdle);
|
|
143
172
|
}
|
|
144
173
|
/**
|
|
145
174
|
* Sets up logic to handle the `prefetch on idle` deferred trigger.
|
|
146
175
|
* @codeGenApi
|
|
147
176
|
*/
|
|
148
177
|
export function ɵɵdeferPrefetchOnIdle() {
|
|
149
|
-
|
|
150
|
-
const tNode = getCurrentTNode();
|
|
151
|
-
const tView = lView[TVIEW];
|
|
152
|
-
const tDetails = getTDeferBlockDetails(tView, tNode);
|
|
153
|
-
if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {
|
|
154
|
-
// Prevent scheduling more than one `requestIdleCallback` call
|
|
155
|
-
// for each defer block. For this reason we use only a trigger
|
|
156
|
-
// identifier in a key, so all instances would use the same key.
|
|
157
|
-
const key = String(0 /* DeferBlockTriggers.OnIdle */);
|
|
158
|
-
const injector = lView[INJECTOR];
|
|
159
|
-
const manager = injector.get(DeferBlockCleanupManager);
|
|
160
|
-
if (!manager.has(tDetails, key)) {
|
|
161
|
-
// In case of prefetching, we intentionally avoid cancelling resource loading if
|
|
162
|
-
// an underlying LView get destroyed (thus passing `null` as a second argument),
|
|
163
|
-
// because there might be other LViews (that represent embedded views) that
|
|
164
|
-
// depend on resource loading.
|
|
165
|
-
const prefetch = () => triggerPrefetching(tDetails, lView);
|
|
166
|
-
const cleanupFn = onIdle(prefetch, lView, false /* withLViewCleanup */);
|
|
167
|
-
registerTDetailsCleanup(injector, tDetails, key, cleanupFn);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
178
|
+
scheduleDelayedPrefetching(onIdle, 0 /* DeferBlockTriggers.OnIdle */);
|
|
170
179
|
}
|
|
171
180
|
/**
|
|
172
181
|
* Sets up logic to handle the `on immediate` deferred trigger.
|
|
@@ -203,13 +212,17 @@ export function ɵɵdeferPrefetchOnImmediate() {
|
|
|
203
212
|
* @param delay Amount of time to wait before loading the content.
|
|
204
213
|
* @codeGenApi
|
|
205
214
|
*/
|
|
206
|
-
export function ɵɵdeferOnTimer(delay) {
|
|
215
|
+
export function ɵɵdeferOnTimer(delay) {
|
|
216
|
+
scheduleDelayedTrigger(onTimer(delay));
|
|
217
|
+
}
|
|
207
218
|
/**
|
|
208
219
|
* Creates runtime data structures for the `prefetch on timer` deferred trigger.
|
|
209
220
|
* @param delay Amount of time to wait before prefetching the content.
|
|
210
221
|
* @codeGenApi
|
|
211
222
|
*/
|
|
212
|
-
export function ɵɵdeferPrefetchOnTimer(delay) {
|
|
223
|
+
export function ɵɵdeferPrefetchOnTimer(delay) {
|
|
224
|
+
scheduleDelayedPrefetching(onTimer(delay), 1 /* DeferBlockTriggers.OnTimer */);
|
|
225
|
+
}
|
|
213
226
|
/**
|
|
214
227
|
* Creates runtime data structures for the `on hover` deferred trigger.
|
|
215
228
|
* @param triggerIndex Index at which to find the trigger element.
|
|
@@ -292,6 +305,44 @@ export function ɵɵdeferPrefetchOnViewport(triggerIndex, walkUpTimes) {
|
|
|
292
305
|
}
|
|
293
306
|
}
|
|
294
307
|
/********** Helper functions **********/
|
|
308
|
+
/**
|
|
309
|
+
* Schedules triggering of a defer block for `on idle` and `on timer` conditions.
|
|
310
|
+
*/
|
|
311
|
+
function scheduleDelayedTrigger(scheduleFn) {
|
|
312
|
+
const lView = getLView();
|
|
313
|
+
const tNode = getCurrentTNode();
|
|
314
|
+
renderPlaceholder(lView, tNode);
|
|
315
|
+
scheduleFn(() => triggerDeferBlock(lView, tNode), lView, true /* withLViewCleanup */);
|
|
316
|
+
}
|
|
317
|
+
/**
|
|
318
|
+
* Schedules prefetching for `on idle` and `on timer` triggers.
|
|
319
|
+
*
|
|
320
|
+
* @param scheduleFn A function that does the scheduling.
|
|
321
|
+
* @param trigger A trigger that initiated scheduling.
|
|
322
|
+
*/
|
|
323
|
+
function scheduleDelayedPrefetching(scheduleFn, trigger) {
|
|
324
|
+
const lView = getLView();
|
|
325
|
+
const tNode = getCurrentTNode();
|
|
326
|
+
const tView = lView[TVIEW];
|
|
327
|
+
const tDetails = getTDeferBlockDetails(tView, tNode);
|
|
328
|
+
if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {
|
|
329
|
+
// Prevent scheduling more than one prefetch init call
|
|
330
|
+
// for each defer block. For this reason we use only a trigger
|
|
331
|
+
// identifier in a key, so all instances would use the same key.
|
|
332
|
+
const key = String(trigger);
|
|
333
|
+
const injector = lView[INJECTOR];
|
|
334
|
+
const manager = injector.get(DeferBlockCleanupManager);
|
|
335
|
+
if (!manager.has(tDetails, key)) {
|
|
336
|
+
// In case of prefetching, we intentionally avoid cancelling resource loading if
|
|
337
|
+
// an underlying LView get destroyed (thus passing `null` as a second argument),
|
|
338
|
+
// because there might be other LViews (that represent embedded views) that
|
|
339
|
+
// depend on resource loading.
|
|
340
|
+
const prefetch = () => triggerPrefetching(tDetails, lView);
|
|
341
|
+
const cleanupFn = scheduleFn(prefetch, lView, false /* withLViewCleanup */);
|
|
342
|
+
registerTDetailsCleanup(injector, tDetails, key, cleanupFn);
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
}
|
|
295
346
|
/**
|
|
296
347
|
* Helper function to get the LView in which a deferred block's trigger is rendered.
|
|
297
348
|
* @param deferredHostLView LView in which the deferred block is defined.
|
|
@@ -402,6 +453,31 @@ function onIdle(callback, lView, withLViewCleanup) {
|
|
|
402
453
|
scheduler.add(wrappedCallback);
|
|
403
454
|
return cleanupFn;
|
|
404
455
|
}
|
|
456
|
+
/**
|
|
457
|
+
* Returns a function that captures a provided delay.
|
|
458
|
+
* Invoking the returned function schedules a trigger.
|
|
459
|
+
*/
|
|
460
|
+
function onTimer(delay) {
|
|
461
|
+
return (callback, lView, withLViewCleanup) => scheduleTimerTrigger(delay, callback, lView, withLViewCleanup);
|
|
462
|
+
}
|
|
463
|
+
/**
|
|
464
|
+
* Schedules a callback to be invoked after a given timeout.
|
|
465
|
+
*
|
|
466
|
+
* @param delay A number of ms to wait until firing a callback.
|
|
467
|
+
* @param callback A function to be invoked after a timeout.
|
|
468
|
+
* @param lView LView that hosts an instance of a defer block.
|
|
469
|
+
* @param withLViewCleanup A flag that indicates whether a scheduled callback
|
|
470
|
+
* should be cancelled in case an LView is destroyed before a callback
|
|
471
|
+
* was invoked.
|
|
472
|
+
*/
|
|
473
|
+
function scheduleTimerTrigger(delay, callback, lView, withLViewCleanup) {
|
|
474
|
+
const injector = lView[INJECTOR];
|
|
475
|
+
const scheduler = injector.get(TimerScheduler);
|
|
476
|
+
const cleanupFn = () => scheduler.remove(callback);
|
|
477
|
+
const wrappedCallback = withLViewCleanup ? wrapWithLViewCleanup(callback, lView, cleanupFn) : callback;
|
|
478
|
+
scheduler.add(delay, wrappedCallback);
|
|
479
|
+
return cleanupFn;
|
|
480
|
+
}
|
|
405
481
|
/**
|
|
406
482
|
* Wraps a given callback into a logic that registers a cleanup function
|
|
407
483
|
* in the LView cleanup slot, to be invoked when an LView is destroyed.
|
|
@@ -466,6 +542,24 @@ function getTemplateIndexForState(newState, hostLView, tNode) {
|
|
|
466
542
|
return null;
|
|
467
543
|
}
|
|
468
544
|
}
|
|
545
|
+
/**
|
|
546
|
+
* Returns a minimum amount of time that a given state should be rendered for,
|
|
547
|
+
* taking into account `minimum` parameter value. If the `minimum` value is
|
|
548
|
+
* not specified - returns `null`.
|
|
549
|
+
*/
|
|
550
|
+
function getMinimumDurationForState(tDetails, currentState) {
|
|
551
|
+
if (currentState === DeferBlockState.Placeholder) {
|
|
552
|
+
return tDetails.placeholderBlockConfig?.[MINIMUM_SLOT] ?? null;
|
|
553
|
+
}
|
|
554
|
+
else if (currentState === DeferBlockState.Loading) {
|
|
555
|
+
return tDetails.loadingBlockConfig?.[MINIMUM_SLOT] ?? null;
|
|
556
|
+
}
|
|
557
|
+
return null;
|
|
558
|
+
}
|
|
559
|
+
/** Retrieves the value of the `after` parameter on the @loading block. */
|
|
560
|
+
function getLoadingBlockAfter(tDetails) {
|
|
561
|
+
return tDetails.loadingBlockConfig?.[LOADING_AFTER_SLOT] ?? null;
|
|
562
|
+
}
|
|
469
563
|
/**
|
|
470
564
|
* Transitions a defer block to the new state. Updates the necessary
|
|
471
565
|
* data structures and renders corresponding block.
|
|
@@ -476,6 +570,7 @@ function getTemplateIndexForState(newState, hostLView, tNode) {
|
|
|
476
570
|
*/
|
|
477
571
|
export function renderDeferBlockState(newState, tNode, lContainer) {
|
|
478
572
|
const hostLView = lContainer[PARENT];
|
|
573
|
+
const hostTView = hostLView[TVIEW];
|
|
479
574
|
// Check if this view is not destroyed. Since the loading process was async,
|
|
480
575
|
// the view might end up being destroyed by the time rendering happens.
|
|
481
576
|
if (isDestroyed(hostLView))
|
|
@@ -484,12 +579,26 @@ export function renderDeferBlockState(newState, tNode, lContainer) {
|
|
|
484
579
|
ngDevMode && assertTNodeForLView(tNode, hostLView);
|
|
485
580
|
const lDetails = getLDeferBlockDetails(hostLView, tNode);
|
|
486
581
|
ngDevMode && assertDefined(lDetails, 'Expected a defer block state defined');
|
|
582
|
+
const currentState = lDetails[DEFER_BLOCK_STATE];
|
|
583
|
+
if (isValidStateChange(currentState, newState) &&
|
|
584
|
+
isValidStateChange(lDetails[NEXT_DEFER_BLOCK_STATE] ?? -1, newState)) {
|
|
585
|
+
const tDetails = getTDeferBlockDetails(hostTView, tNode);
|
|
586
|
+
const needsScheduling = getLoadingBlockAfter(tDetails) !== null ||
|
|
587
|
+
getMinimumDurationForState(tDetails, DeferBlockState.Loading) !== null ||
|
|
588
|
+
getMinimumDurationForState(tDetails, DeferBlockState.Placeholder);
|
|
589
|
+
if (ngDevMode && needsScheduling) {
|
|
590
|
+
assertDefined(applyDeferBlockStateWithSchedulingImpl, 'Expected scheduling function to be defined');
|
|
591
|
+
}
|
|
592
|
+
const applyStateFn = needsScheduling ? applyDeferBlockStateWithSchedulingImpl : applyDeferBlockState;
|
|
593
|
+
applyStateFn(newState, lDetails, lContainer, tNode, hostLView);
|
|
594
|
+
}
|
|
595
|
+
}
|
|
596
|
+
/**
|
|
597
|
+
* Applies changes to the DOM to reflect a given state.
|
|
598
|
+
*/
|
|
599
|
+
function applyDeferBlockState(newState, lDetails, lContainer, tNode, hostLView) {
|
|
487
600
|
const stateTmplIndex = getTemplateIndexForState(newState, hostLView, tNode);
|
|
488
|
-
|
|
489
|
-
// with a number that is less than the next state. For example, if the current
|
|
490
|
-
// state is "loading" (represented as `2`), we should not show a placeholder
|
|
491
|
-
// (represented as `1`).
|
|
492
|
-
if (lDetails[DEFER_BLOCK_STATE] < newState && stateTmplIndex !== null) {
|
|
601
|
+
if (stateTmplIndex !== null) {
|
|
493
602
|
lDetails[DEFER_BLOCK_STATE] = newState;
|
|
494
603
|
const hostTView = hostLView[TVIEW];
|
|
495
604
|
const adjustedIndex = stateTmplIndex + HEADER_OFFSET;
|
|
@@ -501,8 +610,80 @@ export function renderDeferBlockState(newState, tNode, lContainer) {
|
|
|
501
610
|
const dehydratedView = findMatchingDehydratedView(lContainer, tNode.tView.ssrId);
|
|
502
611
|
const embeddedLView = createAndRenderEmbeddedLView(hostLView, tNode, null, { dehydratedView });
|
|
503
612
|
addLViewToLContainer(lContainer, embeddedLView, viewIndex, shouldAddViewToDom(tNode, dehydratedView));
|
|
613
|
+
markViewDirty(embeddedLView);
|
|
614
|
+
}
|
|
615
|
+
}
|
|
616
|
+
/**
|
|
617
|
+
* Extends the `applyDeferBlockState` with timer-based scheduling.
|
|
618
|
+
* This function becomes available on a page if there are defer blocks
|
|
619
|
+
* that use `after` or `minimum` parameters in the `@loading` or
|
|
620
|
+
* `@placeholder` blocks.
|
|
621
|
+
*/
|
|
622
|
+
function applyDeferBlockStateWithScheduling(newState, lDetails, lContainer, tNode, hostLView) {
|
|
623
|
+
const now = Date.now();
|
|
624
|
+
const hostTView = hostLView[TVIEW];
|
|
625
|
+
const tDetails = getTDeferBlockDetails(hostTView, tNode);
|
|
626
|
+
if (lDetails[STATE_IS_FROZEN_UNTIL] === null || lDetails[STATE_IS_FROZEN_UNTIL] <= now) {
|
|
627
|
+
lDetails[STATE_IS_FROZEN_UNTIL] = null;
|
|
628
|
+
const loadingAfter = getLoadingBlockAfter(tDetails);
|
|
629
|
+
const inLoadingAfterPhase = lDetails[LOADING_AFTER_CLEANUP_FN] !== null;
|
|
630
|
+
if (newState === DeferBlockState.Loading && loadingAfter !== null && !inLoadingAfterPhase) {
|
|
631
|
+
// Trying to render loading, but it has an `after` config,
|
|
632
|
+
// so schedule an update action after a timeout.
|
|
633
|
+
lDetails[NEXT_DEFER_BLOCK_STATE] = newState;
|
|
634
|
+
const cleanupFn = scheduleDeferBlockUpdate(loadingAfter, lDetails, tNode, lContainer, hostLView);
|
|
635
|
+
lDetails[LOADING_AFTER_CLEANUP_FN] = cleanupFn;
|
|
636
|
+
}
|
|
637
|
+
else {
|
|
638
|
+
// If we transition to a complete or an error state and there is a pending
|
|
639
|
+
// operation to render loading after a timeout - invoke a cleanup operation,
|
|
640
|
+
// which stops the timer.
|
|
641
|
+
if (newState > DeferBlockState.Loading && inLoadingAfterPhase) {
|
|
642
|
+
lDetails[LOADING_AFTER_CLEANUP_FN]();
|
|
643
|
+
lDetails[LOADING_AFTER_CLEANUP_FN] = null;
|
|
644
|
+
lDetails[NEXT_DEFER_BLOCK_STATE] = null;
|
|
645
|
+
}
|
|
646
|
+
applyDeferBlockState(newState, lDetails, lContainer, tNode, hostLView);
|
|
647
|
+
const duration = getMinimumDurationForState(tDetails, newState);
|
|
648
|
+
if (duration !== null) {
|
|
649
|
+
lDetails[STATE_IS_FROZEN_UNTIL] = now + duration;
|
|
650
|
+
scheduleDeferBlockUpdate(duration, lDetails, tNode, lContainer, hostLView);
|
|
651
|
+
}
|
|
652
|
+
}
|
|
653
|
+
}
|
|
654
|
+
else {
|
|
655
|
+
// We are still rendering the previous state.
|
|
656
|
+
// Update the `NEXT_DEFER_BLOCK_STATE`, which would be
|
|
657
|
+
// picked up once it's time to transition to the next state.
|
|
658
|
+
lDetails[NEXT_DEFER_BLOCK_STATE] = newState;
|
|
504
659
|
}
|
|
505
660
|
}
|
|
661
|
+
/**
|
|
662
|
+
* Schedules an update operation after a specified timeout.
|
|
663
|
+
*/
|
|
664
|
+
function scheduleDeferBlockUpdate(timeout, lDetails, tNode, lContainer, hostLView) {
|
|
665
|
+
const callback = () => {
|
|
666
|
+
const nextState = lDetails[NEXT_DEFER_BLOCK_STATE];
|
|
667
|
+
lDetails[STATE_IS_FROZEN_UNTIL] = null;
|
|
668
|
+
lDetails[NEXT_DEFER_BLOCK_STATE] = null;
|
|
669
|
+
if (nextState !== null) {
|
|
670
|
+
renderDeferBlockState(nextState, tNode, lContainer);
|
|
671
|
+
}
|
|
672
|
+
};
|
|
673
|
+
return scheduleTimerTrigger(timeout, callback, hostLView, true);
|
|
674
|
+
}
|
|
675
|
+
/**
|
|
676
|
+
* Checks whether we can transition to the next state.
|
|
677
|
+
*
|
|
678
|
+
* We transition to the next state if the previous state was represented
|
|
679
|
+
* with a number that is less than the next state. For example, if the current
|
|
680
|
+
* state is "loading" (represented as `1`), we should not show a placeholder
|
|
681
|
+
* (represented as `0`), but we can show a completed state (represented as `2`)
|
|
682
|
+
* or an error state (represented as `3`).
|
|
683
|
+
*/
|
|
684
|
+
function isValidStateChange(currentState, newState) {
|
|
685
|
+
return currentState < newState;
|
|
686
|
+
}
|
|
506
687
|
/**
|
|
507
688
|
* Trigger prefetching of dependencies for a defer block.
|
|
508
689
|
*
|
|
@@ -583,24 +764,36 @@ export function triggerResourceLoading(tDetails, lView) {
|
|
|
583
764
|
// Update directive and pipe registries to add newly downloaded dependencies.
|
|
584
765
|
const primaryBlockTView = primaryBlockTNode.tView;
|
|
585
766
|
if (directiveDefs.length > 0) {
|
|
586
|
-
primaryBlockTView.directiveRegistry =
|
|
587
|
-
|
|
588
|
-
directiveDefs;
|
|
767
|
+
primaryBlockTView.directiveRegistry =
|
|
768
|
+
addDepsToRegistry(primaryBlockTView.directiveRegistry, directiveDefs);
|
|
589
769
|
}
|
|
590
770
|
if (pipeDefs.length > 0) {
|
|
591
|
-
primaryBlockTView.pipeRegistry =
|
|
592
|
-
|
|
593
|
-
pipeDefs;
|
|
771
|
+
primaryBlockTView.pipeRegistry =
|
|
772
|
+
addDepsToRegistry(primaryBlockTView.pipeRegistry, pipeDefs);
|
|
594
773
|
}
|
|
595
774
|
}
|
|
596
775
|
});
|
|
597
776
|
}
|
|
777
|
+
/**
|
|
778
|
+
* Adds downloaded dependencies into a directive or a pipe registry,
|
|
779
|
+
* making sure that a dependency doesn't yet exist in the registry.
|
|
780
|
+
*/
|
|
781
|
+
function addDepsToRegistry(currentDeps, newDeps) {
|
|
782
|
+
if (!currentDeps || currentDeps.length === 0) {
|
|
783
|
+
return newDeps;
|
|
784
|
+
}
|
|
785
|
+
const currentDepSet = new Set(currentDeps);
|
|
786
|
+
for (const dep of newDeps) {
|
|
787
|
+
currentDepSet.add(dep);
|
|
788
|
+
}
|
|
789
|
+
// If `currentDeps` is the same length, there were no new deps and can
|
|
790
|
+
// return the original array.
|
|
791
|
+
return (currentDeps.length === currentDepSet.size) ? currentDeps : Array.from(currentDepSet);
|
|
792
|
+
}
|
|
598
793
|
/** Utility function to render placeholder content (if present) */
|
|
599
794
|
function renderPlaceholder(lView, tNode) {
|
|
600
|
-
const tView = lView[TVIEW];
|
|
601
795
|
const lContainer = lView[tNode.index];
|
|
602
796
|
ngDevMode && assertLContainer(lContainer);
|
|
603
|
-
const tDetails = getTDeferBlockDetails(tView, tNode);
|
|
604
797
|
renderDeferBlockState(DeferBlockState.Placeholder, tNode, lContainer);
|
|
605
798
|
}
|
|
606
799
|
/**
|
|
@@ -642,11 +835,9 @@ function triggerDeferBlock(lView, tNode) {
|
|
|
642
835
|
if (!shouldTriggerDeferBlock(injector))
|
|
643
836
|
return;
|
|
644
837
|
const tDetails = getTDeferBlockDetails(tView, tNode);
|
|
645
|
-
// Condition is triggered, try to render loading state and start downloading.
|
|
646
|
-
// Note: if a block is in a loading, completed or an error state, this call would be a noop.
|
|
647
|
-
renderDeferBlockState(DeferBlockState.Loading, tNode, lContainer);
|
|
648
838
|
switch (tDetails.loadingState) {
|
|
649
839
|
case DeferDependenciesLoadingState.NOT_STARTED:
|
|
840
|
+
renderDeferBlockState(DeferBlockState.Loading, tNode, lContainer);
|
|
650
841
|
triggerResourceLoading(tDetails, lView);
|
|
651
842
|
// The `loadingState` might have changed to "loading".
|
|
652
843
|
if (tDetails.loadingState ===
|
|
@@ -655,6 +846,7 @@ function triggerDeferBlock(lView, tNode) {
|
|
|
655
846
|
}
|
|
656
847
|
break;
|
|
657
848
|
case DeferDependenciesLoadingState.IN_PROGRESS:
|
|
849
|
+
renderDeferBlockState(DeferBlockState.Loading, tNode, lContainer);
|
|
658
850
|
renderDeferStateAfterResourceLoading(tDetails, tNode, lContainer);
|
|
659
851
|
break;
|
|
660
852
|
case DeferDependenciesLoadingState.COMPLETE:
|
|
@@ -820,6 +1012,7 @@ class OnIdleScheduler {
|
|
|
820
1012
|
// Set of callbacks collected while invoking current set of callbacks.
|
|
821
1013
|
// Those callbacks are scheduled for the next idle period.
|
|
822
1014
|
this.deferred = new Set();
|
|
1015
|
+
this.ngZone = inject(NgZone);
|
|
823
1016
|
this.requestIdleCallback = _requestIdleCallback().bind(globalThis);
|
|
824
1017
|
this.cancelIdleCallback = _cancelIdleCallback().bind(globalThis);
|
|
825
1018
|
}
|
|
@@ -855,7 +1048,9 @@ class OnIdleScheduler {
|
|
|
855
1048
|
this.scheduleIdleCallback();
|
|
856
1049
|
}
|
|
857
1050
|
};
|
|
858
|
-
|
|
1051
|
+
// Ensure that the callback runs in the NgZone since
|
|
1052
|
+
// the `requestIdleCallback` is not currently patched by Zone.js.
|
|
1053
|
+
this.idleId = this.requestIdleCallback(() => this.ngZone.run(callback));
|
|
859
1054
|
}
|
|
860
1055
|
ngOnDestroy() {
|
|
861
1056
|
if (this.idleId !== null) {
|
|
@@ -872,4 +1067,159 @@ class OnIdleScheduler {
|
|
|
872
1067
|
factory: () => new OnIdleScheduler(),
|
|
873
1068
|
}); }
|
|
874
1069
|
}
|
|
875
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"defer.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/defer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {InjectionToken, Injector, ɵɵdefineInjectable} from '../../di';\nimport {inject} from '../../di/injector_compatibility';\nimport {findMatchingDehydratedView} from '../../hydration/views';\nimport {populateDehydratedViewsInLContainer} from '../../linker/view_container_ref';\nimport {assertDefined, assertElement, assertEqual, throwError} from '../../util/assert';\nimport {afterRender} from '../after_render_hooks';\nimport {assertIndexInDeclRange, assertLContainer, assertLView, assertTNodeForLView} from '../assert';\nimport {bindingUpdated} from '../bindings';\nimport {getComponentDef, getDirectiveDef, getPipeDef} from '../definition';\nimport {CONTAINER_HEADER_OFFSET, LContainer} from '../interfaces/container';\nimport {DEFER_BLOCK_STATE, DeferBlockBehavior, DeferBlockConfig, DeferBlockInternalState, DeferBlockState, DeferBlockTriggers, DeferDependenciesLoadingState, DeferredLoadingBlockConfig, DeferredPlaceholderBlockConfig, DependencyResolverFn, LDeferBlockDetails, TDeferBlockDetails} from '../interfaces/defer';\nimport {DirectiveDefList, PipeDefList} from '../interfaces/definition';\nimport {TContainerNode, TNode} from '../interfaces/node';\nimport {isDestroyed, isLContainer, isLView} from '../interfaces/type_checks';\nimport {FLAGS, HEADER_OFFSET, INJECTOR, LView, LViewFlags, PARENT, TVIEW, TView} from '../interfaces/view';\nimport {getCurrentTNode, getLView, getSelectedTNode, getTView, nextBindingIndex} from '../state';\nimport {isPlatformBrowser} from '../util/misc_utils';\nimport {getConstant, getNativeByIndex, getTNode, removeLViewOnDestroy, storeLViewOnDestroy, walkUpViews} from '../util/view_utils';\nimport {addLViewToLContainer, createAndRenderEmbeddedLView, removeLViewFromLContainer, shouldAddViewToDom} from '../view_manipulation';\n\nimport {onHover, onInteraction, onViewport} from './defer_events';\nimport {ɵɵtemplate} from './template';\n\n/**\n * Returns whether defer blocks should be triggered.\n *\n * Currently, defer blocks are not triggered on the server,\n * only placeholder content is rendered (if provided).\n */\nfunction shouldTriggerDeferBlock(injector: Injector): boolean {\n  const config = injector.get(DEFER_BLOCK_CONFIG, null, {optional: true});\n  if (config?.behavior === DeferBlockBehavior.Manual) {\n    return false;\n  }\n  return isPlatformBrowser(injector);\n}\n\n/**\n * Creates runtime data structures for defer blocks.\n *\n * @param index Index of the `defer` instruction.\n * @param primaryTmplIndex Index of the template with the primary block content.\n * @param dependencyResolverFn Function that contains dependencies for this defer block.\n * @param loadingTmplIndex Index of the template with the loading block content.\n * @param placeholderTmplIndex Index of the template with the placeholder block content.\n * @param errorTmplIndex Index of the template with the error block content.\n * @param loadingConfigIndex Index in the constants array of the configuration of the loading.\n *     block.\n * @param placeholderConfigIndexIndex in the constants array of the configuration of the\n *     placeholder block.\n *\n * @codeGenApi\n */\nexport function ɵɵdefer(\n    index: number, primaryTmplIndex: number, dependencyResolverFn?: DependencyResolverFn|null,\n    loadingTmplIndex?: number|null, placeholderTmplIndex?: number|null,\n    errorTmplIndex?: number|null, loadingConfigIndex?: number|null,\n    placeholderConfigIndex?: number|null) {\n  const lView = getLView();\n  const tView = getTView();\n  const tViewConsts = tView.consts;\n  const adjustedIndex = index + HEADER_OFFSET;\n\n  ɵɵtemplate(index, null, 0, 0);\n\n  if (tView.firstCreatePass) {\n    const deferBlockConfig: TDeferBlockDetails = {\n      primaryTmplIndex,\n      loadingTmplIndex: loadingTmplIndex ?? null,\n      placeholderTmplIndex: placeholderTmplIndex ?? null,\n      errorTmplIndex: errorTmplIndex ?? null,\n      placeholderBlockConfig: placeholderConfigIndex != null ?\n          getConstant<DeferredPlaceholderBlockConfig>(tViewConsts, placeholderConfigIndex) :\n          null,\n      loadingBlockConfig: loadingConfigIndex != null ?\n          getConstant<DeferredLoadingBlockConfig>(tViewConsts, loadingConfigIndex) :\n          null,\n      dependencyResolverFn: dependencyResolverFn ?? null,\n      loadingState: DeferDependenciesLoadingState.NOT_STARTED,\n      loadingPromise: null,\n    };\n\n    setTDeferBlockDetails(tView, adjustedIndex, deferBlockConfig);\n  }\n\n  const tNode = getCurrentTNode()!;\n  const lContainer = lView[adjustedIndex];\n\n  // If hydration is enabled, looks up dehydrated views in the DOM\n  // using hydration annotation info and stores those views on LContainer.\n  // In client-only mode, this function is a noop.\n  populateDehydratedViewsInLContainer(lContainer, tNode, lView);\n\n  // Init instance-specific defer details and store it.\n  const lDetails = [];\n  lDetails[DEFER_BLOCK_STATE] = DeferBlockInternalState.Initial;\n  setLDeferBlockDetails(lView, adjustedIndex, lDetails as LDeferBlockDetails);\n}\n\n/**\n * Loads defer block dependencies when a trigger value becomes truthy.\n * @codeGenApi\n */\nexport function ɵɵdeferWhen(rawValue: unknown) {\n  const lView = getLView();\n  const bindingIndex = nextBindingIndex();\n  if (bindingUpdated(lView, bindingIndex, rawValue)) {\n    const value = Boolean(rawValue);  // handle truthy or falsy values\n    const tNode = getSelectedTNode();\n    const lDetails = getLDeferBlockDetails(lView, tNode);\n    const renderedState = lDetails[DEFER_BLOCK_STATE];\n    if (value === false && renderedState === DeferBlockInternalState.Initial) {\n      // If nothing is rendered yet, render a placeholder (if defined).\n      renderPlaceholder(lView, tNode);\n    } else if (\n        value === true &&\n        (renderedState === DeferBlockInternalState.Initial ||\n         renderedState === DeferBlockState.Placeholder)) {\n      // The `when` condition has changed to `true`, trigger defer block loading\n      // if the block is either in initial (nothing is rendered) or a placeholder\n      // state.\n      triggerDeferBlock(lView, tNode);\n    }\n  }\n}\n\n/**\n * Prefetches the deferred content when a value becomes truthy.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchWhen(rawValue: unknown) {\n  const lView = getLView();\n  const bindingIndex = nextBindingIndex();\n\n  if (bindingUpdated(lView, bindingIndex, rawValue)) {\n    const value = Boolean(rawValue);  // handle truthy or falsy values\n    const tView = lView[TVIEW];\n    const tNode = getSelectedTNode();\n    const tDetails = getTDeferBlockDetails(tView, tNode);\n    if (value === true && tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n      // If loading has not been started yet, trigger it now.\n      triggerPrefetching(tDetails, lView);\n    }\n  }\n}\n\n/**\n * Sets up logic to handle the `on idle` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnIdle() {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  onIdle(() => triggerDeferBlock(lView, tNode), lView, true /* withLViewCleanup */);\n}\n\n/**\n * Sets up logic to handle the `prefetch on idle` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnIdle() {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    // Prevent scheduling more than one `requestIdleCallback` call\n    // for each defer block. For this reason we use only a trigger\n    // identifier in a key, so all instances would use the same key.\n    const key = String(DeferBlockTriggers.OnIdle);\n    const injector = lView[INJECTOR]!;\n    const manager = injector.get(DeferBlockCleanupManager);\n    if (!manager.has(tDetails, key)) {\n      // In case of prefetching, we intentionally avoid cancelling resource loading if\n      // an underlying LView get destroyed (thus passing `null` as a second argument),\n      // because there might be other LViews (that represent embedded views) that\n      // depend on resource loading.\n      const prefetch = () => triggerPrefetching(tDetails, lView);\n      const cleanupFn = onIdle(prefetch, lView, false /* withLViewCleanup */);\n      registerTDetailsCleanup(injector, tDetails, key, cleanupFn);\n    }\n  }\n}\n\n/**\n * Sets up logic to handle the `on immediate` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnImmediate() {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  // Render placeholder block only if loading template is not present\n  // to avoid content flickering, since it would be immediately replaced\n  // by the loading block.\n  if (tDetails.loadingTmplIndex === null) {\n    renderPlaceholder(lView, tNode);\n  }\n  triggerDeferBlock(lView, tNode);\n}\n\n\n/**\n * Sets up logic to handle the `prefetch on immediate` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnImmediate() {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    triggerResourceLoading(tDetails, lView);\n  }\n}\n\n/**\n * Creates runtime data structures for the `on timer` deferred trigger.\n * @param delay Amount of time to wait before loading the content.\n * @codeGenApi\n */\nexport function ɵɵdeferOnTimer(delay: number) {}  // TODO: implement runtime logic.\n\n/**\n * Creates runtime data structures for the `prefetch on timer` deferred trigger.\n * @param delay Amount of time to wait before prefetching the content.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnTimer(delay: number) {}  // TODO: implement runtime logic.\n\n/**\n * Creates runtime data structures for the `on hover` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnHover(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  registerDomTrigger(\n      lView, tNode, triggerIndex, walkUpTimes, onHover, () => triggerDeferBlock(lView, tNode));\n}\n\n/**\n * Creates runtime data structures for the `prefetch on hover` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnHover(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    registerDomTrigger(\n        lView, tNode, triggerIndex, walkUpTimes, onHover,\n        () => triggerPrefetching(tDetails, lView));\n  }\n}\n\n/**\n * Creates runtime data structures for the `on interaction` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnInteraction(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  registerDomTrigger(\n      lView, tNode, triggerIndex, walkUpTimes, onInteraction,\n      () => triggerDeferBlock(lView, tNode));\n}\n\n/**\n * Creates runtime data structures for the `prefetch on interaction` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnInteraction(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    registerDomTrigger(\n        lView, tNode, triggerIndex, walkUpTimes, onInteraction,\n        () => triggerPrefetching(tDetails, lView));\n  }\n}\n\n/**\n * Creates runtime data structures for the `on viewport` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnViewport(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  registerDomTrigger(\n      lView, tNode, triggerIndex, walkUpTimes, onViewport, () => triggerDeferBlock(lView, tNode));\n}\n\n/**\n * Creates runtime data structures for the `prefetch on viewport` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnViewport(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    registerDomTrigger(\n        lView, tNode, triggerIndex, walkUpTimes, onViewport,\n        () => triggerPrefetching(tDetails, lView));\n  }\n}\n\n/********** Helper functions **********/\n\n/**\n * Helper function to get the LView in which a deferred block's trigger is rendered.\n * @param deferredHostLView LView in which the deferred block is defined.\n * @param deferredTNode TNode defining the deferred block.\n * @param walkUpTimes Number of times to go up in the view hierarchy to find the trigger's view.\n *   A negative value means that the trigger is inside the block's placeholder, while an undefined\n *   value means that the trigger is in the same LView as the deferred block.\n */\nfunction getTriggerLView(\n    deferredHostLView: LView, deferredTNode: TNode, walkUpTimes: number|undefined): LView|null {\n  // The trigger is in the same view, we don't need to traverse.\n  if (walkUpTimes == null) {\n    return deferredHostLView;\n  }\n\n  // A positive value or zero means that the trigger is in a parent view.\n  if (walkUpTimes >= 0) {\n    return walkUpViews(walkUpTimes, deferredHostLView);\n  }\n\n  // If the value is negative, it means that the trigger is inside the placeholder.\n  const deferredContainer = deferredHostLView[deferredTNode.index];\n  ngDevMode && assertLContainer(deferredContainer);\n  const triggerLView = deferredContainer[CONTAINER_HEADER_OFFSET] ?? null;\n\n  // We need to null check, because the placeholder might not have been rendered yet.\n  if (ngDevMode && triggerLView !== null) {\n    const lDetails = getLDeferBlockDetails(deferredHostLView, deferredTNode);\n    const renderedState = lDetails[DEFER_BLOCK_STATE];\n    assertEqual(\n        renderedState, DeferBlockState.Placeholder,\n        'Expected a placeholder to be rendered in this defer block.');\n    assertLView(triggerLView);\n  }\n\n  return triggerLView;\n}\n\n/**\n * Gets the element that a deferred block's trigger is pointing to.\n * @param triggerLView LView in which the trigger is defined.\n * @param triggerIndex Index at which the trigger element should've been rendered.\n */\nfunction getTriggerElement(triggerLView: LView, triggerIndex: number): Element {\n  const element = getNativeByIndex(HEADER_OFFSET + triggerIndex, triggerLView);\n  ngDevMode && assertElement(element);\n  return element as Element;\n}\n\n/**\n * Registers a DOM-node based trigger.\n * @param initialLView LView in which the defer block is rendered.\n * @param tNode TNode representing the defer block.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to go up/down in the view hierarchy to find the trigger.\n * @param registerFn Function that will register the DOM events.\n * @param callback Callback to be invoked when the trigger receives the event that should render\n *     the deferred block.\n */\nfunction registerDomTrigger(\n    initialLView: LView, tNode: TNode, triggerIndex: number, walkUpTimes: number|undefined,\n    registerFn: (element: Element, callback: VoidFunction, injector: Injector) => VoidFunction,\n    callback: VoidFunction) {\n  const injector = initialLView[INJECTOR]!;\n\n  // Assumption: the `afterRender` reference should be destroyed\n  // automatically so we don't need to keep track of it.\n  const afterRenderRef = afterRender(() => {\n    const lDetails = getLDeferBlockDetails(initialLView, tNode);\n    const renderedState = lDetails[DEFER_BLOCK_STATE];\n\n    // If the block was loaded before the trigger was resolved, we don't need to do anything.\n    if (renderedState !== DeferBlockInternalState.Initial &&\n        renderedState !== DeferBlockState.Placeholder) {\n      afterRenderRef.destroy();\n      return;\n    }\n\n    const triggerLView = getTriggerLView(initialLView, tNode, walkUpTimes);\n\n    // Keep polling until we resolve the trigger's LView.\n    // `afterRender` should stop automatically if the view is destroyed.\n    if (!triggerLView) {\n      return;\n    }\n\n    // It's possible that the trigger's view was destroyed before we resolved the trigger element.\n    if (triggerLView[FLAGS] & LViewFlags.Destroyed) {\n      afterRenderRef.destroy();\n      return;\n    }\n\n    // TODO: add integration with `DeferBlockCleanupManager`.\n    const element = getTriggerElement(triggerLView, triggerIndex);\n    const cleanup = registerFn(element, () => {\n      callback();\n      removeLViewOnDestroy(triggerLView, cleanup);\n      if (initialLView !== triggerLView) {\n        removeLViewOnDestroy(initialLView, cleanup);\n      }\n      cleanup();\n    }, injector);\n\n    afterRenderRef.destroy();\n    storeLViewOnDestroy(triggerLView, cleanup);\n\n    // Since the trigger and deferred block might be in different\n    // views, we have to register the callback in both locations.\n    if (initialLView !== triggerLView) {\n      storeLViewOnDestroy(initialLView, cleanup);\n    }\n  }, {injector});\n}\n\n/**\n * Helper function to schedule a callback to be invoked when a browser becomes idle.\n *\n * @param callback A function to be invoked when a browser becomes idle.\n * @param lView LView that hosts an instance of a defer block.\n * @param withLViewCleanup A flag that indicates whether a scheduled callback\n *           should be cancelled in case an LView is destroyed before a callback\n *           was invoked.\n */\nfunction onIdle(callback: VoidFunction, lView: LView, withLViewCleanup: boolean) {\n  const injector = lView[INJECTOR]!;\n  const scheduler = injector.get(OnIdleScheduler);\n  const cleanupFn = () => scheduler.remove(callback);\n  const wrappedCallback =\n      withLViewCleanup ? wrapWithLViewCleanup(callback, lView, cleanupFn) : callback;\n  scheduler.add(wrappedCallback);\n  return cleanupFn;\n}\n\n/**\n * Wraps a given callback into a logic that registers a cleanup function\n * in the LView cleanup slot, to be invoked when an LView is destroyed.\n */\nfunction wrapWithLViewCleanup(\n    callback: VoidFunction, lView: LView, cleanup: VoidFunction): VoidFunction {\n  const wrappedCallback = () => {\n    callback();\n    removeLViewOnDestroy(lView, cleanup);\n  };\n  storeLViewOnDestroy(lView, cleanup);\n  return wrappedCallback;\n}\n\n/**\n * Calculates a data slot index for defer block info (either static or\n * instance-specific), given an index of a defer instruction.\n */\nfunction getDeferBlockDataIndex(deferBlockIndex: number) {\n  // Instance state is located at the *next* position\n  // after the defer block slot in an LView or TView.data.\n  return deferBlockIndex + 1;\n}\n\n/** Retrieves a defer block state from an LView, given a TNode that represents a block. */\nfunction getLDeferBlockDetails(lView: LView, tNode: TNode): LDeferBlockDetails {\n  const tView = lView[TVIEW];\n  const slotIndex = getDeferBlockDataIndex(tNode.index);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  return lView[slotIndex];\n}\n\n/** Stores a defer block instance state in LView. */\nfunction setLDeferBlockDetails(\n    lView: LView, deferBlockIndex: number, lDetails: LDeferBlockDetails) {\n  const tView = lView[TVIEW];\n  const slotIndex = getDeferBlockDataIndex(deferBlockIndex);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  lView[slotIndex] = lDetails;\n}\n\n/** Retrieves static info about a defer block, given a TView and a TNode that represents a block. */\nfunction getTDeferBlockDetails(tView: TView, tNode: TNode): TDeferBlockDetails {\n  const slotIndex = getDeferBlockDataIndex(tNode.index);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  return tView.data[slotIndex] as TDeferBlockDetails;\n}\n\n/** Stores a defer block static info in `TView.data`. */\nfunction setTDeferBlockDetails(\n    tView: TView, deferBlockIndex: number, deferBlockConfig: TDeferBlockDetails) {\n  const slotIndex = getDeferBlockDataIndex(deferBlockIndex);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  tView.data[slotIndex] = deferBlockConfig;\n}\n\nfunction getTemplateIndexForState(\n    newState: DeferBlockState, hostLView: LView, tNode: TNode): number|null {\n  const tView = hostLView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  switch (newState) {\n    case DeferBlockState.Complete:\n      return tDetails.primaryTmplIndex;\n    case DeferBlockState.Loading:\n      return tDetails.loadingTmplIndex;\n    case DeferBlockState.Error:\n      return tDetails.errorTmplIndex;\n    case DeferBlockState.Placeholder:\n      return tDetails.placeholderTmplIndex;\n    default:\n      ngDevMode && throwError(`Unexpected defer block state: ${newState}`);\n      return null;\n  }\n}\n\n/**\n * Transitions a defer block to the new state. Updates the  necessary\n * data structures and renders corresponding block.\n *\n * @param newState New state that should be applied to the defer block.\n * @param tNode TNode that represents a defer block.\n * @param lContainer Represents an instance of a defer block.\n */\nexport function renderDeferBlockState(\n    newState: DeferBlockState, tNode: TNode, lContainer: LContainer): void {\n  const hostLView = lContainer[PARENT];\n\n  // Check if this view is not destroyed. Since the loading process was async,\n  // the view might end up being destroyed by the time rendering happens.\n  if (isDestroyed(hostLView)) return;\n\n  // Make sure this TNode belongs to TView that represents host LView.\n  ngDevMode && assertTNodeForLView(tNode, hostLView);\n\n  const lDetails = getLDeferBlockDetails(hostLView, tNode);\n\n  ngDevMode && assertDefined(lDetails, 'Expected a defer block state defined');\n\n  const stateTmplIndex = getTemplateIndexForState(newState, hostLView, tNode);\n  // Note: we transition to the next state if the previous state was represented\n  // with a number that is less than the next state. For example, if the current\n  // state is \"loading\" (represented as `2`), we should not show a placeholder\n  // (represented as `1`).\n  if (lDetails[DEFER_BLOCK_STATE] < newState && stateTmplIndex !== null) {\n    lDetails[DEFER_BLOCK_STATE] = newState;\n    const hostTView = hostLView[TVIEW];\n    const adjustedIndex = stateTmplIndex + HEADER_OFFSET;\n    const tNode = getTNode(hostTView, adjustedIndex) as TContainerNode;\n\n    // There is only 1 view that can be present in an LContainer that\n    // represents a defer block, so always refer to the first one.\n    const viewIndex = 0;\n\n    removeLViewFromLContainer(lContainer, viewIndex);\n    const dehydratedView = findMatchingDehydratedView(lContainer, tNode.tView!.ssrId);\n    const embeddedLView = createAndRenderEmbeddedLView(hostLView, tNode, null, {dehydratedView});\n    addLViewToLContainer(\n        lContainer, embeddedLView, viewIndex, shouldAddViewToDom(tNode, dehydratedView));\n  }\n}\n\n/**\n * Trigger prefetching of dependencies for a defer block.\n *\n * @param tDetails Static information about this defer block.\n * @param lView LView of a host view.\n */\nexport function triggerPrefetching(tDetails: TDeferBlockDetails, lView: LView) {\n  if (lView[INJECTOR] && shouldTriggerDeferBlock(lView[INJECTOR]!)) {\n    triggerResourceLoading(tDetails, lView);\n  }\n}\n\n/**\n * Trigger loading of defer block dependencies if the process hasn't started yet.\n *\n * @param tDetails Static information about this defer block.\n * @param lView LView of a host view.\n */\nexport function triggerResourceLoading(tDetails: TDeferBlockDetails, lView: LView) {\n  const injector = lView[INJECTOR]!;\n  const tView = lView[TVIEW];\n\n  if (tDetails.loadingState !== DeferDependenciesLoadingState.NOT_STARTED) {\n    // If the loading status is different from initial one, it means that\n    // the loading of dependencies is in progress and there is nothing to do\n    // in this function. All details can be obtained from the `tDetails` object.\n    return;\n  }\n\n  const primaryBlockTNode = getPrimaryBlockTNode(tView, tDetails);\n\n  // Switch from NOT_STARTED -> IN_PROGRESS state.\n  tDetails.loadingState = DeferDependenciesLoadingState.IN_PROGRESS;\n\n  // Check if dependency function interceptor is configured.\n  const deferDependencyInterceptor =\n      injector.get(DEFER_BLOCK_DEPENDENCY_INTERCEPTOR, null, {optional: true});\n\n  const dependenciesFn = deferDependencyInterceptor ?\n      deferDependencyInterceptor.intercept(tDetails.dependencyResolverFn) :\n      tDetails.dependencyResolverFn;\n\n  // The `dependenciesFn` might be `null` when all dependencies within\n  // a given defer block were eagerly references elsewhere in a file,\n  // thus no dynamic `import()`s were produced.\n  if (!dependenciesFn) {\n    tDetails.loadingPromise = Promise.resolve().then(() => {\n      tDetails.loadingState = DeferDependenciesLoadingState.COMPLETE;\n    });\n    return;\n  }\n\n  // Defer block may have multiple prefetch triggers. Once the loading\n  // starts, invoke all clean functions, since they are no longer needed.\n  invokeTDetailsCleanup(injector, tDetails);\n\n  // Start downloading of defer block dependencies.\n  tDetails.loadingPromise = Promise.allSettled(dependenciesFn()).then(results => {\n    let failed = false;\n    const directiveDefs: DirectiveDefList = [];\n    const pipeDefs: PipeDefList = [];\n\n    for (const result of results) {\n      if (result.status === 'fulfilled') {\n        const dependency = result.value;\n        const directiveDef = getComponentDef(dependency) || getDirectiveDef(dependency);\n        if (directiveDef) {\n          directiveDefs.push(directiveDef);\n        } else {\n          const pipeDef = getPipeDef(dependency);\n          if (pipeDef) {\n            pipeDefs.push(pipeDef);\n          }\n        }\n      } else {\n        failed = true;\n        break;\n      }\n    }\n\n    // Loading is completed, we no longer need this Promise.\n    tDetails.loadingPromise = null;\n\n    if (failed) {\n      tDetails.loadingState = DeferDependenciesLoadingState.FAILED;\n    } else {\n      tDetails.loadingState = DeferDependenciesLoadingState.COMPLETE;\n\n      // Update directive and pipe registries to add newly downloaded dependencies.\n      const primaryBlockTView = primaryBlockTNode.tView!;\n      if (directiveDefs.length > 0) {\n        primaryBlockTView.directiveRegistry = primaryBlockTView.directiveRegistry ?\n            [...primaryBlockTView.directiveRegistry, ...directiveDefs] :\n            directiveDefs;\n      }\n      if (pipeDefs.length > 0) {\n        primaryBlockTView.pipeRegistry = primaryBlockTView.pipeRegistry ?\n            [...primaryBlockTView.pipeRegistry, ...pipeDefs] :\n            pipeDefs;\n      }\n    }\n  });\n}\n\n/** Utility function to render placeholder content (if present) */\nfunction renderPlaceholder(lView: LView, tNode: TNode) {\n  const tView = lView[TVIEW];\n  const lContainer = lView[tNode.index];\n  ngDevMode && assertLContainer(lContainer);\n\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n  renderDeferBlockState(DeferBlockState.Placeholder, tNode, lContainer);\n}\n\n/**\n * Subscribes to the \"loading\" Promise and renders corresponding defer sub-block,\n * based on the loading results.\n *\n * @param lContainer Represents an instance of a defer block.\n * @param tNode Represents defer block info shared across all instances.\n */\nfunction renderDeferStateAfterResourceLoading(\n    tDetails: TDeferBlockDetails, tNode: TNode, lContainer: LContainer) {\n  ngDevMode &&\n      assertDefined(\n          tDetails.loadingPromise, 'Expected loading Promise to exist on this defer block');\n\n  tDetails.loadingPromise!.then(() => {\n    if (tDetails.loadingState === DeferDependenciesLoadingState.COMPLETE) {\n      ngDevMode && assertDeferredDependenciesLoaded(tDetails);\n\n      // Everything is loaded, show the primary block content\n      renderDeferBlockState(DeferBlockState.Complete, tNode, lContainer);\n\n    } else if (tDetails.loadingState === DeferDependenciesLoadingState.FAILED) {\n      renderDeferBlockState(DeferBlockState.Error, tNode, lContainer);\n    }\n  });\n}\n\n/** Retrieves a TNode that represents main content of a defer block. */\nfunction getPrimaryBlockTNode(tView: TView, tDetails: TDeferBlockDetails): TContainerNode {\n  const adjustedIndex = tDetails.primaryTmplIndex + HEADER_OFFSET;\n  return getTNode(tView, adjustedIndex) as TContainerNode;\n}\n\n/**\n * Attempts to trigger loading of defer block dependencies.\n * If the block is already in a loading, completed or an error state -\n * no additional actions are taken.\n */\nfunction triggerDeferBlock(lView: LView, tNode: TNode) {\n  const tView = lView[TVIEW];\n  const lContainer = lView[tNode.index];\n  const injector = lView[INJECTOR]!;\n  ngDevMode && assertLContainer(lContainer);\n\n  if (!shouldTriggerDeferBlock(injector)) return;\n\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  // Condition is triggered, try to render loading state and start downloading.\n  // Note: if a block is in a loading, completed or an error state, this call would be a noop.\n  renderDeferBlockState(DeferBlockState.Loading, tNode, lContainer);\n\n  switch (tDetails.loadingState) {\n    case DeferDependenciesLoadingState.NOT_STARTED:\n      triggerResourceLoading(tDetails, lView);\n\n      // The `loadingState` might have changed to \"loading\".\n      if ((tDetails.loadingState as DeferDependenciesLoadingState) ===\n          DeferDependenciesLoadingState.IN_PROGRESS) {\n        renderDeferStateAfterResourceLoading(tDetails, tNode, lContainer);\n      }\n      break;\n    case DeferDependenciesLoadingState.IN_PROGRESS:\n      renderDeferStateAfterResourceLoading(tDetails, tNode, lContainer);\n      break;\n    case DeferDependenciesLoadingState.COMPLETE:\n      ngDevMode && assertDeferredDependenciesLoaded(tDetails);\n      renderDeferBlockState(DeferBlockState.Complete, tNode, lContainer);\n      break;\n    case DeferDependenciesLoadingState.FAILED:\n      renderDeferBlockState(DeferBlockState.Error, tNode, lContainer);\n      break;\n    default:\n      if (ngDevMode) {\n        throwError('Unknown defer block state');\n      }\n  }\n}\n\n/**\n * Asserts whether all dependencies for a defer block are loaded.\n * Always run this function (in dev mode) before rendering a defer\n * block in completed state.\n */\nfunction assertDeferredDependenciesLoaded(tDetails: TDeferBlockDetails) {\n  assertEqual(\n      tDetails.loadingState, DeferDependenciesLoadingState.COMPLETE,\n      'Expecting all deferred dependencies to be loaded.');\n}\n\n/**\n * **INTERNAL**, avoid referencing it in application code.\n *\n * Describes a helper class that allows to intercept a call to retrieve current\n * dependency loading function and replace it with a different implementation.\n * This interceptor class is needed to allow testing blocks in different states\n * by simulating loading response.\n */\nexport interface DeferBlockDependencyInterceptor {\n  /**\n   * Invoked for each defer block when dependency loading function is accessed.\n   */\n  intercept(dependencyFn: DependencyResolverFn|null): DependencyResolverFn|null;\n\n  /**\n   * Allows to configure an interceptor function.\n   */\n  setInterceptor(interceptorFn: (current: DependencyResolverFn) => DependencyResolverFn): void;\n}\n\n/**\n * **INTERNAL**, avoid referencing it in application code.\n *\n * Injector token that allows to provide `DeferBlockDependencyInterceptor` class\n * implementation.\n */\nexport const DEFER_BLOCK_DEPENDENCY_INTERCEPTOR =\n    new InjectionToken<DeferBlockDependencyInterceptor>(\n        ngDevMode ? 'DEFER_BLOCK_DEPENDENCY_INTERCEPTOR' : '');\n\n/**\n * Determines if a given value matches the expected structure of a defer block\n *\n * We can safely rely on the primaryTmplIndex because every defer block requires\n * that a primary template exists. All the other template options are optional.\n */\nfunction isTDeferBlockDetails(value: unknown): value is TDeferBlockDetails {\n  return (typeof value === 'object') &&\n      (typeof (value as TDeferBlockDetails).primaryTmplIndex === 'number');\n}\n\n/**\n * Internal token used for configuring defer block behavior.\n */\nexport const DEFER_BLOCK_CONFIG =\n    new InjectionToken<DeferBlockConfig>(ngDevMode ? 'DEFER_BLOCK_CONFIG' : '');\n\n/**\n * Defer block instance for testing.\n */\nexport interface DeferBlockDetails {\n  lContainer: LContainer;\n  lView: LView;\n  tNode: TNode;\n  tDetails: TDeferBlockDetails;\n}\n\n/**\n * Retrieves all defer blocks in a given LView.\n *\n * @param lView lView with defer blocks\n * @param deferBlocks defer block aggregator array\n */\nexport function getDeferBlocks(lView: LView, deferBlocks: DeferBlockDetails[]) {\n  const tView = lView[TVIEW];\n  for (let i = HEADER_OFFSET; i < tView.bindingStartIndex; i++) {\n    if (isLContainer(lView[i])) {\n      const lContainer = lView[i];\n      // An LContainer may represent an instance of a defer block, in which case\n      // we store it as a result. Otherwise, keep iterating over LContainer views and\n      // look for defer blocks.\n      const isLast = i === tView.bindingStartIndex - 1;\n      if (!isLast) {\n        const tNode = tView.data[i] as TNode;\n        const tDetails = getTDeferBlockDetails(tView, tNode);\n        if (isTDeferBlockDetails(tDetails)) {\n          deferBlocks.push({lContainer, lView, tNode, tDetails});\n          // This LContainer represents a defer block, so we exit\n          // this iteration and don't inspect views in this LContainer.\n          continue;\n        }\n      }\n      for (let i = CONTAINER_HEADER_OFFSET; i < lContainer.length; i++) {\n        getDeferBlocks(lContainer[i] as LView, deferBlocks);\n      }\n    } else if (isLView(lView[i])) {\n      // This is a component, enter the `getDeferBlocks` recursively.\n      getDeferBlocks(lView[i], deferBlocks);\n    }\n  }\n}\n\n/**\n * Registers a cleanup function associated with a prefetching trigger\n * of a given defer block.\n */\nfunction registerTDetailsCleanup(\n    injector: Injector, tDetails: TDeferBlockDetails, key: string, cleanupFn: VoidFunction) {\n  injector.get(DeferBlockCleanupManager).add(tDetails, key, cleanupFn);\n}\n\n/**\n * Invokes all registered prefetch cleanup triggers\n * and removes all cleanup functions afterwards.\n */\nfunction invokeTDetailsCleanup(injector: Injector, tDetails: TDeferBlockDetails) {\n  injector.get(DeferBlockCleanupManager).cleanup(tDetails);\n}\n\n/**\n * Internal service to keep track of cleanup functions associated\n * with defer blocks. This class is used to manage cleanup functions\n * created for prefetching triggers.\n */\nclass DeferBlockCleanupManager {\n  private blocks = new Map<TDeferBlockDetails, Map<string, VoidFunction[]>>();\n\n  add(tDetails: TDeferBlockDetails, key: string, callback: VoidFunction) {\n    if (!this.blocks.has(tDetails)) {\n      this.blocks.set(tDetails, new Map());\n    }\n    const block = this.blocks.get(tDetails)!;\n    if (!block.has(key)) {\n      block.set(key, []);\n    }\n    const callbacks = block.get(key)!;\n    callbacks.push(callback);\n  }\n\n  has(tDetails: TDeferBlockDetails, key: string): boolean {\n    return !!this.blocks.get(tDetails)?.has(key);\n  }\n\n  cleanup(tDetails: TDeferBlockDetails) {\n    const block = this.blocks.get(tDetails);\n    if (block) {\n      for (const callbacks of Object.values(block)) {\n        for (const callback of callbacks) {\n          callback();\n        }\n      }\n      this.blocks.delete(tDetails);\n    }\n  }\n\n  ngOnDestroy() {\n    for (const [block] of this.blocks) {\n      this.cleanup(block);\n    }\n    this.blocks.clear();\n  }\n\n  /** @nocollapse */\n  static ɵprov = /** @pureOrBreakMyCode */ ɵɵdefineInjectable({\n    token: DeferBlockCleanupManager,\n    providedIn: 'root',\n    factory: () => new DeferBlockCleanupManager(),\n  });\n}\n\n/**\n * Use shims for the `requestIdleCallback` and `cancelIdleCallback` functions for\n * environments where those functions are not available (e.g. Node.js and Safari).\n *\n * Note: we wrap the `requestIdleCallback` call into a function, so that it can be\n * overridden/mocked in test environment and picked up by the runtime code.\n */\nconst _requestIdleCallback = () =>\n    typeof requestIdleCallback !== 'undefined' ? requestIdleCallback : setTimeout;\nconst _cancelIdleCallback = () =>\n    typeof requestIdleCallback !== 'undefined' ? cancelIdleCallback : clearTimeout;\n\n/**\n * Helper service to schedule `requestIdleCallback`s for batches of defer blocks,\n * to avoid calling `requestIdleCallback` for each defer block (e.g. if\n * defer blocks are defined inside a for loop).\n */\nclass OnIdleScheduler {\n  // Indicates whether current callbacks are being invoked.\n  executingCallbacks = false;\n\n  // Currently scheduled idle callback id.\n  idleId: number|null = null;\n\n  // Set of callbacks to be invoked next.\n  current = new Set<VoidFunction>();\n\n  // Set of callbacks collected while invoking current set of callbacks.\n  // Those callbacks are scheduled for the next idle period.\n  deferred = new Set<VoidFunction>();\n\n  requestIdleCallback = _requestIdleCallback().bind(globalThis);\n  cancelIdleCallback = _cancelIdleCallback().bind(globalThis);\n\n  add(callback: VoidFunction) {\n    const target = this.executingCallbacks ? this.deferred : this.current;\n    target.add(callback);\n    if (this.idleId === null) {\n      this.scheduleIdleCallback();\n    }\n  }\n\n  remove(callback: VoidFunction) {\n    this.current.delete(callback);\n    this.deferred.delete(callback);\n  }\n\n  private scheduleIdleCallback() {\n    const callback = () => {\n      this.cancelIdleCallback(this.idleId!);\n      this.idleId = null;\n\n      this.executingCallbacks = true;\n\n      for (const callback of this.current) {\n        callback();\n      }\n      this.current.clear();\n\n      this.executingCallbacks = false;\n\n      // If there are any callbacks added during an invocation\n      // of the current ones - make them \"current\" and schedule\n      // a new idle callback.\n      if (this.deferred.size > 0) {\n        for (const callback of this.deferred) {\n          this.current.add(callback);\n        }\n        this.deferred.clear();\n        this.scheduleIdleCallback();\n      }\n    };\n    this.idleId = this.requestIdleCallback(callback) as number;\n  }\n\n  ngOnDestroy() {\n    if (this.idleId !== null) {\n      this.cancelIdleCallback(this.idleId);\n      this.idleId = null;\n    }\n    this.current.clear();\n    this.deferred.clear();\n  }\n\n  /** @nocollapse */\n  static ɵprov = /** @pureOrBreakMyCode */ ɵɵdefineInjectable({\n    token: OnIdleScheduler,\n    providedIn: 'root',\n    factory: () => new OnIdleScheduler(),\n  });\n}\n"]}
|
|
1070
|
+
/**
|
|
1071
|
+
* Helper service to schedule `setTimeout`s for batches of defer blocks,
|
|
1072
|
+
* to avoid calling `setTimeout` for each defer block (e.g. if defer blocks
|
|
1073
|
+
* are created inside a for loop).
|
|
1074
|
+
*/
|
|
1075
|
+
class TimerScheduler {
|
|
1076
|
+
constructor() {
|
|
1077
|
+
// Indicates whether current callbacks are being invoked.
|
|
1078
|
+
this.executingCallbacks = false;
|
|
1079
|
+
// Currently scheduled `setTimeout` id.
|
|
1080
|
+
this.timeoutId = null;
|
|
1081
|
+
// When currently scheduled timer would fire.
|
|
1082
|
+
this.invokeTimerAt = null;
|
|
1083
|
+
// List of callbacks to be invoked.
|
|
1084
|
+
// For each callback we also store a timestamp on when the callback
|
|
1085
|
+
// should be invoked. We store timestamps and callback functions
|
|
1086
|
+
// in a flat array to avoid creating new objects for each entry.
|
|
1087
|
+
// [timestamp1, callback1, timestamp2, callback2, ...]
|
|
1088
|
+
this.current = [];
|
|
1089
|
+
// List of callbacks collected while invoking current set of callbacks.
|
|
1090
|
+
// Those callbacks are added to the "current" queue at the end of
|
|
1091
|
+
// the current callback invocation. The shape of this list is the same
|
|
1092
|
+
// as the shape of the `current` list.
|
|
1093
|
+
this.deferred = [];
|
|
1094
|
+
}
|
|
1095
|
+
add(delay, callback) {
|
|
1096
|
+
const target = this.executingCallbacks ? this.deferred : this.current;
|
|
1097
|
+
this.addToQueue(target, Date.now() + delay, callback);
|
|
1098
|
+
this.scheduleTimer();
|
|
1099
|
+
}
|
|
1100
|
+
remove(callback) {
|
|
1101
|
+
const callbackIndex = this.removeFromQueue(this.current, callback);
|
|
1102
|
+
if (callbackIndex === -1) {
|
|
1103
|
+
// Try cleaning up deferred queue only in case
|
|
1104
|
+
// we didn't find a callback in the "current" queue.
|
|
1105
|
+
this.removeFromQueue(this.deferred, callback);
|
|
1106
|
+
}
|
|
1107
|
+
}
|
|
1108
|
+
addToQueue(target, invokeAt, callback) {
|
|
1109
|
+
let insertAtIndex = target.length;
|
|
1110
|
+
for (let i = 0; i < target.length; i += 2) {
|
|
1111
|
+
const invokeQueuedCallbackAt = target[i];
|
|
1112
|
+
if (invokeQueuedCallbackAt > invokeAt) {
|
|
1113
|
+
// We've reached a first timer that is scheduled
|
|
1114
|
+
// for a later time than what we are trying to insert.
|
|
1115
|
+
// This is the location at which we need to insert,
|
|
1116
|
+
// no need to iterate further.
|
|
1117
|
+
insertAtIndex = i;
|
|
1118
|
+
break;
|
|
1119
|
+
}
|
|
1120
|
+
}
|
|
1121
|
+
arrayInsert2(target, insertAtIndex, invokeAt, callback);
|
|
1122
|
+
}
|
|
1123
|
+
removeFromQueue(target, callback) {
|
|
1124
|
+
let index = -1;
|
|
1125
|
+
for (let i = 0; i < target.length; i += 2) {
|
|
1126
|
+
const queuedCallback = target[i + 1];
|
|
1127
|
+
if (queuedCallback === callback) {
|
|
1128
|
+
index = i;
|
|
1129
|
+
break;
|
|
1130
|
+
}
|
|
1131
|
+
}
|
|
1132
|
+
if (index > -1) {
|
|
1133
|
+
// Remove 2 elements: a timestamp slot and
|
|
1134
|
+
// the following slot with a callback function.
|
|
1135
|
+
arraySplice(target, index, 2);
|
|
1136
|
+
}
|
|
1137
|
+
return index;
|
|
1138
|
+
}
|
|
1139
|
+
scheduleTimer() {
|
|
1140
|
+
const callback = () => {
|
|
1141
|
+
clearTimeout(this.timeoutId);
|
|
1142
|
+
this.timeoutId = null;
|
|
1143
|
+
this.executingCallbacks = true;
|
|
1144
|
+
// Invoke callbacks that were scheduled to run
|
|
1145
|
+
// before the current time.
|
|
1146
|
+
let now = Date.now();
|
|
1147
|
+
let lastCallbackIndex = null;
|
|
1148
|
+
for (let i = 0; i < this.current.length; i += 2) {
|
|
1149
|
+
const invokeAt = this.current[i];
|
|
1150
|
+
const callback = this.current[i + 1];
|
|
1151
|
+
if (invokeAt <= now) {
|
|
1152
|
+
callback();
|
|
1153
|
+
// Point at the invoked callback function, which is located
|
|
1154
|
+
// after the timestamp.
|
|
1155
|
+
lastCallbackIndex = i + 1;
|
|
1156
|
+
}
|
|
1157
|
+
else {
|
|
1158
|
+
// We've reached a timer that should not be invoked yet.
|
|
1159
|
+
break;
|
|
1160
|
+
}
|
|
1161
|
+
}
|
|
1162
|
+
if (lastCallbackIndex !== null) {
|
|
1163
|
+
// If last callback index is `null` - no callbacks were invoked,
|
|
1164
|
+
// so no cleanup is needed. Otherwise, remove invoked callbacks
|
|
1165
|
+
// from the queue.
|
|
1166
|
+
arraySplice(this.current, 0, lastCallbackIndex + 1);
|
|
1167
|
+
}
|
|
1168
|
+
this.executingCallbacks = false;
|
|
1169
|
+
// If there are any callbacks added during an invocation
|
|
1170
|
+
// of the current ones - move them over to the "current"
|
|
1171
|
+
// queue.
|
|
1172
|
+
if (this.deferred.length > 0) {
|
|
1173
|
+
for (let i = 0; i < this.deferred.length; i += 2) {
|
|
1174
|
+
const invokeAt = this.deferred[i];
|
|
1175
|
+
const callback = this.deferred[i + 1];
|
|
1176
|
+
this.addToQueue(this.current, invokeAt, callback);
|
|
1177
|
+
}
|
|
1178
|
+
this.deferred.length = 0;
|
|
1179
|
+
}
|
|
1180
|
+
this.scheduleTimer();
|
|
1181
|
+
};
|
|
1182
|
+
// Avoid running timer callbacks more than once per
|
|
1183
|
+
// average frame duration. This is needed for better
|
|
1184
|
+
// batching and to avoid kicking off excessive change
|
|
1185
|
+
// detection cycles.
|
|
1186
|
+
const FRAME_DURATION_MS = 16; // 1000ms / 60fps
|
|
1187
|
+
if (this.current.length > 0) {
|
|
1188
|
+
const now = Date.now();
|
|
1189
|
+
// First element in the queue points at the timestamp
|
|
1190
|
+
// of the first (earliest) event.
|
|
1191
|
+
const invokeAt = this.current[0];
|
|
1192
|
+
if (!this.timeoutId ||
|
|
1193
|
+
// Reschedule a timer in case a queue contains an item with
|
|
1194
|
+
// an earlier timestamp and the delta is more than an average
|
|
1195
|
+
// frame duration.
|
|
1196
|
+
(this.invokeTimerAt && (this.invokeTimerAt - invokeAt > FRAME_DURATION_MS))) {
|
|
1197
|
+
if (this.timeoutId !== null) {
|
|
1198
|
+
// There was a timeout already, but an earlier event was added
|
|
1199
|
+
// into the queue. In this case we drop an old timer and setup
|
|
1200
|
+
// a new one with an updated (smaller) timeout.
|
|
1201
|
+
clearTimeout(this.timeoutId);
|
|
1202
|
+
this.timeoutId = null;
|
|
1203
|
+
}
|
|
1204
|
+
const timeout = Math.max(invokeAt - now, FRAME_DURATION_MS);
|
|
1205
|
+
this.invokeTimerAt = invokeAt;
|
|
1206
|
+
this.timeoutId = setTimeout(callback, timeout);
|
|
1207
|
+
}
|
|
1208
|
+
}
|
|
1209
|
+
}
|
|
1210
|
+
ngOnDestroy() {
|
|
1211
|
+
if (this.timeoutId !== null) {
|
|
1212
|
+
clearTimeout(this.timeoutId);
|
|
1213
|
+
this.timeoutId = null;
|
|
1214
|
+
}
|
|
1215
|
+
this.current.length = 0;
|
|
1216
|
+
this.deferred.length = 0;
|
|
1217
|
+
}
|
|
1218
|
+
/** @nocollapse */
|
|
1219
|
+
static { this.ɵprov = ɵɵdefineInjectable({
|
|
1220
|
+
token: TimerScheduler,
|
|
1221
|
+
providedIn: 'root',
|
|
1222
|
+
factory: () => new TimerScheduler(),
|
|
1223
|
+
}); }
|
|
1224
|
+
}
|
|
1225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"defer.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/defer.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,MAAM,EAAE,cAAc,EAAY,kBAAkB,EAAC,MAAM,UAAU,CAAC;AAC9E,OAAO,EAAC,0BAA0B,EAAC,MAAM,uBAAuB,CAAC;AACjE,OAAO,EAAC,mCAAmC,EAAC,MAAM,iCAAiC,CAAC;AACpF,OAAO,EAAC,YAAY,EAAE,WAAW,EAAC,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAC,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,EAAC,MAAM,mBAAmB,CAAC;AACxF,OAAO,EAAC,MAAM,EAAC,MAAM,YAAY,CAAC;AAClC,OAAO,EAAC,WAAW,EAAC,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAC,sBAAsB,EAAE,gBAAgB,EAAE,WAAW,EAAE,mBAAmB,EAAC,MAAM,WAAW,CAAC;AACrG,OAAO,EAAC,cAAc,EAAC,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAC,eAAe,EAAE,eAAe,EAAE,UAAU,EAAC,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAC,uBAAuB,EAAa,MAAM,yBAAyB,CAAC;AAC5E,OAAO,EAAC,iBAAiB,EAAE,kBAAkB,EAAoB,uBAAuB,EAAE,eAAe,EAAsB,6BAA6B,EAAwG,wBAAwB,EAAE,kBAAkB,EAAE,YAAY,EAAE,sBAAsB,EAAE,qBAAqB,EAAqB,MAAM,qBAAqB,CAAC;AAG9Z,OAAO,EAAC,WAAW,EAAE,YAAY,EAAE,OAAO,EAAC,MAAM,2BAA2B,CAAC;AAC7E,OAAO,EAAC,KAAK,EAAE,aAAa,EAAE,QAAQ,EAAqB,MAAM,EAAE,KAAK,EAAQ,MAAM,oBAAoB,CAAC;AAC3G,OAAO,EAAC,eAAe,EAAE,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,EAAE,gBAAgB,EAAC,MAAM,UAAU,CAAC;AACjG,OAAO,EAAC,iBAAiB,EAAC,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAC,WAAW,EAAE,gBAAgB,EAAE,QAAQ,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,WAAW,EAAC,MAAM,oBAAoB,CAAC;AACnI,OAAO,EAAC,oBAAoB,EAAE,4BAA4B,EAAE,yBAAyB,EAAE,kBAAkB,EAAC,MAAM,sBAAsB,CAAC;AAEvI,OAAO,EAAC,OAAO,EAAE,aAAa,EAAE,UAAU,EAAC,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAC,UAAU,EAAC,MAAM,YAAY,CAAC;AAEtC;;;;;GAKG;AACH,SAAS,uBAAuB,CAAC,QAAkB;IACjD,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,kBAAkB,EAAE,IAAI,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;IACxE,IAAI,MAAM,EAAE,QAAQ,KAAK,kBAAkB,CAAC,MAAM,EAAE;QAClD,OAAO,KAAK,CAAC;KACd;IACD,OAAO,iBAAiB,CAAC,QAAQ,CAAC,CAAC;AACrC,CAAC;AAED;;;;;;GAMG;AACH,IAAI,sCAAsC,GAAuC,IAAI,CAAC;AAEtF;;;GAGG;AACH,MAAM,UAAU,4BAA4B,CACxC,KAAY,EAAE,QAA4B,EAAE,sBAAoC,EAChF,kBAAgC;IAClC,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC;IACjC,IAAI,sBAAsB,IAAI,IAAI,EAAE;QAClC,QAAQ,CAAC,sBAAsB;YAC3B,WAAW,CAAiC,WAAW,EAAE,sBAAsB,CAAC,CAAC;KACtF;IACD,IAAI,kBAAkB,IAAI,IAAI,EAAE;QAC9B,QAAQ,CAAC,kBAAkB;YACvB,WAAW,CAA6B,WAAW,EAAE,kBAAkB,CAAC,CAAC;KAC9E;IAED,8DAA8D;IAC9D,IAAI,sCAAsC,KAAK,IAAI,EAAE;QACnD,sCAAsC,GAAG,kCAAkC,CAAC;KAC7E;AACH,CAAC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,UAAU,OAAO,CACnB,KAAa,EAAE,gBAAwB,EAAE,oBAAgD,EACzF,gBAA8B,EAAE,oBAAkC,EAClE,cAA4B,EAAE,kBAAgC,EAC9D,sBAAoC,EACpC,qBAA2D;IAC7D,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,aAAa,GAAG,KAAK,GAAG,aAAa,CAAC;IAE5C,UAAU,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAE9B,IAAI,KAAK,CAAC,eAAe,EAAE;QACzB,MAAM,QAAQ,GAAuB;YACnC,gBAAgB;YAChB,gBAAgB,EAAE,gBAAgB,IAAI,IAAI;YAC1C,oBAAoB,EAAE,oBAAoB,IAAI,IAAI;YAClD,cAAc,EAAE,cAAc,IAAI,IAAI;YACtC,sBAAsB,EAAE,IAAI;YAC5B,kBAAkB,EAAE,IAAI;YACxB,oBAAoB,EAAE,oBAAoB,IAAI,IAAI;YAClD,YAAY,EAAE,6BAA6B,CAAC,WAAW;YACvD,cAAc,EAAE,IAAI;SACrB,CAAC;QACF,qBAAqB,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,sBAAsB,EAAE,kBAAkB,CAAC,CAAC;QACrF,qBAAqB,CAAC,KAAK,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;KACvD;IAED,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,UAAU,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC;IAExC,gEAAgE;IAChE,wEAAwE;IACxE,gDAAgD;IAChD,mCAAmC,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAE9D,qDAAqD;IACrD,MAAM,QAAQ,GAAuB;QACnC,IAAI;QACJ,uBAAuB,CAAC,OAAO;QAC/B,IAAI;QACJ,IAAI,CAA8B,2BAA2B;KAC9D,CAAC;IACF,qBAAqB,CAAC,KAAK,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,WAAW,CAAC,QAAiB;IAC3C,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,YAAY,GAAG,gBAAgB,EAAE,CAAC;IACxC,IAAI,cAAc,CAAC,KAAK,EAAE,YAAY,EAAE,QAAQ,CAAC,EAAE;QACjD,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAE,gCAAgC;QAClE,MAAM,KAAK,GAAG,gBAAgB,EAAE,CAAC;QACjC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACrD,MAAM,aAAa,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAClD,IAAI,KAAK,KAAK,KAAK,IAAI,aAAa,KAAK,uBAAuB,CAAC,OAAO,EAAE;YACxE,iEAAiE;YACjE,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;SACjC;aAAM,IACH,KAAK,KAAK,IAAI;YACd,CAAC,aAAa,KAAK,uBAAuB,CAAC,OAAO;gBACjD,aAAa,KAAK,eAAe,CAAC,WAAW,CAAC,EAAE;YACnD,0EAA0E;YAC1E,2EAA2E;YAC3E,SAAS;YACT,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;SACjC;KACF;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,QAAiB;IACnD,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,YAAY,GAAG,gBAAgB,EAAE,CAAC;IAExC,IAAI,cAAc,CAAC,KAAK,EAAE,YAAY,EAAE,QAAQ,CAAC,EAAE;QACjD,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAE,gCAAgC;QAClE,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAC3B,MAAM,KAAK,GAAG,gBAAgB,EAAE,CAAC;QACjC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACrD,IAAI,KAAK,KAAK,IAAI,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,WAAW,EAAE;YACzF,uDAAuD;YACvD,kBAAkB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;SACrC;KACF;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,aAAa;IAC3B,sBAAsB,CAAC,MAAM,CAAC,CAAC;AACjC,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,qBAAqB;IACnC,0BAA0B,CAAC,MAAM,oCAA4B,CAAC;AAChE,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,kBAAkB;IAChC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAErD,mEAAmE;IACnE,sEAAsE;IACtE,wBAAwB;IACxB,IAAI,QAAQ,CAAC,gBAAgB,KAAK,IAAI,EAAE;QACtC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;KACjC;IACD,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAClC,CAAC;AAGD;;;GAGG;AACH,MAAM,UAAU,0BAA0B;IACxC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAErD,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,WAAW,EAAE;QACvE,sBAAsB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;KACzC;AACH,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAAC,KAAa;IAC1C,sBAAsB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;AACzC,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,sBAAsB,CAAC,KAAa;IAClD,0BAA0B,CAAC,OAAO,CAAC,KAAK,CAAC,qCAA6B,CAAC;AACzE,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,cAAc,CAAC,YAAoB,EAAE,WAAoB;IACvE,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IAEjC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAChC,kBAAkB,CACd,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;AAC/F,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,sBAAsB,CAAC,YAAoB,EAAE,WAAoB;IAC/E,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAErD,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,WAAW,EAAE;QACvE,kBAAkB,CACd,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAChD,GAAG,EAAE,CAAC,kBAAkB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;KAChD;AACH,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,oBAAoB,CAAC,YAAoB,EAAE,WAAoB;IAC7E,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IAEjC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAChC,kBAAkB,CACd,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,aAAa,EACtD,GAAG,EAAE,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,4BAA4B,CAAC,YAAoB,EAAE,WAAoB;IACrF,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAErD,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,WAAW,EAAE;QACvE,kBAAkB,CACd,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,aAAa,EACtD,GAAG,EAAE,CAAC,kBAAkB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;KAChD;AACH,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,iBAAiB,CAAC,YAAoB,EAAE,WAAoB;IAC1E,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IAEjC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAChC,kBAAkB,CACd,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;AAClG,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,yBAAyB,CAAC,YAAoB,EAAE,WAAoB;IAClF,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAErD,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,WAAW,EAAE;QACvE,kBAAkB,CACd,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,UAAU,EACnD,GAAG,EAAE,CAAC,kBAAkB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;KAChD;AACH,CAAC;AAED,wCAAwC;AAExC;;GAEG;AACH,SAAS,sBAAsB,CAC3B,UAA6F;IAC/F,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IAEjC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAChC,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC;AACxF,CAAC;AAED;;;;;GAKG;AACH,SAAS,0BAA0B,CAC/B,UAA6F,EAC7F,OAA2B;IAC7B,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAErD,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,WAAW,EAAE;QACvE,sDAAsD;QACtD,8DAA8D;QAC9D,gEAAgE;QAChE,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;QAC5B,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAE,CAAC;QAClC,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;QACvD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE;YAC/B,gFAAgF;YAChF,gFAAgF;YAChF,2EAA2E;YAC3E,8BAA8B;YAC9B,MAAM,QAAQ,GAAG,GAAG,EAAE,CAAC,kBAAkB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YAC3D,MAAM,SAAS,GAAG,UAAU,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,CAAC,sBAAsB,CAAC,CAAC;YAC5E,uBAAuB,CAAC,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;SAC7D;KACF;AACH,CAAC;AAED;;;;;;;GAOG;AACH,SAAS,eAAe,CACpB,iBAAwB,EAAE,aAAoB,EAAE,WAA6B;IAC/E,8DAA8D;IAC9D,IAAI,WAAW,IAAI,IAAI,EAAE;QACvB,OAAO,iBAAiB,CAAC;KAC1B;IAED,uEAAuE;IACvE,IAAI,WAAW,IAAI,CAAC,EAAE;QACpB,OAAO,WAAW,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAC;KACpD;IAED,iFAAiF;IACjF,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACjE,SAAS,IAAI,gBAAgB,CAAC,iBAAiB,CAAC,CAAC;IACjD,MAAM,YAAY,GAAG,iBAAiB,CAAC,uBAAuB,CAAC,IAAI,IAAI,CAAC;IAExE,mFAAmF;IACnF,IAAI,SAAS,IAAI,YAAY,KAAK,IAAI,EAAE;QACtC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,iBAAiB,EAAE,aAAa,CAAC,CAAC;QACzE,MAAM,aAAa,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAClD,WAAW,CACP,aAAa,EAAE,eAAe,CAAC,WAAW,EAC1C,4DAA4D,CAAC,CAAC;QAClE,WAAW,CAAC,YAAY,CAAC,CAAC;KAC3B;IAED,OAAO,YAAY,CAAC;AACtB,CAAC;AAED;;;;GAIG;AACH,SAAS,iBAAiB,CAAC,YAAmB,EAAE,YAAoB;IAClE,MAAM,OAAO,GAAG,gBAAgB,CAAC,aAAa,GAAG,YAAY,EAAE,YAAY,CAAC,CAAC;IAC7E,SAAS,IAAI,aAAa,CAAC,OAAO,CAAC,CAAC;IACpC,OAAO,OAAkB,CAAC;AAC5B,CAAC;AAED;;;;;;;;;GASG;AACH,SAAS,kBAAkB,CACvB,YAAmB,EAAE,KAAY,EAAE,YAAoB,EAAE,WAA6B,EACtF,UAA0F,EAC1F,QAAsB;IACxB,MAAM,QAAQ,GAAG,YAAY,CAAC,QAAQ,CAAE,CAAC;IAEzC,8DAA8D;IAC9D,sDAAsD;IACtD,MAAM,cAAc,GAAG,WAAW,CAAC,GAAG,EAAE;QACtC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;QAC5D,MAAM,aAAa,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAElD,yFAAyF;QACzF,IAAI,aAAa,KAAK,uBAAuB,CAAC,OAAO;YACjD,aAAa,KAAK,eAAe,CAAC,WAAW,EAAE;YACjD,cAAc,CAAC,OAAO,EAAE,CAAC;YACzB,OAAO;SACR;QAED,MAAM,YAAY,GAAG,eAAe,CAAC,YAAY,EAAE,KAAK,EAAE,WAAW,CAAC,CAAC;QAEvE,qDAAqD;QACrD,oEAAoE;QACpE,IAAI,CAAC,YAAY,EAAE;YACjB,OAAO;SACR;QAED,8FAA8F;QAC9F,IAAI,YAAY,CAAC,KAAK,CAAC,iCAAuB,EAAE;YAC9C,cAAc,CAAC,OAAO,EAAE,CAAC;YACzB,OAAO;SACR;QAED,yDAAyD;QACzD,MAAM,OAAO,GAAG,iBAAiB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAC9D,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,EAAE,GAAG,EAAE;YACvC,QAAQ,EAAE,CAAC;YACX,oBAAoB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YAC5C,IAAI,YAAY,KAAK,YAAY,EAAE;gBACjC,oBAAoB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;aAC7C;YACD,OAAO,EAAE,CAAC;QACZ,CAAC,EAAE,QAAQ,CAAC,CAAC;QAEb,cAAc,CAAC,OAAO,EAAE,CAAC;QACzB,mBAAmB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;QAE3C,6DAA6D;QAC7D,6DAA6D;QAC7D,IAAI,YAAY,KAAK,YAAY,EAAE;YACjC,mBAAmB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;SAC5C;IACH,CAAC,EAAE,EAAC,QAAQ,EAAC,CAAC,CAAC;AACjB,CAAC;AAED;;;;;;;;GAQG;AACH,SAAS,MAAM,CAAC,QAAsB,EAAE,KAAY,EAAE,gBAAyB;IAC7E,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAE,CAAC;IAClC,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAChD,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACnD,MAAM,eAAe,GACjB,gBAAgB,CAAC,CAAC,CAAC,oBAAoB,CAAC,QAAQ,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;IACnF,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAC/B,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;GAGG;AACH,SAAS,OAAO,CAAC,KAAa;IAC5B,OAAO,CAAC,QAAsB,EAAE,KAAY,EAAE,gBAAyB,EAAE,EAAE,CAChE,oBAAoB,CAAC,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,gBAAgB,CAAC,CAAC;AAC5E,CAAC;AAED;;;;;;;;;GASG;AACH,SAAS,oBAAoB,CACzB,KAAa,EAAE,QAAsB,EAAE,KAAY,EAAE,gBAAyB;IAChF,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAE,CAAC;IAClC,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IAC/C,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACnD,MAAM,eAAe,GACjB,gBAAgB,CAAC,CAAC,CAAC,oBAAoB,CAAC,QAAQ,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;IACnF,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC;IACtC,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;GAGG;AACH,SAAS,oBAAoB,CACzB,QAAsB,EAAE,KAAY,EAAE,OAAqB;IAC7D,MAAM,eAAe,GAAG,GAAG,EAAE;QAC3B,QAAQ,EAAE,CAAC;QACX,oBAAoB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACvC,CAAC,CAAC;IACF,mBAAmB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACpC,OAAO,eAAe,CAAC;AACzB,CAAC;AAED;;;GAGG;AACH,SAAS,sBAAsB,CAAC,eAAuB;IACrD,mDAAmD;IACnD,wDAAwD;IACxD,OAAO,eAAe,GAAG,CAAC,CAAC;AAC7B,CAAC;AAED,0FAA0F;AAC1F,SAAS,qBAAqB,CAAC,KAAY,EAAE,KAAY;IACvD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,SAAS,GAAG,sBAAsB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACtD,SAAS,IAAI,sBAAsB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACtD,OAAO,KAAK,CAAC,SAAS,CAAC,CAAC;AAC1B,CAAC;AAED,oDAAoD;AACpD,SAAS,qBAAqB,CAC1B,KAAY,EAAE,eAAuB,EAAE,QAA4B;IACrE,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,SAAS,GAAG,sBAAsB,CAAC,eAAe,CAAC,CAAC;IAC1D,SAAS,IAAI,sBAAsB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACtD,KAAK,CAAC,SAAS,CAAC,GAAG,QAAQ,CAAC;AAC9B,CAAC;AAED,oGAAoG;AACpG,SAAS,qBAAqB,CAAC,KAAY,EAAE,KAAY;IACvD,MAAM,SAAS,GAAG,sBAAsB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACtD,SAAS,IAAI,sBAAsB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACtD,OAAO,KAAK,CAAC,IAAI,CAAC,SAAS,CAAuB,CAAC;AACrD,CAAC;AAED,wDAAwD;AACxD,SAAS,qBAAqB,CAC1B,KAAY,EAAE,eAAuB,EAAE,gBAAoC;IAC7E,MAAM,SAAS,GAAG,sBAAsB,CAAC,eAAe,CAAC,CAAC;IAC1D,SAAS,IAAI,sBAAsB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACtD,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,gBAAgB,CAAC;AAC3C,CAAC;AAED,SAAS,wBAAwB,CAC7B,QAAyB,EAAE,SAAgB,EAAE,KAAY;IAC3D,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IAC/B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAErD,QAAQ,QAAQ,EAAE;QAChB,KAAK,eAAe,CAAC,QAAQ;YAC3B,OAAO,QAAQ,CAAC,gBAAgB,CAAC;QACnC,KAAK,eAAe,CAAC,OAAO;YAC1B,OAAO,QAAQ,CAAC,gBAAgB,CAAC;QACnC,KAAK,eAAe,CAAC,KAAK;YACxB,OAAO,QAAQ,CAAC,cAAc,CAAC;QACjC,KAAK,eAAe,CAAC,WAAW;YAC9B,OAAO,QAAQ,CAAC,oBAAoB,CAAC;QACvC;YACE,SAAS,IAAI,UAAU,CAAC,iCAAiC,QAAQ,EAAE,CAAC,CAAC;YACrE,OAAO,IAAI,CAAC;KACf;AACH,CAAC;AAED;;;;GAIG;AACH,SAAS,0BAA0B,CAC/B,QAA4B,EAAE,YAA6B;IAC7D,IAAI,YAAY,KAAK,eAAe,CAAC,WAAW,EAAE;QAChD,OAAO,QAAQ,CAAC,sBAAsB,EAAE,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC;KAChE;SAAM,IAAI,YAAY,KAAK,eAAe,CAAC,OAAO,EAAE;QACnD,OAAO,QAAQ,CAAC,kBAAkB,EAAE,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC;KAC5D;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,0EAA0E;AAC1E,SAAS,oBAAoB,CAAC,QAA4B;IACxD,OAAO,QAAQ,CAAC,kBAAkB,EAAE,CAAC,kBAAkB,CAAC,IAAI,IAAI,CAAC;AACnE,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,qBAAqB,CACjC,QAAyB,EAAE,KAAY,EAAE,UAAsB;IACjE,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;IACrC,MAAM,SAAS,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IAEnC,4EAA4E;IAC5E,uEAAuE;IACvE,IAAI,WAAW,CAAC,SAAS,CAAC;QAAE,OAAO;IAEnC,oEAAoE;IACpE,SAAS,IAAI,mBAAmB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAEnD,MAAM,QAAQ,GAAG,qBAAqB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;IAEzD,SAAS,IAAI,aAAa,CAAC,QAAQ,EAAE,sCAAsC,CAAC,CAAC;IAE7E,MAAM,YAAY,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC;IAEjD,IAAI,kBAAkB,CAAC,YAAY,EAAE,QAAQ,CAAC;QAC1C,kBAAkB,CAAC,QAAQ,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE;QACxE,MAAM,QAAQ,GAAG,qBAAqB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACzD,MAAM,eAAe,GAAG,oBAAoB,CAAC,QAAQ,CAAC,KAAK,IAAI;YAC3D,0BAA0B,CAAC,QAAQ,EAAE,eAAe,CAAC,OAAO,CAAC,KAAK,IAAI;YACtE,0BAA0B,CAAC,QAAQ,EAAE,eAAe,CAAC,WAAW,CAAC,CAAC;QAEtE,IAAI,SAAS,IAAI,eAAe,EAAE;YAChC,aAAa,CACT,sCAAsC,EAAE,4CAA4C,CAAC,CAAC;SAC3F;QAED,MAAM,YAAY,GACd,eAAe,CAAC,CAAC,CAAC,sCAAuC,CAAC,CAAC,CAAC,oBAAoB,CAAC;QACrF,YAAY,CAAC,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;KAChE;AACH,CAAC;AAED;;GAEG;AACH,SAAS,oBAAoB,CACzB,QAAyB,EAAE,QAA4B,EAAE,UAAsB,EAAE,KAAY,EAC7F,SAAyB;IAC3B,MAAM,cAAc,GAAG,wBAAwB,CAAC,QAAQ,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;IAE5E,IAAI,cAAc,KAAK,IAAI,EAAE;QAC3B,QAAQ,CAAC,iBAAiB,CAAC,GAAG,QAAQ,CAAC;QACvC,MAAM,SAAS,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;QACnC,MAAM,aAAa,GAAG,cAAc,GAAG,aAAa,CAAC;QACrD,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,EAAE,aAAa,CAAmB,CAAC;QAEnE,iEAAiE;QACjE,8DAA8D;QAC9D,MAAM,SAAS,GAAG,CAAC,CAAC;QAEpB,yBAAyB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QACjD,MAAM,cAAc,GAAG,0BAA0B,CAAC,UAAU,EAAE,KAAK,CAAC,KAAM,CAAC,KAAK,CAAC,CAAC;QAClF,MAAM,aAAa,GAAG,4BAA4B,CAAC,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,EAAC,cAAc,EAAC,CAAC,CAAC;QAC7F,oBAAoB,CAChB,UAAU,EAAE,aAAa,EAAE,SAAS,EAAE,kBAAkB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC;QACrF,aAAa,CAAC,aAAa,CAAC,CAAC;KAC9B;AACH,CAAC;AAED;;;;;GAKG;AACH,SAAS,kCAAkC,CACvC,QAAyB,EAAE,QAA4B,EAAE,UAAsB,EAAE,KAAY,EAC7F,SAAyB;IAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,MAAM,SAAS,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IACnC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;IAEzD,IAAI,QAAQ,CAAC,qBAAqB,CAAC,KAAK,IAAI,IAAI,QAAQ,CAAC,qBAAqB,CAAC,IAAI,GAAG,EAAE;QACtF,QAAQ,CAAC,qBAAqB,CAAC,GAAG,IAAI,CAAC;QAEvC,MAAM,YAAY,GAAG,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QACpD,MAAM,mBAAmB,GAAG,QAAQ,CAAC,wBAAwB,CAAC,KAAK,IAAI,CAAC;QACxE,IAAI,QAAQ,KAAK,eAAe,CAAC,OAAO,IAAI,YAAY,KAAK,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACzF,0DAA0D;YAC1D,gDAAgD;YAChD,QAAQ,CAAC,sBAAsB,CAAC,GAAG,QAAQ,CAAC;YAC5C,MAAM,SAAS,GACX,wBAAwB,CAAC,YAAY,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;YACnF,QAAQ,CAAC,wBAAwB,CAAC,GAAG,SAAS,CAAC;SAChD;aAAM;YACL,0EAA0E;YAC1E,4EAA4E;YAC5E,yBAAyB;YACzB,IAAI,QAAQ,GAAG,eAAe,CAAC,OAAO,IAAI,mBAAmB,EAAE;gBAC7D,QAAQ,CAAC,wBAAwB,CAAE,EAAE,CAAC;gBACtC,QAAQ,CAAC,wBAAwB,CAAC,GAAG,IAAI,CAAC;gBAC1C,QAAQ,CAAC,sBAAsB,CAAC,GAAG,IAAI,CAAC;aACzC;YAED,oBAAoB,CAAC,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;YAEvE,MAAM,QAAQ,GAAG,0BAA0B,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAChE,IAAI,QAAQ,KAAK,IAAI,EAAE;gBACrB,QAAQ,CAAC,qBAAqB,CAAC,GAAG,GAAG,GAAG,QAAQ,CAAC;gBACjD,wBAAwB,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;aAC5E;SACF;KACF;SAAM;QACL,6CAA6C;QAC7C,sDAAsD;QACtD,4DAA4D;QAC5D,QAAQ,CAAC,sBAAsB,CAAC,GAAG,QAAQ,CAAC;KAC7C;AACH,CAAC;AAED;;GAEG;AACH,SAAS,wBAAwB,CAC7B,OAAe,EAAE,QAA4B,EAAE,KAAY,EAAE,UAAsB,EACnF,SAAyB;IAC3B,MAAM,QAAQ,GAAG,GAAG,EAAE;QACpB,MAAM,SAAS,GAAG,QAAQ,CAAC,sBAAsB,CAAC,CAAC;QACnD,QAAQ,CAAC,qBAAqB,CAAC,GAAG,IAAI,CAAC;QACvC,QAAQ,CAAC,sBAAsB,CAAC,GAAG,IAAI,CAAC;QACxC,IAAI,SAAS,KAAK,IAAI,EAAE;YACtB,qBAAqB,CAAC,SAAS,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;SACrD;IACH,CAAC,CAAC;IACF,OAAO,oBAAoB,CAAC,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;AAClE,CAAC;AAED;;;;;;;;GAQG;AACH,SAAS,kBAAkB,CACvB,YAAqD,EAAE,QAAyB;IAClF,OAAO,YAAY,GAAG,QAAQ,CAAC;AACjC,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,kBAAkB,CAAC,QAA4B,EAAE,KAAY;IAC3E,IAAI,KAAK,CAAC,QAAQ,CAAC,IAAI,uBAAuB,CAAC,KAAK,CAAC,QAAQ,CAAE,CAAC,EAAE;QAChE,sBAAsB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;KACzC;AACH,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,sBAAsB,CAAC,QAA4B,EAAE,KAAY;IAC/E,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAE,CAAC;IAClC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAE3B,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,WAAW,EAAE;QACvE,qEAAqE;QACrE,wEAAwE;QACxE,4EAA4E;QAC5E,OAAO;KACR;IAED,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IAEhE,gDAAgD;IAChD,QAAQ,CAAC,YAAY,GAAG,6BAA6B,CAAC,WAAW,CAAC;IAElE,0DAA0D;IAC1D,MAAM,0BAA0B,GAC5B,QAAQ,CAAC,GAAG,CAAC,kCAAkC,EAAE,IAAI,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;IAE7E,MAAM,cAAc,GAAG,0BAA0B,CAAC,CAAC;QAC/C,0BAA0B,CAAC,SAAS,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACrE,QAAQ,CAAC,oBAAoB,CAAC;IAElC,oEAAoE;IACpE,mEAAmE;IACnE,6CAA6C;IAC7C,IAAI,CAAC,cAAc,EAAE;QACnB,QAAQ,CAAC,cAAc,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACpD,QAAQ,CAAC,YAAY,GAAG,6BAA6B,CAAC,QAAQ,CAAC;QACjE,CAAC,CAAC,CAAC;QACH,OAAO;KACR;IAED,oEAAoE;IACpE,uEAAuE;IACvE,qBAAqB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAE1C,iDAAiD;IACjD,QAAQ,CAAC,cAAc,GAAG,OAAO,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;QAC5E,IAAI,MAAM,GAAG,KAAK,CAAC;QACnB,MAAM,aAAa,GAAqB,EAAE,CAAC;QAC3C,MAAM,QAAQ,GAAgB,EAAE,CAAC;QAEjC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC5B,IAAI,MAAM,CAAC,MAAM,KAAK,WAAW,EAAE;gBACjC,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC;gBAChC,MAAM,YAAY,GAAG,eAAe,CAAC,UAAU,CAAC,IAAI,eAAe,CAAC,UAAU,CAAC,CAAC;gBAChF,IAAI,YAAY,EAAE;oBAChB,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAClC;qBAAM;oBACL,MAAM,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC,CAAC;oBACvC,IAAI,OAAO,EAAE;wBACX,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;qBACxB;iBACF;aACF;iBAAM;gBACL,MAAM,GAAG,IAAI,CAAC;gBACd,MAAM;aACP;SACF;QAED,wDAAwD;QACxD,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC;QAE/B,IAAI,MAAM,EAAE;YACV,QAAQ,CAAC,YAAY,GAAG,6BAA6B,CAAC,MAAM,CAAC;SAC9D;aAAM;YACL,QAAQ,CAAC,YAAY,GAAG,6BAA6B,CAAC,QAAQ,CAAC;YAE/D,6EAA6E;YAC7E,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,KAAM,CAAC;YACnD,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC5B,iBAAiB,CAAC,iBAAiB;oBAC/B,iBAAiB,CAAmB,iBAAiB,CAAC,iBAAiB,EAAE,aAAa,CAAC,CAAC;aAC7F;YACD,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBACvB,iBAAiB,CAAC,YAAY;oBAC1B,iBAAiB,CAAc,iBAAiB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;aAC9E;SACF;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;;GAGG;AACH,SAAS,iBAAiB,CAA4B,WAAmB,EAAE,OAAU;IACnF,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;QAC5C,OAAO,OAAO,CAAC;KAChB;IAED,MAAM,aAAa,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,CAAC;IAC3C,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE;QACzB,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;KACxB;IAED,sEAAsE;IACtE,6BAA6B;IAC7B,OAAO,CAAC,WAAW,CAAC,MAAM,KAAK,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAM,CAAC;AACpG,CAAC;AAED,kEAAkE;AAClE,SAAS,iBAAiB,CAAC,KAAY,EAAE,KAAY;IACnD,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACtC,SAAS,IAAI,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAE1C,qBAAqB,CAAC,eAAe,CAAC,WAAW,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;AACxE,CAAC;AAED;;;;;;GAMG;AACH,SAAS,oCAAoC,CACzC,QAA4B,EAAE,KAAY,EAAE,UAAsB;IACpE,SAAS;QACL,aAAa,CACT,QAAQ,CAAC,cAAc,EAAE,uDAAuD,CAAC,CAAC;IAE1F,QAAQ,CAAC,cAAe,CAAC,IAAI,CAAC,GAAG,EAAE;QACjC,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,QAAQ,EAAE;YACpE,SAAS,IAAI,gCAAgC,CAAC,QAAQ,CAAC,CAAC;YAExD,uDAAuD;YACvD,qBAAqB,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;SAEpE;aAAM,IAAI,QAAQ,CAAC,YAAY,KAAK,6BAA6B,CAAC,MAAM,EAAE;YACzE,qBAAqB,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;SACjE;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,uEAAuE;AACvE,SAAS,oBAAoB,CAAC,KAAY,EAAE,QAA4B;IACtE,MAAM,aAAa,GAAG,QAAQ,CAAC,gBAAgB,GAAG,aAAa,CAAC;IAChE,OAAO,QAAQ,CAAC,KAAK,EAAE,aAAa,CAAmB,CAAC;AAC1D,CAAC;AAED;;;;GAIG;AACH,SAAS,iBAAiB,CAAC,KAAY,EAAE,KAAY;IACnD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACtC,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAE,CAAC;IAClC,SAAS,IAAI,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAE1C,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC;QAAE,OAAO;IAE/C,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACrD,QAAQ,QAAQ,CAAC,YAAY,EAAE;QAC7B,KAAK,6BAA6B,CAAC,WAAW;YAC5C,qBAAqB,CAAC,eAAe,CAAC,OAAO,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;YAClE,sBAAsB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YAExC,sDAAsD;YACtD,IAAK,QAAQ,CAAC,YAA8C;gBACxD,6BAA6B,CAAC,WAAW,EAAE;gBAC7C,oCAAoC,CAAC,QAAQ,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;aACnE;YACD,MAAM;QACR,KAAK,6BAA6B,CAAC,WAAW;YAC5C,qBAAqB,CAAC,eAAe,CAAC,OAAO,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;YAClE,oCAAoC,CAAC,QAAQ,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;YAClE,MAAM;QACR,KAAK,6BAA6B,CAAC,QAAQ;YACzC,SAAS,IAAI,gCAAgC,CAAC,QAAQ,CAAC,CAAC;YACxD,qBAAqB,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;YACnE,MAAM;QACR,KAAK,6BAA6B,CAAC,MAAM;YACvC,qBAAqB,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;YAChE,MAAM;QACR;YACE,IAAI,SAAS,EAAE;gBACb,UAAU,CAAC,2BAA2B,CAAC,CAAC;aACzC;KACJ;AACH,CAAC;AAED;;;;GAIG;AACH,SAAS,gCAAgC,CAAC,QAA4B;IACpE,WAAW,CACP,QAAQ,CAAC,YAAY,EAAE,6BAA6B,CAAC,QAAQ,EAC7D,mDAAmD,CAAC,CAAC;AAC3D,CAAC;AAsBD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,kCAAkC,GAC3C,IAAI,cAAc,CACd,SAAS,CAAC,CAAC,CAAC,oCAAoC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAE/D;;;;;GAKG;AACH,SAAS,oBAAoB,CAAC,KAAc;IAC1C,OAAO,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC;QAC9B,CAAC,OAAQ,KAA4B,CAAC,gBAAgB,KAAK,QAAQ,CAAC,CAAC;AAC3E,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAC3B,IAAI,cAAc,CAAmB,SAAS,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAYhF;;;;;GAKG;AACH,MAAM,UAAU,cAAc,CAAC,KAAY,EAAE,WAAgC;IAC3E,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,KAAK,IAAI,CAAC,GAAG,aAAa,EAAE,CAAC,GAAG,KAAK,CAAC,iBAAiB,EAAE,CAAC,EAAE,EAAE;QAC5D,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;YAC1B,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAC5B,0EAA0E;YAC1E,+EAA+E;YAC/E,yBAAyB;YACzB,MAAM,MAAM,GAAG,CAAC,KAAK,KAAK,CAAC,iBAAiB,GAAG,CAAC,CAAC;YACjD,IAAI,CAAC,MAAM,EAAE;gBACX,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAU,CAAC;gBACrC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACrD,IAAI,oBAAoB,CAAC,QAAQ,CAAC,EAAE;oBAClC,WAAW,CAAC,IAAI,CAAC,EAAC,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAC,CAAC,CAAC;oBACvD,uDAAuD;oBACvD,6DAA6D;oBAC7D,SAAS;iBACV;aACF;YACD,KAAK,IAAI,CAAC,GAAG,uBAAuB,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChE,cAAc,CAAC,UAAU,CAAC,CAAC,CAAU,EAAE,WAAW,CAAC,CAAC;aACrD;SACF;aAAM,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;YAC5B,+DAA+D;YAC/D,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC;SACvC;KACF;AACH,CAAC;AAED;;;GAGG;AACH,SAAS,uBAAuB,CAC5B,QAAkB,EAAE,QAA4B,EAAE,GAAW,EAAE,SAAuB;IACxF,QAAQ,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;AACvE,CAAC;AAED;;;GAGG;AACH,SAAS,qBAAqB,CAAC,QAAkB,EAAE,QAA4B;IAC7E,QAAQ,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;AAC3D,CAAC;AAED;;;;GAIG;AACH,MAAM,wBAAwB;IAA9B;QACU,WAAM,GAAG,IAAI,GAAG,EAAmD,CAAC;IA2C9E,CAAC;IAzCC,GAAG,CAAC,QAA4B,EAAE,GAAW,EAAE,QAAsB;QACnE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;SACtC;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;QACzC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YACnB,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;SACpB;QACD,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC;QAClC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC3B,CAAC;IAED,GAAG,CAAC,QAA4B,EAAE,GAAW;QAC3C,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;IAC/C,CAAC;IAED,OAAO,CAAC,QAA4B;QAClC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACxC,IAAI,KAAK,EAAE;YACT,KAAK,MAAM,SAAS,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;gBAC5C,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;oBAChC,QAAQ,EAAE,CAAC;iBACZ;aACF;YACD,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;SAC9B;IACH,CAAC;IAED,WAAW;QACT,KAAK,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE;YACjC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SACrB;QACD,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IACtB,CAAC;IAED,kBAAkB;aACX,UAAK,GAA6B,kBAAkB,CAAC;QAC1D,KAAK,EAAE,wBAAwB;QAC/B,UAAU,EAAE,MAAM;QAClB,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,wBAAwB,EAAE;KAC9C,CAAC,AAJU,CAIT;;AAGL;;;;;;GAMG;AACH,MAAM,oBAAoB,GAAG,GAAG,EAAE,CAC9B,OAAO,mBAAmB,KAAK,WAAW,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,UAAU,CAAC;AAClF,MAAM,mBAAmB,GAAG,GAAG,EAAE,CAC7B,OAAO,mBAAmB,KAAK,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,YAAY,CAAC;AAEnF;;;;GAIG;AACH,MAAM,eAAe;IAArB;QACE,yDAAyD;QACzD,uBAAkB,GAAG,KAAK,CAAC;QAE3B,wCAAwC;QACxC,WAAM,GAAgB,IAAI,CAAC;QAE3B,uCAAuC;QACvC,YAAO,GAAG,IAAI,GAAG,EAAgB,CAAC;QAElC,sEAAsE;QACtE,0DAA0D;QAC1D,aAAQ,GAAG,IAAI,GAAG,EAAgB,CAAC;QAEnC,WAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QAExB,wBAAmB,GAAG,oBAAoB,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC9D,uBAAkB,GAAG,mBAAmB,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IA4D9D,CAAC;IA1DC,GAAG,CAAC,QAAsB;QACxB,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC;QACtE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACrB,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE;YACxB,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;IACH,CAAC;IAED,MAAM,CAAC,QAAsB;QAC3B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IAEO,oBAAoB;QAC1B,MAAM,QAAQ,GAAG,GAAG,EAAE;YACpB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAO,CAAC,CAAC;YACtC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YAEnB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAE/B,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,OAAO,EAAE;gBACnC,QAAQ,EAAE,CAAC;aACZ;YACD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAErB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAEhC,wDAAwD;YACxD,yDAAyD;YACzD,uBAAuB;YACvB,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC,EAAE;gBAC1B,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;iBAC5B;gBACD,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACtB,IAAI,CAAC,oBAAoB,EAAE,CAAC;aAC7B;QACH,CAAC,CAAC;QACF,oDAAoD;QACpD,iEAAiE;QACjE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAW,CAAC;IACpF,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE;YACxB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACrC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACpB;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;IAED,kBAAkB;aACX,UAAK,GAA6B,kBAAkB,CAAC;QAC1D,KAAK,EAAE,eAAe;QACtB,UAAU,EAAE,MAAM;QAClB,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,eAAe,EAAE;KACrC,CAAC,AAJU,CAIT;;AAGL;;;;GAIG;AACH,MAAM,cAAc;IAApB;QACE,yDAAyD;QACzD,uBAAkB,GAAG,KAAK,CAAC;QAE3B,uCAAuC;QACvC,cAAS,GAAgB,IAAI,CAAC;QAE9B,6CAA6C;QAC7C,kBAAa,GAAgB,IAAI,CAAC;QAElC,mCAAmC;QACnC,mEAAmE;QACnE,gEAAgE;QAChE,gEAAgE;QAChE,sDAAsD;QACtD,YAAO,GAA+B,EAAE,CAAC;QAEzC,uEAAuE;QACvE,iEAAiE;QACjE,sEAAsE;QACtE,sCAAsC;QACtC,aAAQ,GAA+B,EAAE,CAAC;IA8I5C,CAAC;IA5IC,GAAG,CAAC,KAAa,EAAE,QAAsB;QACvC,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC;QACtE,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,QAAQ,CAAC,CAAC;QACtD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,QAAsB;QAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QACnE,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE;YACxB,8CAA8C;YAC9C,oDAAoD;YACpD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;SAC/C;IACH,CAAC;IAEO,UAAU,CAAC,MAAkC,EAAE,QAAgB,EAAE,QAAsB;QAC7F,IAAI,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC;QAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;YACzC,MAAM,sBAAsB,GAAG,MAAM,CAAC,CAAC,CAAW,CAAC;YACnD,IAAI,sBAAsB,GAAG,QAAQ,EAAE;gBACrC,gDAAgD;gBAChD,sDAAsD;gBACtD,mDAAmD;gBACnD,8BAA8B;gBAC9B,aAAa,GAAG,CAAC,CAAC;gBAClB,MAAM;aACP;SACF;QACD,YAAY,CAAC,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAC1D,CAAC;IAEO,eAAe,CAAC,MAAkC,EAAE,QAAsB;QAChF,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC;QACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;YACzC,MAAM,cAAc,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACrC,IAAI,cAAc,KAAK,QAAQ,EAAE;gBAC/B,KAAK,GAAG,CAAC,CAAC;gBACV,MAAM;aACP;SACF;QACD,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE;YACd,0CAA0C;YAC1C,+CAA+C;YAC/C,WAAW,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;SAC/B;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,aAAa;QACnB,MAAM,QAAQ,GAAG,GAAG,EAAE;YACpB,YAAY,CAAC,IAAI,CAAC,SAAU,CAAC,CAAC;YAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YAEtB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAE/B,8CAA8C;YAC9C,2BAA2B;YAC3B,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACrB,IAAI,iBAAiB,GAAgB,IAAI,CAAC;YAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;gBAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAW,CAAC;gBAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAiB,CAAC;gBACrD,IAAI,QAAQ,IAAI,GAAG,EAAE;oBACnB,QAAQ,EAAE,CAAC;oBACX,2DAA2D;oBAC3D,uBAAuB;oBACvB,iBAAiB,GAAG,CAAC,GAAG,CAAC,CAAC;iBAC3B;qBAAM;oBACL,wDAAwD;oBACxD,MAAM;iBACP;aACF;YACD,IAAI,iBAAiB,KAAK,IAAI,EAAE;gBAC9B,gEAAgE;gBAChE,+DAA+D;gBAC/D,kBAAkB;gBAClB,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,iBAAiB,GAAG,CAAC,CAAC,CAAC;aACrD;YAED,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAEhC,wDAAwD;YACxD,wDAAwD;YACxD,SAAS;YACT,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;oBAChD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAW,CAAC;oBAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAiB,CAAC;oBACtD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;iBACnD;gBACD,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;aAC1B;YACD,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC;QAEF,mDAAmD;QACnD,oDAAoD;QACpD,qDAAqD;QACrD,oBAAoB;QACpB,MAAM,iBAAiB,GAAG,EAAE,CAAC,CAAE,iBAAiB;QAEhD,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,qDAAqD;YACrD,iCAAiC;YACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAW,CAAC;YAC3C,IAAI,CAAC,IAAI,CAAC,SAAS;gBACf,2DAA2D;gBAC3D,6DAA6D;gBAC7D,kBAAkB;gBAClB,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,aAAa,GAAG,QAAQ,GAAG,iBAAiB,CAAC,CAAC,EAAE;gBAC/E,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;oBAC3B,8DAA8D;oBAC9D,8DAA8D;oBAC9D,+CAA+C;oBAC/C,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;oBAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;iBACvB;gBACD,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,GAAG,GAAG,EAAE,iBAAiB,CAAC,CAAC;gBAC5D,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;gBAC9B,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC,QAAQ,EAAE,OAAO,CAAsB,CAAC;aACrE;SACF;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;YAC3B,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QACD,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;QACxB,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;IAC3B,CAAC;IAED,kBAAkB;aACX,UAAK,GAA6B,kBAAkB,CAAC;QAC1D,KAAK,EAAE,cAAc;QACrB,UAAU,EAAE,MAAM;QAClB,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,cAAc,EAAE;KACpC,CAAC,AAJU,CAIT","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {inject, InjectionToken, Injector, ɵɵdefineInjectable} from '../../di';\nimport {findMatchingDehydratedView} from '../../hydration/views';\nimport {populateDehydratedViewsInLContainer} from '../../linker/view_container_ref';\nimport {arrayInsert2, arraySplice} from '../../util/array_utils';\nimport {assertDefined, assertElement, assertEqual, throwError} from '../../util/assert';\nimport {NgZone} from '../../zone';\nimport {afterRender} from '../after_render_hooks';\nimport {assertIndexInDeclRange, assertLContainer, assertLView, assertTNodeForLView} from '../assert';\nimport {bindingUpdated} from '../bindings';\nimport {getComponentDef, getDirectiveDef, getPipeDef} from '../definition';\nimport {CONTAINER_HEADER_OFFSET, LContainer} from '../interfaces/container';\nimport {DEFER_BLOCK_STATE, DeferBlockBehavior, DeferBlockConfig, DeferBlockInternalState, DeferBlockState, DeferBlockTriggers, DeferDependenciesLoadingState, DeferredLoadingBlockConfig, DeferredPlaceholderBlockConfig, DependencyResolverFn, LDeferBlockDetails, LOADING_AFTER_CLEANUP_FN, LOADING_AFTER_SLOT, MINIMUM_SLOT, NEXT_DEFER_BLOCK_STATE, STATE_IS_FROZEN_UNTIL, TDeferBlockDetails} from '../interfaces/defer';\nimport {DependencyDef, DirectiveDefList, PipeDefList} from '../interfaces/definition';\nimport {TContainerNode, TNode} from '../interfaces/node';\nimport {isDestroyed, isLContainer, isLView} from '../interfaces/type_checks';\nimport {FLAGS, HEADER_OFFSET, INJECTOR, LView, LViewFlags, PARENT, TVIEW, TView} from '../interfaces/view';\nimport {getCurrentTNode, getLView, getSelectedTNode, getTView, nextBindingIndex} from '../state';\nimport {isPlatformBrowser} from '../util/misc_utils';\nimport {getConstant, getNativeByIndex, getTNode, removeLViewOnDestroy, storeLViewOnDestroy, walkUpViews} from '../util/view_utils';\nimport {addLViewToLContainer, createAndRenderEmbeddedLView, removeLViewFromLContainer, shouldAddViewToDom} from '../view_manipulation';\n\nimport {onHover, onInteraction, onViewport} from './defer_events';\nimport {markViewDirty} from './mark_view_dirty';\nimport {ɵɵtemplate} from './template';\n\n/**\n * Returns whether defer blocks should be triggered.\n *\n * Currently, defer blocks are not triggered on the server,\n * only placeholder content is rendered (if provided).\n */\nfunction shouldTriggerDeferBlock(injector: Injector): boolean {\n  const config = injector.get(DEFER_BLOCK_CONFIG, null, {optional: true});\n  if (config?.behavior === DeferBlockBehavior.Manual) {\n    return false;\n  }\n  return isPlatformBrowser(injector);\n}\n\n/**\n * Reference to the timer-based scheduler implementation of defer block state\n * rendering method. It's used to make timer-based scheduling tree-shakable.\n * If `minimum` or `after` parameters are used, compiler generates an extra\n * argument for the `ɵɵdefer` instruction, which references a timer-based\n * implementation.\n */\nlet applyDeferBlockStateWithSchedulingImpl: (typeof applyDeferBlockState)|null = null;\n\n/**\n * Enables timer-related scheduling if `after` or `minimum` parameters are setup\n * on the `@loading` or `@placeholder` blocks.\n */\nexport function ɵɵdeferEnableTimerScheduling(\n    tView: TView, tDetails: TDeferBlockDetails, placeholderConfigIndex?: number|null,\n    loadingConfigIndex?: number|null) {\n  const tViewConsts = tView.consts;\n  if (placeholderConfigIndex != null) {\n    tDetails.placeholderBlockConfig =\n        getConstant<DeferredPlaceholderBlockConfig>(tViewConsts, placeholderConfigIndex);\n  }\n  if (loadingConfigIndex != null) {\n    tDetails.loadingBlockConfig =\n        getConstant<DeferredLoadingBlockConfig>(tViewConsts, loadingConfigIndex);\n  }\n\n  // Enable implementation that supports timer-based scheduling.\n  if (applyDeferBlockStateWithSchedulingImpl === null) {\n    applyDeferBlockStateWithSchedulingImpl = applyDeferBlockStateWithScheduling;\n  }\n}\n\n/**\n * Creates runtime data structures for defer blocks.\n *\n * @param index Index of the `defer` instruction.\n * @param primaryTmplIndex Index of the template with the primary block content.\n * @param dependencyResolverFn Function that contains dependencies for this defer block.\n * @param loadingTmplIndex Index of the template with the loading block content.\n * @param placeholderTmplIndex Index of the template with the placeholder block content.\n * @param errorTmplIndex Index of the template with the error block content.\n * @param loadingConfigIndex Index in the constants array of the configuration of the loading.\n *     block.\n * @param placeholderConfigIndex Index in the constants array of the configuration of the\n *     placeholder block.\n * @param enableTimerScheduling Function that enables timer-related scheduling if `after`\n *     or `minimum` parameters are setup on the `@loading` or `@placeholder` blocks.\n *\n * @codeGenApi\n */\nexport function ɵɵdefer(\n    index: number, primaryTmplIndex: number, dependencyResolverFn?: DependencyResolverFn|null,\n    loadingTmplIndex?: number|null, placeholderTmplIndex?: number|null,\n    errorTmplIndex?: number|null, loadingConfigIndex?: number|null,\n    placeholderConfigIndex?: number|null,\n    enableTimerScheduling?: typeof ɵɵdeferEnableTimerScheduling) {\n  const lView = getLView();\n  const tView = getTView();\n  const adjustedIndex = index + HEADER_OFFSET;\n\n  ɵɵtemplate(index, null, 0, 0);\n\n  if (tView.firstCreatePass) {\n    const tDetails: TDeferBlockDetails = {\n      primaryTmplIndex,\n      loadingTmplIndex: loadingTmplIndex ?? null,\n      placeholderTmplIndex: placeholderTmplIndex ?? null,\n      errorTmplIndex: errorTmplIndex ?? null,\n      placeholderBlockConfig: null,\n      loadingBlockConfig: null,\n      dependencyResolverFn: dependencyResolverFn ?? null,\n      loadingState: DeferDependenciesLoadingState.NOT_STARTED,\n      loadingPromise: null,\n    };\n    enableTimerScheduling?.(tView, tDetails, placeholderConfigIndex, loadingConfigIndex);\n    setTDeferBlockDetails(tView, adjustedIndex, tDetails);\n  }\n\n  const tNode = getCurrentTNode()!;\n  const lContainer = lView[adjustedIndex];\n\n  // If hydration is enabled, looks up dehydrated views in the DOM\n  // using hydration annotation info and stores those views on LContainer.\n  // In client-only mode, this function is a noop.\n  populateDehydratedViewsInLContainer(lContainer, tNode, lView);\n\n  // Init instance-specific defer details and store it.\n  const lDetails: LDeferBlockDetails = [\n    null,                             // NEXT_DEFER_BLOCK_STATE\n    DeferBlockInternalState.Initial,  // DEFER_BLOCK_STATE\n    null,                             // STATE_IS_FROZEN_UNTIL\n    null                              // LOADING_AFTER_CLEANUP_FN\n  ];\n  setLDeferBlockDetails(lView, adjustedIndex, lDetails);\n}\n\n/**\n * Loads defer block dependencies when a trigger value becomes truthy.\n * @codeGenApi\n */\nexport function ɵɵdeferWhen(rawValue: unknown) {\n  const lView = getLView();\n  const bindingIndex = nextBindingIndex();\n  if (bindingUpdated(lView, bindingIndex, rawValue)) {\n    const value = Boolean(rawValue);  // handle truthy or falsy values\n    const tNode = getSelectedTNode();\n    const lDetails = getLDeferBlockDetails(lView, tNode);\n    const renderedState = lDetails[DEFER_BLOCK_STATE];\n    if (value === false && renderedState === DeferBlockInternalState.Initial) {\n      // If nothing is rendered yet, render a placeholder (if defined).\n      renderPlaceholder(lView, tNode);\n    } else if (\n        value === true &&\n        (renderedState === DeferBlockInternalState.Initial ||\n         renderedState === DeferBlockState.Placeholder)) {\n      // The `when` condition has changed to `true`, trigger defer block loading\n      // if the block is either in initial (nothing is rendered) or a placeholder\n      // state.\n      triggerDeferBlock(lView, tNode);\n    }\n  }\n}\n\n/**\n * Prefetches the deferred content when a value becomes truthy.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchWhen(rawValue: unknown) {\n  const lView = getLView();\n  const bindingIndex = nextBindingIndex();\n\n  if (bindingUpdated(lView, bindingIndex, rawValue)) {\n    const value = Boolean(rawValue);  // handle truthy or falsy values\n    const tView = lView[TVIEW];\n    const tNode = getSelectedTNode();\n    const tDetails = getTDeferBlockDetails(tView, tNode);\n    if (value === true && tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n      // If loading has not been started yet, trigger it now.\n      triggerPrefetching(tDetails, lView);\n    }\n  }\n}\n\n/**\n * Sets up logic to handle the `on idle` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnIdle() {\n  scheduleDelayedTrigger(onIdle);\n}\n\n/**\n * Sets up logic to handle the `prefetch on idle` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnIdle() {\n  scheduleDelayedPrefetching(onIdle, DeferBlockTriggers.OnIdle);\n}\n\n/**\n * Sets up logic to handle the `on immediate` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnImmediate() {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  // Render placeholder block only if loading template is not present\n  // to avoid content flickering, since it would be immediately replaced\n  // by the loading block.\n  if (tDetails.loadingTmplIndex === null) {\n    renderPlaceholder(lView, tNode);\n  }\n  triggerDeferBlock(lView, tNode);\n}\n\n\n/**\n * Sets up logic to handle the `prefetch on immediate` deferred trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnImmediate() {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    triggerResourceLoading(tDetails, lView);\n  }\n}\n\n/**\n * Creates runtime data structures for the `on timer` deferred trigger.\n * @param delay Amount of time to wait before loading the content.\n * @codeGenApi\n */\nexport function ɵɵdeferOnTimer(delay: number) {\n  scheduleDelayedTrigger(onTimer(delay));\n}\n\n/**\n * Creates runtime data structures for the `prefetch on timer` deferred trigger.\n * @param delay Amount of time to wait before prefetching the content.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnTimer(delay: number) {\n  scheduleDelayedPrefetching(onTimer(delay), DeferBlockTriggers.OnTimer);\n}\n\n/**\n * Creates runtime data structures for the `on hover` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnHover(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  registerDomTrigger(\n      lView, tNode, triggerIndex, walkUpTimes, onHover, () => triggerDeferBlock(lView, tNode));\n}\n\n/**\n * Creates runtime data structures for the `prefetch on hover` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnHover(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    registerDomTrigger(\n        lView, tNode, triggerIndex, walkUpTimes, onHover,\n        () => triggerPrefetching(tDetails, lView));\n  }\n}\n\n/**\n * Creates runtime data structures for the `on interaction` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnInteraction(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  registerDomTrigger(\n      lView, tNode, triggerIndex, walkUpTimes, onInteraction,\n      () => triggerDeferBlock(lView, tNode));\n}\n\n/**\n * Creates runtime data structures for the `prefetch on interaction` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnInteraction(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    registerDomTrigger(\n        lView, tNode, triggerIndex, walkUpTimes, onInteraction,\n        () => triggerPrefetching(tDetails, lView));\n  }\n}\n\n/**\n * Creates runtime data structures for the `on viewport` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferOnViewport(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  registerDomTrigger(\n      lView, tNode, triggerIndex, walkUpTimes, onViewport, () => triggerDeferBlock(lView, tNode));\n}\n\n/**\n * Creates runtime data structures for the `prefetch on viewport` deferred trigger.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to walk up/down the tree hierarchy to find the trigger.\n * @codeGenApi\n */\nexport function ɵɵdeferPrefetchOnViewport(triggerIndex: number, walkUpTimes?: number) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    registerDomTrigger(\n        lView, tNode, triggerIndex, walkUpTimes, onViewport,\n        () => triggerPrefetching(tDetails, lView));\n  }\n}\n\n/********** Helper functions **********/\n\n/**\n * Schedules triggering of a defer block for `on idle` and `on timer` conditions.\n */\nfunction scheduleDelayedTrigger(\n    scheduleFn: (callback: VoidFunction, lView: LView, withLViewCleanup: boolean) => VoidFunction) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n\n  renderPlaceholder(lView, tNode);\n  scheduleFn(() => triggerDeferBlock(lView, tNode), lView, true /* withLViewCleanup */);\n}\n\n/**\n * Schedules prefetching for `on idle` and `on timer` triggers.\n *\n * @param scheduleFn A function that does the scheduling.\n * @param trigger A trigger that initiated scheduling.\n */\nfunction scheduleDelayedPrefetching(\n    scheduleFn: (callback: VoidFunction, lView: LView, withLViewCleanup: boolean) => VoidFunction,\n    trigger: DeferBlockTriggers) {\n  const lView = getLView();\n  const tNode = getCurrentTNode()!;\n  const tView = lView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  if (tDetails.loadingState === DeferDependenciesLoadingState.NOT_STARTED) {\n    // Prevent scheduling more than one prefetch init call\n    // for each defer block. For this reason we use only a trigger\n    // identifier in a key, so all instances would use the same key.\n    const key = String(trigger);\n    const injector = lView[INJECTOR]!;\n    const manager = injector.get(DeferBlockCleanupManager);\n    if (!manager.has(tDetails, key)) {\n      // In case of prefetching, we intentionally avoid cancelling resource loading if\n      // an underlying LView get destroyed (thus passing `null` as a second argument),\n      // because there might be other LViews (that represent embedded views) that\n      // depend on resource loading.\n      const prefetch = () => triggerPrefetching(tDetails, lView);\n      const cleanupFn = scheduleFn(prefetch, lView, false /* withLViewCleanup */);\n      registerTDetailsCleanup(injector, tDetails, key, cleanupFn);\n    }\n  }\n}\n\n/**\n * Helper function to get the LView in which a deferred block's trigger is rendered.\n * @param deferredHostLView LView in which the deferred block is defined.\n * @param deferredTNode TNode defining the deferred block.\n * @param walkUpTimes Number of times to go up in the view hierarchy to find the trigger's view.\n *   A negative value means that the trigger is inside the block's placeholder, while an undefined\n *   value means that the trigger is in the same LView as the deferred block.\n */\nfunction getTriggerLView(\n    deferredHostLView: LView, deferredTNode: TNode, walkUpTimes: number|undefined): LView|null {\n  // The trigger is in the same view, we don't need to traverse.\n  if (walkUpTimes == null) {\n    return deferredHostLView;\n  }\n\n  // A positive value or zero means that the trigger is in a parent view.\n  if (walkUpTimes >= 0) {\n    return walkUpViews(walkUpTimes, deferredHostLView);\n  }\n\n  // If the value is negative, it means that the trigger is inside the placeholder.\n  const deferredContainer = deferredHostLView[deferredTNode.index];\n  ngDevMode && assertLContainer(deferredContainer);\n  const triggerLView = deferredContainer[CONTAINER_HEADER_OFFSET] ?? null;\n\n  // We need to null check, because the placeholder might not have been rendered yet.\n  if (ngDevMode && triggerLView !== null) {\n    const lDetails = getLDeferBlockDetails(deferredHostLView, deferredTNode);\n    const renderedState = lDetails[DEFER_BLOCK_STATE];\n    assertEqual(\n        renderedState, DeferBlockState.Placeholder,\n        'Expected a placeholder to be rendered in this defer block.');\n    assertLView(triggerLView);\n  }\n\n  return triggerLView;\n}\n\n/**\n * Gets the element that a deferred block's trigger is pointing to.\n * @param triggerLView LView in which the trigger is defined.\n * @param triggerIndex Index at which the trigger element should've been rendered.\n */\nfunction getTriggerElement(triggerLView: LView, triggerIndex: number): Element {\n  const element = getNativeByIndex(HEADER_OFFSET + triggerIndex, triggerLView);\n  ngDevMode && assertElement(element);\n  return element as Element;\n}\n\n/**\n * Registers a DOM-node based trigger.\n * @param initialLView LView in which the defer block is rendered.\n * @param tNode TNode representing the defer block.\n * @param triggerIndex Index at which to find the trigger element.\n * @param walkUpTimes Number of times to go up/down in the view hierarchy to find the trigger.\n * @param registerFn Function that will register the DOM events.\n * @param callback Callback to be invoked when the trigger receives the event that should render\n *     the deferred block.\n */\nfunction registerDomTrigger(\n    initialLView: LView, tNode: TNode, triggerIndex: number, walkUpTimes: number|undefined,\n    registerFn: (element: Element, callback: VoidFunction, injector: Injector) => VoidFunction,\n    callback: VoidFunction) {\n  const injector = initialLView[INJECTOR]!;\n\n  // Assumption: the `afterRender` reference should be destroyed\n  // automatically so we don't need to keep track of it.\n  const afterRenderRef = afterRender(() => {\n    const lDetails = getLDeferBlockDetails(initialLView, tNode);\n    const renderedState = lDetails[DEFER_BLOCK_STATE];\n\n    // If the block was loaded before the trigger was resolved, we don't need to do anything.\n    if (renderedState !== DeferBlockInternalState.Initial &&\n        renderedState !== DeferBlockState.Placeholder) {\n      afterRenderRef.destroy();\n      return;\n    }\n\n    const triggerLView = getTriggerLView(initialLView, tNode, walkUpTimes);\n\n    // Keep polling until we resolve the trigger's LView.\n    // `afterRender` should stop automatically if the view is destroyed.\n    if (!triggerLView) {\n      return;\n    }\n\n    // It's possible that the trigger's view was destroyed before we resolved the trigger element.\n    if (triggerLView[FLAGS] & LViewFlags.Destroyed) {\n      afterRenderRef.destroy();\n      return;\n    }\n\n    // TODO: add integration with `DeferBlockCleanupManager`.\n    const element = getTriggerElement(triggerLView, triggerIndex);\n    const cleanup = registerFn(element, () => {\n      callback();\n      removeLViewOnDestroy(triggerLView, cleanup);\n      if (initialLView !== triggerLView) {\n        removeLViewOnDestroy(initialLView, cleanup);\n      }\n      cleanup();\n    }, injector);\n\n    afterRenderRef.destroy();\n    storeLViewOnDestroy(triggerLView, cleanup);\n\n    // Since the trigger and deferred block might be in different\n    // views, we have to register the callback in both locations.\n    if (initialLView !== triggerLView) {\n      storeLViewOnDestroy(initialLView, cleanup);\n    }\n  }, {injector});\n}\n\n/**\n * Helper function to schedule a callback to be invoked when a browser becomes idle.\n *\n * @param callback A function to be invoked when a browser becomes idle.\n * @param lView LView that hosts an instance of a defer block.\n * @param withLViewCleanup A flag that indicates whether a scheduled callback\n *           should be cancelled in case an LView is destroyed before a callback\n *           was invoked.\n */\nfunction onIdle(callback: VoidFunction, lView: LView, withLViewCleanup: boolean) {\n  const injector = lView[INJECTOR]!;\n  const scheduler = injector.get(OnIdleScheduler);\n  const cleanupFn = () => scheduler.remove(callback);\n  const wrappedCallback =\n      withLViewCleanup ? wrapWithLViewCleanup(callback, lView, cleanupFn) : callback;\n  scheduler.add(wrappedCallback);\n  return cleanupFn;\n}\n\n/**\n * Returns a function that captures a provided delay.\n * Invoking the returned function schedules a trigger.\n */\nfunction onTimer(delay: number) {\n  return (callback: VoidFunction, lView: LView, withLViewCleanup: boolean) =>\n             scheduleTimerTrigger(delay, callback, lView, withLViewCleanup);\n}\n\n/**\n * Schedules a callback to be invoked after a given timeout.\n *\n * @param delay A number of ms to wait until firing a callback.\n * @param callback A function to be invoked after a timeout.\n * @param lView LView that hosts an instance of a defer block.\n * @param withLViewCleanup A flag that indicates whether a scheduled callback\n *           should be cancelled in case an LView is destroyed before a callback\n *           was invoked.\n */\nfunction scheduleTimerTrigger(\n    delay: number, callback: VoidFunction, lView: LView, withLViewCleanup: boolean) {\n  const injector = lView[INJECTOR]!;\n  const scheduler = injector.get(TimerScheduler);\n  const cleanupFn = () => scheduler.remove(callback);\n  const wrappedCallback =\n      withLViewCleanup ? wrapWithLViewCleanup(callback, lView, cleanupFn) : callback;\n  scheduler.add(delay, wrappedCallback);\n  return cleanupFn;\n}\n\n/**\n * Wraps a given callback into a logic that registers a cleanup function\n * in the LView cleanup slot, to be invoked when an LView is destroyed.\n */\nfunction wrapWithLViewCleanup(\n    callback: VoidFunction, lView: LView, cleanup: VoidFunction): VoidFunction {\n  const wrappedCallback = () => {\n    callback();\n    removeLViewOnDestroy(lView, cleanup);\n  };\n  storeLViewOnDestroy(lView, cleanup);\n  return wrappedCallback;\n}\n\n/**\n * Calculates a data slot index for defer block info (either static or\n * instance-specific), given an index of a defer instruction.\n */\nfunction getDeferBlockDataIndex(deferBlockIndex: number) {\n  // Instance state is located at the *next* position\n  // after the defer block slot in an LView or TView.data.\n  return deferBlockIndex + 1;\n}\n\n/** Retrieves a defer block state from an LView, given a TNode that represents a block. */\nfunction getLDeferBlockDetails(lView: LView, tNode: TNode): LDeferBlockDetails {\n  const tView = lView[TVIEW];\n  const slotIndex = getDeferBlockDataIndex(tNode.index);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  return lView[slotIndex];\n}\n\n/** Stores a defer block instance state in LView. */\nfunction setLDeferBlockDetails(\n    lView: LView, deferBlockIndex: number, lDetails: LDeferBlockDetails) {\n  const tView = lView[TVIEW];\n  const slotIndex = getDeferBlockDataIndex(deferBlockIndex);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  lView[slotIndex] = lDetails;\n}\n\n/** Retrieves static info about a defer block, given a TView and a TNode that represents a block. */\nfunction getTDeferBlockDetails(tView: TView, tNode: TNode): TDeferBlockDetails {\n  const slotIndex = getDeferBlockDataIndex(tNode.index);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  return tView.data[slotIndex] as TDeferBlockDetails;\n}\n\n/** Stores a defer block static info in `TView.data`. */\nfunction setTDeferBlockDetails(\n    tView: TView, deferBlockIndex: number, deferBlockConfig: TDeferBlockDetails) {\n  const slotIndex = getDeferBlockDataIndex(deferBlockIndex);\n  ngDevMode && assertIndexInDeclRange(tView, slotIndex);\n  tView.data[slotIndex] = deferBlockConfig;\n}\n\nfunction getTemplateIndexForState(\n    newState: DeferBlockState, hostLView: LView, tNode: TNode): number|null {\n  const tView = hostLView[TVIEW];\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n\n  switch (newState) {\n    case DeferBlockState.Complete:\n      return tDetails.primaryTmplIndex;\n    case DeferBlockState.Loading:\n      return tDetails.loadingTmplIndex;\n    case DeferBlockState.Error:\n      return tDetails.errorTmplIndex;\n    case DeferBlockState.Placeholder:\n      return tDetails.placeholderTmplIndex;\n    default:\n      ngDevMode && throwError(`Unexpected defer block state: ${newState}`);\n      return null;\n  }\n}\n\n/**\n * Returns a minimum amount of time that a given state should be rendered for,\n * taking into account `minimum` parameter value. If the `minimum` value is\n * not specified - returns `null`.\n */\nfunction getMinimumDurationForState(\n    tDetails: TDeferBlockDetails, currentState: DeferBlockState): number|null {\n  if (currentState === DeferBlockState.Placeholder) {\n    return tDetails.placeholderBlockConfig?.[MINIMUM_SLOT] ?? null;\n  } else if (currentState === DeferBlockState.Loading) {\n    return tDetails.loadingBlockConfig?.[MINIMUM_SLOT] ?? null;\n  }\n  return null;\n}\n\n/** Retrieves the value of the `after` parameter on the @loading block. */\nfunction getLoadingBlockAfter(tDetails: TDeferBlockDetails): number|null {\n  return tDetails.loadingBlockConfig?.[LOADING_AFTER_SLOT] ?? null;\n}\n\n/**\n * Transitions a defer block to the new state. Updates the  necessary\n * data structures and renders corresponding block.\n *\n * @param newState New state that should be applied to the defer block.\n * @param tNode TNode that represents a defer block.\n * @param lContainer Represents an instance of a defer block.\n */\nexport function renderDeferBlockState(\n    newState: DeferBlockState, tNode: TNode, lContainer: LContainer): void {\n  const hostLView = lContainer[PARENT];\n  const hostTView = hostLView[TVIEW];\n\n  // Check if this view is not destroyed. Since the loading process was async,\n  // the view might end up being destroyed by the time rendering happens.\n  if (isDestroyed(hostLView)) return;\n\n  // Make sure this TNode belongs to TView that represents host LView.\n  ngDevMode && assertTNodeForLView(tNode, hostLView);\n\n  const lDetails = getLDeferBlockDetails(hostLView, tNode);\n\n  ngDevMode && assertDefined(lDetails, 'Expected a defer block state defined');\n\n  const currentState = lDetails[DEFER_BLOCK_STATE];\n\n  if (isValidStateChange(currentState, newState) &&\n      isValidStateChange(lDetails[NEXT_DEFER_BLOCK_STATE] ?? -1, newState)) {\n    const tDetails = getTDeferBlockDetails(hostTView, tNode);\n    const needsScheduling = getLoadingBlockAfter(tDetails) !== null ||\n        getMinimumDurationForState(tDetails, DeferBlockState.Loading) !== null ||\n        getMinimumDurationForState(tDetails, DeferBlockState.Placeholder);\n\n    if (ngDevMode && needsScheduling) {\n      assertDefined(\n          applyDeferBlockStateWithSchedulingImpl, 'Expected scheduling function to be defined');\n    }\n\n    const applyStateFn =\n        needsScheduling ? applyDeferBlockStateWithSchedulingImpl! : applyDeferBlockState;\n    applyStateFn(newState, lDetails, lContainer, tNode, hostLView);\n  }\n}\n\n/**\n * Applies changes to the DOM to reflect a given state.\n */\nfunction applyDeferBlockState(\n    newState: DeferBlockState, lDetails: LDeferBlockDetails, lContainer: LContainer, tNode: TNode,\n    hostLView: LView<unknown>) {\n  const stateTmplIndex = getTemplateIndexForState(newState, hostLView, tNode);\n\n  if (stateTmplIndex !== null) {\n    lDetails[DEFER_BLOCK_STATE] = newState;\n    const hostTView = hostLView[TVIEW];\n    const adjustedIndex = stateTmplIndex + HEADER_OFFSET;\n    const tNode = getTNode(hostTView, adjustedIndex) as TContainerNode;\n\n    // There is only 1 view that can be present in an LContainer that\n    // represents a defer block, so always refer to the first one.\n    const viewIndex = 0;\n\n    removeLViewFromLContainer(lContainer, viewIndex);\n    const dehydratedView = findMatchingDehydratedView(lContainer, tNode.tView!.ssrId);\n    const embeddedLView = createAndRenderEmbeddedLView(hostLView, tNode, null, {dehydratedView});\n    addLViewToLContainer(\n        lContainer, embeddedLView, viewIndex, shouldAddViewToDom(tNode, dehydratedView));\n    markViewDirty(embeddedLView);\n  }\n}\n\n/**\n * Extends the `applyDeferBlockState` with timer-based scheduling.\n * This function becomes available on a page if there are defer blocks\n * that use `after` or `minimum` parameters in the `@loading` or\n * `@placeholder` blocks.\n */\nfunction applyDeferBlockStateWithScheduling(\n    newState: DeferBlockState, lDetails: LDeferBlockDetails, lContainer: LContainer, tNode: TNode,\n    hostLView: LView<unknown>) {\n  const now = Date.now();\n  const hostTView = hostLView[TVIEW];\n  const tDetails = getTDeferBlockDetails(hostTView, tNode);\n\n  if (lDetails[STATE_IS_FROZEN_UNTIL] === null || lDetails[STATE_IS_FROZEN_UNTIL] <= now) {\n    lDetails[STATE_IS_FROZEN_UNTIL] = null;\n\n    const loadingAfter = getLoadingBlockAfter(tDetails);\n    const inLoadingAfterPhase = lDetails[LOADING_AFTER_CLEANUP_FN] !== null;\n    if (newState === DeferBlockState.Loading && loadingAfter !== null && !inLoadingAfterPhase) {\n      // Trying to render loading, but it has an `after` config,\n      // so schedule an update action after a timeout.\n      lDetails[NEXT_DEFER_BLOCK_STATE] = newState;\n      const cleanupFn =\n          scheduleDeferBlockUpdate(loadingAfter, lDetails, tNode, lContainer, hostLView);\n      lDetails[LOADING_AFTER_CLEANUP_FN] = cleanupFn;\n    } else {\n      // If we transition to a complete or an error state and there is a pending\n      // operation to render loading after a timeout - invoke a cleanup operation,\n      // which stops the timer.\n      if (newState > DeferBlockState.Loading && inLoadingAfterPhase) {\n        lDetails[LOADING_AFTER_CLEANUP_FN]!();\n        lDetails[LOADING_AFTER_CLEANUP_FN] = null;\n        lDetails[NEXT_DEFER_BLOCK_STATE] = null;\n      }\n\n      applyDeferBlockState(newState, lDetails, lContainer, tNode, hostLView);\n\n      const duration = getMinimumDurationForState(tDetails, newState);\n      if (duration !== null) {\n        lDetails[STATE_IS_FROZEN_UNTIL] = now + duration;\n        scheduleDeferBlockUpdate(duration, lDetails, tNode, lContainer, hostLView);\n      }\n    }\n  } else {\n    // We are still rendering the previous state.\n    // Update the `NEXT_DEFER_BLOCK_STATE`, which would be\n    // picked up once it's time to transition to the next state.\n    lDetails[NEXT_DEFER_BLOCK_STATE] = newState;\n  }\n}\n\n/**\n * Schedules an update operation after a specified timeout.\n */\nfunction scheduleDeferBlockUpdate(\n    timeout: number, lDetails: LDeferBlockDetails, tNode: TNode, lContainer: LContainer,\n    hostLView: LView<unknown>): VoidFunction {\n  const callback = () => {\n    const nextState = lDetails[NEXT_DEFER_BLOCK_STATE];\n    lDetails[STATE_IS_FROZEN_UNTIL] = null;\n    lDetails[NEXT_DEFER_BLOCK_STATE] = null;\n    if (nextState !== null) {\n      renderDeferBlockState(nextState, tNode, lContainer);\n    }\n  };\n  return scheduleTimerTrigger(timeout, callback, hostLView, true);\n}\n\n/**\n * Checks whether we can transition to the next state.\n *\n * We transition to the next state if the previous state was represented\n * with a number that is less than the next state. For example, if the current\n * state is \"loading\" (represented as `1`), we should not show a placeholder\n * (represented as `0`), but we can show a completed state (represented as `2`)\n * or an error state (represented as `3`).\n */\nfunction isValidStateChange(\n    currentState: DeferBlockState|DeferBlockInternalState, newState: DeferBlockState): boolean {\n  return currentState < newState;\n}\n\n/**\n * Trigger prefetching of dependencies for a defer block.\n *\n * @param tDetails Static information about this defer block.\n * @param lView LView of a host view.\n */\nexport function triggerPrefetching(tDetails: TDeferBlockDetails, lView: LView) {\n  if (lView[INJECTOR] && shouldTriggerDeferBlock(lView[INJECTOR]!)) {\n    triggerResourceLoading(tDetails, lView);\n  }\n}\n\n/**\n * Trigger loading of defer block dependencies if the process hasn't started yet.\n *\n * @param tDetails Static information about this defer block.\n * @param lView LView of a host view.\n */\nexport function triggerResourceLoading(tDetails: TDeferBlockDetails, lView: LView) {\n  const injector = lView[INJECTOR]!;\n  const tView = lView[TVIEW];\n\n  if (tDetails.loadingState !== DeferDependenciesLoadingState.NOT_STARTED) {\n    // If the loading status is different from initial one, it means that\n    // the loading of dependencies is in progress and there is nothing to do\n    // in this function. All details can be obtained from the `tDetails` object.\n    return;\n  }\n\n  const primaryBlockTNode = getPrimaryBlockTNode(tView, tDetails);\n\n  // Switch from NOT_STARTED -> IN_PROGRESS state.\n  tDetails.loadingState = DeferDependenciesLoadingState.IN_PROGRESS;\n\n  // Check if dependency function interceptor is configured.\n  const deferDependencyInterceptor =\n      injector.get(DEFER_BLOCK_DEPENDENCY_INTERCEPTOR, null, {optional: true});\n\n  const dependenciesFn = deferDependencyInterceptor ?\n      deferDependencyInterceptor.intercept(tDetails.dependencyResolverFn) :\n      tDetails.dependencyResolverFn;\n\n  // The `dependenciesFn` might be `null` when all dependencies within\n  // a given defer block were eagerly references elsewhere in a file,\n  // thus no dynamic `import()`s were produced.\n  if (!dependenciesFn) {\n    tDetails.loadingPromise = Promise.resolve().then(() => {\n      tDetails.loadingState = DeferDependenciesLoadingState.COMPLETE;\n    });\n    return;\n  }\n\n  // Defer block may have multiple prefetch triggers. Once the loading\n  // starts, invoke all clean functions, since they are no longer needed.\n  invokeTDetailsCleanup(injector, tDetails);\n\n  // Start downloading of defer block dependencies.\n  tDetails.loadingPromise = Promise.allSettled(dependenciesFn()).then(results => {\n    let failed = false;\n    const directiveDefs: DirectiveDefList = [];\n    const pipeDefs: PipeDefList = [];\n\n    for (const result of results) {\n      if (result.status === 'fulfilled') {\n        const dependency = result.value;\n        const directiveDef = getComponentDef(dependency) || getDirectiveDef(dependency);\n        if (directiveDef) {\n          directiveDefs.push(directiveDef);\n        } else {\n          const pipeDef = getPipeDef(dependency);\n          if (pipeDef) {\n            pipeDefs.push(pipeDef);\n          }\n        }\n      } else {\n        failed = true;\n        break;\n      }\n    }\n\n    // Loading is completed, we no longer need this Promise.\n    tDetails.loadingPromise = null;\n\n    if (failed) {\n      tDetails.loadingState = DeferDependenciesLoadingState.FAILED;\n    } else {\n      tDetails.loadingState = DeferDependenciesLoadingState.COMPLETE;\n\n      // Update directive and pipe registries to add newly downloaded dependencies.\n      const primaryBlockTView = primaryBlockTNode.tView!;\n      if (directiveDefs.length > 0) {\n        primaryBlockTView.directiveRegistry =\n            addDepsToRegistry<DirectiveDefList>(primaryBlockTView.directiveRegistry, directiveDefs);\n      }\n      if (pipeDefs.length > 0) {\n        primaryBlockTView.pipeRegistry =\n            addDepsToRegistry<PipeDefList>(primaryBlockTView.pipeRegistry, pipeDefs);\n      }\n    }\n  });\n}\n\n/**\n * Adds downloaded dependencies into a directive or a pipe registry,\n * making sure that a dependency doesn't yet exist in the registry.\n */\nfunction addDepsToRegistry<T extends DependencyDef[]>(currentDeps: T|null, newDeps: T): T {\n  if (!currentDeps || currentDeps.length === 0) {\n    return newDeps;\n  }\n\n  const currentDepSet = new Set(currentDeps);\n  for (const dep of newDeps) {\n    currentDepSet.add(dep);\n  }\n\n  // If `currentDeps` is the same length, there were no new deps and can\n  // return the original array.\n  return (currentDeps.length === currentDepSet.size) ? currentDeps : Array.from(currentDepSet) as T;\n}\n\n/** Utility function to render placeholder content (if present) */\nfunction renderPlaceholder(lView: LView, tNode: TNode) {\n  const lContainer = lView[tNode.index];\n  ngDevMode && assertLContainer(lContainer);\n\n  renderDeferBlockState(DeferBlockState.Placeholder, tNode, lContainer);\n}\n\n/**\n * Subscribes to the \"loading\" Promise and renders corresponding defer sub-block,\n * based on the loading results.\n *\n * @param lContainer Represents an instance of a defer block.\n * @param tNode Represents defer block info shared across all instances.\n */\nfunction renderDeferStateAfterResourceLoading(\n    tDetails: TDeferBlockDetails, tNode: TNode, lContainer: LContainer) {\n  ngDevMode &&\n      assertDefined(\n          tDetails.loadingPromise, 'Expected loading Promise to exist on this defer block');\n\n  tDetails.loadingPromise!.then(() => {\n    if (tDetails.loadingState === DeferDependenciesLoadingState.COMPLETE) {\n      ngDevMode && assertDeferredDependenciesLoaded(tDetails);\n\n      // Everything is loaded, show the primary block content\n      renderDeferBlockState(DeferBlockState.Complete, tNode, lContainer);\n\n    } else if (tDetails.loadingState === DeferDependenciesLoadingState.FAILED) {\n      renderDeferBlockState(DeferBlockState.Error, tNode, lContainer);\n    }\n  });\n}\n\n/** Retrieves a TNode that represents main content of a defer block. */\nfunction getPrimaryBlockTNode(tView: TView, tDetails: TDeferBlockDetails): TContainerNode {\n  const adjustedIndex = tDetails.primaryTmplIndex + HEADER_OFFSET;\n  return getTNode(tView, adjustedIndex) as TContainerNode;\n}\n\n/**\n * Attempts to trigger loading of defer block dependencies.\n * If the block is already in a loading, completed or an error state -\n * no additional actions are taken.\n */\nfunction triggerDeferBlock(lView: LView, tNode: TNode) {\n  const tView = lView[TVIEW];\n  const lContainer = lView[tNode.index];\n  const injector = lView[INJECTOR]!;\n  ngDevMode && assertLContainer(lContainer);\n\n  if (!shouldTriggerDeferBlock(injector)) return;\n\n  const tDetails = getTDeferBlockDetails(tView, tNode);\n  switch (tDetails.loadingState) {\n    case DeferDependenciesLoadingState.NOT_STARTED:\n      renderDeferBlockState(DeferBlockState.Loading, tNode, lContainer);\n      triggerResourceLoading(tDetails, lView);\n\n      // The `loadingState` might have changed to \"loading\".\n      if ((tDetails.loadingState as DeferDependenciesLoadingState) ===\n          DeferDependenciesLoadingState.IN_PROGRESS) {\n        renderDeferStateAfterResourceLoading(tDetails, tNode, lContainer);\n      }\n      break;\n    case DeferDependenciesLoadingState.IN_PROGRESS:\n      renderDeferBlockState(DeferBlockState.Loading, tNode, lContainer);\n      renderDeferStateAfterResourceLoading(tDetails, tNode, lContainer);\n      break;\n    case DeferDependenciesLoadingState.COMPLETE:\n      ngDevMode && assertDeferredDependenciesLoaded(tDetails);\n      renderDeferBlockState(DeferBlockState.Complete, tNode, lContainer);\n      break;\n    case DeferDependenciesLoadingState.FAILED:\n      renderDeferBlockState(DeferBlockState.Error, tNode, lContainer);\n      break;\n    default:\n      if (ngDevMode) {\n        throwError('Unknown defer block state');\n      }\n  }\n}\n\n/**\n * Asserts whether all dependencies for a defer block are loaded.\n * Always run this function (in dev mode) before rendering a defer\n * block in completed state.\n */\nfunction assertDeferredDependenciesLoaded(tDetails: TDeferBlockDetails) {\n  assertEqual(\n      tDetails.loadingState, DeferDependenciesLoadingState.COMPLETE,\n      'Expecting all deferred dependencies to be loaded.');\n}\n\n/**\n * **INTERNAL**, avoid referencing it in application code.\n *\n * Describes a helper class that allows to intercept a call to retrieve current\n * dependency loading function and replace it with a different implementation.\n * This interceptor class is needed to allow testing blocks in different states\n * by simulating loading response.\n */\nexport interface DeferBlockDependencyInterceptor {\n  /**\n   * Invoked for each defer block when dependency loading function is accessed.\n   */\n  intercept(dependencyFn: DependencyResolverFn|null): DependencyResolverFn|null;\n\n  /**\n   * Allows to configure an interceptor function.\n   */\n  setInterceptor(interceptorFn: (current: DependencyResolverFn) => DependencyResolverFn): void;\n}\n\n/**\n * **INTERNAL**, avoid referencing it in application code.\n *\n * Injector token that allows to provide `DeferBlockDependencyInterceptor` class\n * implementation.\n */\nexport const DEFER_BLOCK_DEPENDENCY_INTERCEPTOR =\n    new InjectionToken<DeferBlockDependencyInterceptor>(\n        ngDevMode ? 'DEFER_BLOCK_DEPENDENCY_INTERCEPTOR' : '');\n\n/**\n * Determines if a given value matches the expected structure of a defer block\n *\n * We can safely rely on the primaryTmplIndex because every defer block requires\n * that a primary template exists. All the other template options are optional.\n */\nfunction isTDeferBlockDetails(value: unknown): value is TDeferBlockDetails {\n  return (typeof value === 'object') &&\n      (typeof (value as TDeferBlockDetails).primaryTmplIndex === 'number');\n}\n\n/**\n * Internal token used for configuring defer block behavior.\n */\nexport const DEFER_BLOCK_CONFIG =\n    new InjectionToken<DeferBlockConfig>(ngDevMode ? 'DEFER_BLOCK_CONFIG' : '');\n\n/**\n * Defer block instance for testing.\n */\nexport interface DeferBlockDetails {\n  lContainer: LContainer;\n  lView: LView;\n  tNode: TNode;\n  tDetails: TDeferBlockDetails;\n}\n\n/**\n * Retrieves all defer blocks in a given LView.\n *\n * @param lView lView with defer blocks\n * @param deferBlocks defer block aggregator array\n */\nexport function getDeferBlocks(lView: LView, deferBlocks: DeferBlockDetails[]) {\n  const tView = lView[TVIEW];\n  for (let i = HEADER_OFFSET; i < tView.bindingStartIndex; i++) {\n    if (isLContainer(lView[i])) {\n      const lContainer = lView[i];\n      // An LContainer may represent an instance of a defer block, in which case\n      // we store it as a result. Otherwise, keep iterating over LContainer views and\n      // look for defer blocks.\n      const isLast = i === tView.bindingStartIndex - 1;\n      if (!isLast) {\n        const tNode = tView.data[i] as TNode;\n        const tDetails = getTDeferBlockDetails(tView, tNode);\n        if (isTDeferBlockDetails(tDetails)) {\n          deferBlocks.push({lContainer, lView, tNode, tDetails});\n          // This LContainer represents a defer block, so we exit\n          // this iteration and don't inspect views in this LContainer.\n          continue;\n        }\n      }\n      for (let i = CONTAINER_HEADER_OFFSET; i < lContainer.length; i++) {\n        getDeferBlocks(lContainer[i] as LView, deferBlocks);\n      }\n    } else if (isLView(lView[i])) {\n      // This is a component, enter the `getDeferBlocks` recursively.\n      getDeferBlocks(lView[i], deferBlocks);\n    }\n  }\n}\n\n/**\n * Registers a cleanup function associated with a prefetching trigger\n * of a given defer block.\n */\nfunction registerTDetailsCleanup(\n    injector: Injector, tDetails: TDeferBlockDetails, key: string, cleanupFn: VoidFunction) {\n  injector.get(DeferBlockCleanupManager).add(tDetails, key, cleanupFn);\n}\n\n/**\n * Invokes all registered prefetch cleanup triggers\n * and removes all cleanup functions afterwards.\n */\nfunction invokeTDetailsCleanup(injector: Injector, tDetails: TDeferBlockDetails) {\n  injector.get(DeferBlockCleanupManager).cleanup(tDetails);\n}\n\n/**\n * Internal service to keep track of cleanup functions associated\n * with defer blocks. This class is used to manage cleanup functions\n * created for prefetching triggers.\n */\nclass DeferBlockCleanupManager {\n  private blocks = new Map<TDeferBlockDetails, Map<string, VoidFunction[]>>();\n\n  add(tDetails: TDeferBlockDetails, key: string, callback: VoidFunction) {\n    if (!this.blocks.has(tDetails)) {\n      this.blocks.set(tDetails, new Map());\n    }\n    const block = this.blocks.get(tDetails)!;\n    if (!block.has(key)) {\n      block.set(key, []);\n    }\n    const callbacks = block.get(key)!;\n    callbacks.push(callback);\n  }\n\n  has(tDetails: TDeferBlockDetails, key: string): boolean {\n    return !!this.blocks.get(tDetails)?.has(key);\n  }\n\n  cleanup(tDetails: TDeferBlockDetails) {\n    const block = this.blocks.get(tDetails);\n    if (block) {\n      for (const callbacks of Object.values(block)) {\n        for (const callback of callbacks) {\n          callback();\n        }\n      }\n      this.blocks.delete(tDetails);\n    }\n  }\n\n  ngOnDestroy() {\n    for (const [block] of this.blocks) {\n      this.cleanup(block);\n    }\n    this.blocks.clear();\n  }\n\n  /** @nocollapse */\n  static ɵprov = /** @pureOrBreakMyCode */ ɵɵdefineInjectable({\n    token: DeferBlockCleanupManager,\n    providedIn: 'root',\n    factory: () => new DeferBlockCleanupManager(),\n  });\n}\n\n/**\n * Use shims for the `requestIdleCallback` and `cancelIdleCallback` functions for\n * environments where those functions are not available (e.g. Node.js and Safari).\n *\n * Note: we wrap the `requestIdleCallback` call into a function, so that it can be\n * overridden/mocked in test environment and picked up by the runtime code.\n */\nconst _requestIdleCallback = () =>\n    typeof requestIdleCallback !== 'undefined' ? requestIdleCallback : setTimeout;\nconst _cancelIdleCallback = () =>\n    typeof requestIdleCallback !== 'undefined' ? cancelIdleCallback : clearTimeout;\n\n/**\n * Helper service to schedule `requestIdleCallback`s for batches of defer blocks,\n * to avoid calling `requestIdleCallback` for each defer block (e.g. if\n * defer blocks are defined inside a for loop).\n */\nclass OnIdleScheduler {\n  // Indicates whether current callbacks are being invoked.\n  executingCallbacks = false;\n\n  // Currently scheduled idle callback id.\n  idleId: number|null = null;\n\n  // Set of callbacks to be invoked next.\n  current = new Set<VoidFunction>();\n\n  // Set of callbacks collected while invoking current set of callbacks.\n  // Those callbacks are scheduled for the next idle period.\n  deferred = new Set<VoidFunction>();\n\n  ngZone = inject(NgZone);\n\n  requestIdleCallback = _requestIdleCallback().bind(globalThis);\n  cancelIdleCallback = _cancelIdleCallback().bind(globalThis);\n\n  add(callback: VoidFunction) {\n    const target = this.executingCallbacks ? this.deferred : this.current;\n    target.add(callback);\n    if (this.idleId === null) {\n      this.scheduleIdleCallback();\n    }\n  }\n\n  remove(callback: VoidFunction) {\n    this.current.delete(callback);\n    this.deferred.delete(callback);\n  }\n\n  private scheduleIdleCallback() {\n    const callback = () => {\n      this.cancelIdleCallback(this.idleId!);\n      this.idleId = null;\n\n      this.executingCallbacks = true;\n\n      for (const callback of this.current) {\n        callback();\n      }\n      this.current.clear();\n\n      this.executingCallbacks = false;\n\n      // If there are any callbacks added during an invocation\n      // of the current ones - make them \"current\" and schedule\n      // a new idle callback.\n      if (this.deferred.size > 0) {\n        for (const callback of this.deferred) {\n          this.current.add(callback);\n        }\n        this.deferred.clear();\n        this.scheduleIdleCallback();\n      }\n    };\n    // Ensure that the callback runs in the NgZone since\n    // the `requestIdleCallback` is not currently patched by Zone.js.\n    this.idleId = this.requestIdleCallback(() => this.ngZone.run(callback)) as number;\n  }\n\n  ngOnDestroy() {\n    if (this.idleId !== null) {\n      this.cancelIdleCallback(this.idleId);\n      this.idleId = null;\n    }\n    this.current.clear();\n    this.deferred.clear();\n  }\n\n  /** @nocollapse */\n  static ɵprov = /** @pureOrBreakMyCode */ ɵɵdefineInjectable({\n    token: OnIdleScheduler,\n    providedIn: 'root',\n    factory: () => new OnIdleScheduler(),\n  });\n}\n\n/**\n * Helper service to schedule `setTimeout`s for batches of defer blocks,\n * to avoid calling `setTimeout` for each defer block (e.g. if defer blocks\n * are created inside a for loop).\n */\nclass TimerScheduler {\n  // Indicates whether current callbacks are being invoked.\n  executingCallbacks = false;\n\n  // Currently scheduled `setTimeout` id.\n  timeoutId: number|null = null;\n\n  // When currently scheduled timer would fire.\n  invokeTimerAt: number|null = null;\n\n  // List of callbacks to be invoked.\n  // For each callback we also store a timestamp on when the callback\n  // should be invoked. We store timestamps and callback functions\n  // in a flat array to avoid creating new objects for each entry.\n  // [timestamp1, callback1, timestamp2, callback2, ...]\n  current: Array<number|VoidFunction> = [];\n\n  // List of callbacks collected while invoking current set of callbacks.\n  // Those callbacks are added to the \"current\" queue at the end of\n  // the current callback invocation. The shape of this list is the same\n  // as the shape of the `current` list.\n  deferred: Array<number|VoidFunction> = [];\n\n  add(delay: number, callback: VoidFunction) {\n    const target = this.executingCallbacks ? this.deferred : this.current;\n    this.addToQueue(target, Date.now() + delay, callback);\n    this.scheduleTimer();\n  }\n\n  remove(callback: VoidFunction) {\n    const callbackIndex = this.removeFromQueue(this.current, callback);\n    if (callbackIndex === -1) {\n      // Try cleaning up deferred queue only in case\n      // we didn't find a callback in the \"current\" queue.\n      this.removeFromQueue(this.deferred, callback);\n    }\n  }\n\n  private addToQueue(target: Array<number|VoidFunction>, invokeAt: number, callback: VoidFunction) {\n    let insertAtIndex = target.length;\n    for (let i = 0; i < target.length; i += 2) {\n      const invokeQueuedCallbackAt = target[i] as number;\n      if (invokeQueuedCallbackAt > invokeAt) {\n        // We've reached a first timer that is scheduled\n        // for a later time than what we are trying to insert.\n        // This is the location at which we need to insert,\n        // no need to iterate further.\n        insertAtIndex = i;\n        break;\n      }\n    }\n    arrayInsert2(target, insertAtIndex, invokeAt, callback);\n  }\n\n  private removeFromQueue(target: Array<number|VoidFunction>, callback: VoidFunction) {\n    let index = -1;\n    for (let i = 0; i < target.length; i += 2) {\n      const queuedCallback = target[i + 1];\n      if (queuedCallback === callback) {\n        index = i;\n        break;\n      }\n    }\n    if (index > -1) {\n      // Remove 2 elements: a timestamp slot and\n      // the following slot with a callback function.\n      arraySplice(target, index, 2);\n    }\n    return index;\n  }\n\n  private scheduleTimer() {\n    const callback = () => {\n      clearTimeout(this.timeoutId!);\n      this.timeoutId = null;\n\n      this.executingCallbacks = true;\n\n      // Invoke callbacks that were scheduled to run\n      // before the current time.\n      let now = Date.now();\n      let lastCallbackIndex: number|null = null;\n      for (let i = 0; i < this.current.length; i += 2) {\n        const invokeAt = this.current[i] as number;\n        const callback = this.current[i + 1] as VoidFunction;\n        if (invokeAt <= now) {\n          callback();\n          // Point at the invoked callback function, which is located\n          // after the timestamp.\n          lastCallbackIndex = i + 1;\n        } else {\n          // We've reached a timer that should not be invoked yet.\n          break;\n        }\n      }\n      if (lastCallbackIndex !== null) {\n        // If last callback index is `null` - no callbacks were invoked,\n        // so no cleanup is needed. Otherwise, remove invoked callbacks\n        // from the queue.\n        arraySplice(this.current, 0, lastCallbackIndex + 1);\n      }\n\n      this.executingCallbacks = false;\n\n      // If there are any callbacks added during an invocation\n      // of the current ones - move them over to the \"current\"\n      // queue.\n      if (this.deferred.length > 0) {\n        for (let i = 0; i < this.deferred.length; i += 2) {\n          const invokeAt = this.deferred[i] as number;\n          const callback = this.deferred[i + 1] as VoidFunction;\n          this.addToQueue(this.current, invokeAt, callback);\n        }\n        this.deferred.length = 0;\n      }\n      this.scheduleTimer();\n    };\n\n    // Avoid running timer callbacks more than once per\n    // average frame duration. This is needed for better\n    // batching and to avoid kicking off excessive change\n    // detection cycles.\n    const FRAME_DURATION_MS = 16;  // 1000ms / 60fps\n\n    if (this.current.length > 0) {\n      const now = Date.now();\n      // First element in the queue points at the timestamp\n      // of the first (earliest) event.\n      const invokeAt = this.current[0] as number;\n      if (!this.timeoutId ||\n          // Reschedule a timer in case a queue contains an item with\n          // an earlier timestamp and the delta is more than an average\n          // frame duration.\n          (this.invokeTimerAt && (this.invokeTimerAt - invokeAt > FRAME_DURATION_MS))) {\n        if (this.timeoutId !== null) {\n          // There was a timeout already, but an earlier event was added\n          // into the queue. In this case we drop an old timer and setup\n          // a new one with an updated (smaller) timeout.\n          clearTimeout(this.timeoutId);\n          this.timeoutId = null;\n        }\n        const timeout = Math.max(invokeAt - now, FRAME_DURATION_MS);\n        this.invokeTimerAt = invokeAt;\n        this.timeoutId = setTimeout(callback, timeout) as unknown as number;\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.timeoutId !== null) {\n      clearTimeout(this.timeoutId);\n      this.timeoutId = null;\n    }\n    this.current.length = 0;\n    this.deferred.length = 0;\n  }\n\n  /** @nocollapse */\n  static ɵprov = /** @pureOrBreakMyCode */ ɵɵdefineInjectable({\n    token: TimerScheduler,\n    providedIn: 'root',\n    factory: () => new TimerScheduler(),\n  });\n}\n"]}
|