@angular/router 19.0.0-next.1 → 19.0.0-next.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/router.mjs +86 -96
- package/fesm2022/router.mjs.map +1 -1
- package/fesm2022/testing.mjs +11 -11
- package/fesm2022/upgrade.mjs +1 -1
- package/index.d.ts +1 -1
- package/package.json +4 -10
- package/testing/index.d.ts +1 -1
- package/upgrade/index.d.ts +1 -1
- package/esm2022/index.mjs +0 -13
- package/esm2022/public_api.mjs +0 -15
- package/esm2022/router.mjs +0 -5
- package/esm2022/src/apply_redirects.mjs +0 -124
- package/esm2022/src/components/empty_outlet.mjs +0 -49
- package/esm2022/src/create_router_state.mjs +0 -52
- package/esm2022/src/create_url_tree.mjs +0 -420
- package/esm2022/src/directives/router_link.mjs +0 -361
- package/esm2022/src/directives/router_link_active.mjs +0 -237
- package/esm2022/src/directives/router_outlet.mjs +0 -388
- package/esm2022/src/errors.mjs +0 -2
- package/esm2022/src/events.mjs +0 -588
- package/esm2022/src/index.mjs +0 -31
- package/esm2022/src/models.mjs +0 -45
- package/esm2022/src/models_deprecated.mjs +0 -9
- package/esm2022/src/navigation_canceling_error.mjs +0 -33
- package/esm2022/src/navigation_transition.mjs +0 -437
- package/esm2022/src/operators/activate_routes.mjs +0 -190
- package/esm2022/src/operators/check_guards.mjs +0 -157
- package/esm2022/src/operators/prioritized_guard_value.mjs +0 -40
- package/esm2022/src/operators/recognize.mjs +0 -15
- package/esm2022/src/operators/resolve_data.mjs +0 -92
- package/esm2022/src/operators/switch_tap.mjs +0 -25
- package/esm2022/src/page_title_strategy.mjs +0 -89
- package/esm2022/src/private_export.mjs +0 -12
- package/esm2022/src/provide_router.mjs +0 -549
- package/esm2022/src/recognize.mjs +0 -321
- package/esm2022/src/route_reuse_strategy.mjs +0 -79
- package/esm2022/src/router.mjs +0 -571
- package/esm2022/src/router_config.mjs +0 -18
- package/esm2022/src/router_config_loader.mjs +0 -137
- package/esm2022/src/router_module.mjs +0 -226
- package/esm2022/src/router_outlet_context.mjs +0 -90
- package/esm2022/src/router_preloader.mjs +0 -162
- package/esm2022/src/router_scroller.mjs +0 -111
- package/esm2022/src/router_state.mjs +0 -419
- package/esm2022/src/shared.mjs +0 -97
- package/esm2022/src/statemanager/state_manager.mjs +0 -200
- package/esm2022/src/url_handling_strategy.mjs +0 -45
- package/esm2022/src/url_tree.mjs +0 -643
- package/esm2022/src/utils/collection.mjs +0 -75
- package/esm2022/src/utils/config.mjs +0 -191
- package/esm2022/src/utils/config_matching.mjs +0 -150
- package/esm2022/src/utils/functional_guards.mjs +0 -69
- package/esm2022/src/utils/navigations.mjs +0 -44
- package/esm2022/src/utils/preactivation.mjs +0 -154
- package/esm2022/src/utils/tree.mjs +0 -94
- package/esm2022/src/utils/type_guards.mjs +0 -46
- package/esm2022/src/utils/view_transition.mjs +0 -61
- package/esm2022/src/version.mjs +0 -18
- package/esm2022/testing/index.mjs +0 -13
- package/esm2022/testing/public_api.mjs +0 -15
- package/esm2022/testing/src/router_testing_harness.mjs +0 -127
- package/esm2022/testing/src/router_testing_module.mjs +0 -75
- package/esm2022/testing/src/testing.mjs +0 -15
- package/esm2022/testing/testing.mjs +0 -5
- package/esm2022/upgrade/index.mjs +0 -13
- package/esm2022/upgrade/public_api.mjs +0 -15
- package/esm2022/upgrade/src/upgrade.mjs +0 -128
- package/esm2022/upgrade/upgrade.mjs +0 -5
|
@@ -1,388 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { ChangeDetectorRef, Directive, EventEmitter, inject, Injectable, InjectionToken, Input, Output, reflectComponentType, ViewContainerRef, ɵRuntimeError as RuntimeError, input, } from '@angular/core';
|
|
9
|
-
import { combineLatest, of } from 'rxjs';
|
|
10
|
-
import { switchMap } from 'rxjs/operators';
|
|
11
|
-
import { ChildrenOutletContexts } from '../router_outlet_context';
|
|
12
|
-
import { ActivatedRoute } from '../router_state';
|
|
13
|
-
import { PRIMARY_OUTLET } from '../shared';
|
|
14
|
-
import * as i0 from "@angular/core";
|
|
15
|
-
/**
|
|
16
|
-
* An `InjectionToken` provided by the `RouterOutlet` and can be set using the `routerOutletData`
|
|
17
|
-
* input.
|
|
18
|
-
*
|
|
19
|
-
* When unset, this value is `null` by default.
|
|
20
|
-
*
|
|
21
|
-
* @usageNotes
|
|
22
|
-
*
|
|
23
|
-
* To set the data from the template of the component with `router-outlet`:
|
|
24
|
-
* ```
|
|
25
|
-
* <router-outlet [routerOutletData]="{name: 'Angular'}" />
|
|
26
|
-
* ```
|
|
27
|
-
*
|
|
28
|
-
* To read the data in the routed component:
|
|
29
|
-
* ```
|
|
30
|
-
* data = inject(ROUTER_OUTLET_DATA) as Signal<{name: string}>;
|
|
31
|
-
* ```
|
|
32
|
-
*
|
|
33
|
-
* @publicApi
|
|
34
|
-
*/
|
|
35
|
-
export const ROUTER_OUTLET_DATA = new InjectionToken(ngDevMode ? 'RouterOutlet data' : '');
|
|
36
|
-
/**
|
|
37
|
-
* @description
|
|
38
|
-
*
|
|
39
|
-
* Acts as a placeholder that Angular dynamically fills based on the current router state.
|
|
40
|
-
*
|
|
41
|
-
* Each outlet can have a unique name, determined by the optional `name` attribute.
|
|
42
|
-
* The name cannot be set or changed dynamically. If not set, default value is "primary".
|
|
43
|
-
*
|
|
44
|
-
* ```
|
|
45
|
-
* <router-outlet></router-outlet>
|
|
46
|
-
* <router-outlet name='left'></router-outlet>
|
|
47
|
-
* <router-outlet name='right'></router-outlet>
|
|
48
|
-
* ```
|
|
49
|
-
*
|
|
50
|
-
* Named outlets can be the targets of secondary routes.
|
|
51
|
-
* The `Route` object for a secondary route has an `outlet` property to identify the target outlet:
|
|
52
|
-
*
|
|
53
|
-
* `{path: <base-path>, component: <component>, outlet: <target_outlet_name>}`
|
|
54
|
-
*
|
|
55
|
-
* Using named outlets and secondary routes, you can target multiple outlets in
|
|
56
|
-
* the same `RouterLink` directive.
|
|
57
|
-
*
|
|
58
|
-
* The router keeps track of separate branches in a navigation tree for each named outlet and
|
|
59
|
-
* generates a representation of that tree in the URL.
|
|
60
|
-
* The URL for a secondary route uses the following syntax to specify both the primary and secondary
|
|
61
|
-
* routes at the same time:
|
|
62
|
-
*
|
|
63
|
-
* `http://base-path/primary-route-path(outlet-name:route-path)`
|
|
64
|
-
*
|
|
65
|
-
* A router outlet emits an activate event when a new component is instantiated,
|
|
66
|
-
* deactivate event when a component is destroyed.
|
|
67
|
-
* An attached event emits when the `RouteReuseStrategy` instructs the outlet to reattach the
|
|
68
|
-
* subtree, and the detached event emits when the `RouteReuseStrategy` instructs the outlet to
|
|
69
|
-
* detach the subtree.
|
|
70
|
-
*
|
|
71
|
-
* ```
|
|
72
|
-
* <router-outlet
|
|
73
|
-
* (activate)='onActivate($event)'
|
|
74
|
-
* (deactivate)='onDeactivate($event)'
|
|
75
|
-
* (attach)='onAttach($event)'
|
|
76
|
-
* (detach)='onDetach($event)'></router-outlet>
|
|
77
|
-
* ```
|
|
78
|
-
*
|
|
79
|
-
* @see {@link RouterLink}
|
|
80
|
-
* @see {@link Route}
|
|
81
|
-
* @ngModule RouterModule
|
|
82
|
-
*
|
|
83
|
-
* @publicApi
|
|
84
|
-
*/
|
|
85
|
-
export class RouterOutlet {
|
|
86
|
-
constructor() {
|
|
87
|
-
this.activated = null;
|
|
88
|
-
this._activatedRoute = null;
|
|
89
|
-
/**
|
|
90
|
-
* The name of the outlet
|
|
91
|
-
*
|
|
92
|
-
*/
|
|
93
|
-
this.name = PRIMARY_OUTLET;
|
|
94
|
-
this.activateEvents = new EventEmitter();
|
|
95
|
-
this.deactivateEvents = new EventEmitter();
|
|
96
|
-
/**
|
|
97
|
-
* Emits an attached component instance when the `RouteReuseStrategy` instructs to re-attach a
|
|
98
|
-
* previously detached subtree.
|
|
99
|
-
**/
|
|
100
|
-
this.attachEvents = new EventEmitter();
|
|
101
|
-
/**
|
|
102
|
-
* Emits a detached component instance when the `RouteReuseStrategy` instructs to detach the
|
|
103
|
-
* subtree.
|
|
104
|
-
*/
|
|
105
|
-
this.detachEvents = new EventEmitter();
|
|
106
|
-
/**
|
|
107
|
-
* Data that will be provided to the child injector through the `ROUTER_OUTLET_DATA` token.
|
|
108
|
-
*
|
|
109
|
-
* When unset, the value of the token is `undefined` by default.
|
|
110
|
-
*/
|
|
111
|
-
this.routerOutletData = input(undefined);
|
|
112
|
-
this.parentContexts = inject(ChildrenOutletContexts);
|
|
113
|
-
this.location = inject(ViewContainerRef);
|
|
114
|
-
this.changeDetector = inject(ChangeDetectorRef);
|
|
115
|
-
this.inputBinder = inject(INPUT_BINDER, { optional: true });
|
|
116
|
-
/** @nodoc */
|
|
117
|
-
this.supportsBindingToComponentInputs = true;
|
|
118
|
-
}
|
|
119
|
-
/** @internal */
|
|
120
|
-
get activatedComponentRef() {
|
|
121
|
-
return this.activated;
|
|
122
|
-
}
|
|
123
|
-
/** @nodoc */
|
|
124
|
-
ngOnChanges(changes) {
|
|
125
|
-
if (changes['name']) {
|
|
126
|
-
const { firstChange, previousValue } = changes['name'];
|
|
127
|
-
if (firstChange) {
|
|
128
|
-
// The first change is handled by ngOnInit. Because ngOnChanges doesn't get called when no
|
|
129
|
-
// input is set at all, we need to centrally handle the first change there.
|
|
130
|
-
return;
|
|
131
|
-
}
|
|
132
|
-
// unregister with the old name
|
|
133
|
-
if (this.isTrackedInParentContexts(previousValue)) {
|
|
134
|
-
this.deactivate();
|
|
135
|
-
this.parentContexts.onChildOutletDestroyed(previousValue);
|
|
136
|
-
}
|
|
137
|
-
// register the new name
|
|
138
|
-
this.initializeOutletWithName();
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
/** @nodoc */
|
|
142
|
-
ngOnDestroy() {
|
|
143
|
-
// Ensure that the registered outlet is this one before removing it on the context.
|
|
144
|
-
if (this.isTrackedInParentContexts(this.name)) {
|
|
145
|
-
this.parentContexts.onChildOutletDestroyed(this.name);
|
|
146
|
-
}
|
|
147
|
-
this.inputBinder?.unsubscribeFromRouteData(this);
|
|
148
|
-
}
|
|
149
|
-
isTrackedInParentContexts(outletName) {
|
|
150
|
-
return this.parentContexts.getContext(outletName)?.outlet === this;
|
|
151
|
-
}
|
|
152
|
-
/** @nodoc */
|
|
153
|
-
ngOnInit() {
|
|
154
|
-
this.initializeOutletWithName();
|
|
155
|
-
}
|
|
156
|
-
initializeOutletWithName() {
|
|
157
|
-
this.parentContexts.onChildOutletCreated(this.name, this);
|
|
158
|
-
if (this.activated) {
|
|
159
|
-
return;
|
|
160
|
-
}
|
|
161
|
-
// If the outlet was not instantiated at the time the route got activated we need to populate
|
|
162
|
-
// the outlet when it is initialized (ie inside a NgIf)
|
|
163
|
-
const context = this.parentContexts.getContext(this.name);
|
|
164
|
-
if (context?.route) {
|
|
165
|
-
if (context.attachRef) {
|
|
166
|
-
// `attachRef` is populated when there is an existing component to mount
|
|
167
|
-
this.attach(context.attachRef, context.route);
|
|
168
|
-
}
|
|
169
|
-
else {
|
|
170
|
-
// otherwise the component defined in the configuration is created
|
|
171
|
-
this.activateWith(context.route, context.injector);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
get isActivated() {
|
|
176
|
-
return !!this.activated;
|
|
177
|
-
}
|
|
178
|
-
/**
|
|
179
|
-
* @returns The currently activated component instance.
|
|
180
|
-
* @throws An error if the outlet is not activated.
|
|
181
|
-
*/
|
|
182
|
-
get component() {
|
|
183
|
-
if (!this.activated)
|
|
184
|
-
throw new RuntimeError(4012 /* RuntimeErrorCode.OUTLET_NOT_ACTIVATED */, (typeof ngDevMode === 'undefined' || ngDevMode) && 'Outlet is not activated');
|
|
185
|
-
return this.activated.instance;
|
|
186
|
-
}
|
|
187
|
-
get activatedRoute() {
|
|
188
|
-
if (!this.activated)
|
|
189
|
-
throw new RuntimeError(4012 /* RuntimeErrorCode.OUTLET_NOT_ACTIVATED */, (typeof ngDevMode === 'undefined' || ngDevMode) && 'Outlet is not activated');
|
|
190
|
-
return this._activatedRoute;
|
|
191
|
-
}
|
|
192
|
-
get activatedRouteData() {
|
|
193
|
-
if (this._activatedRoute) {
|
|
194
|
-
return this._activatedRoute.snapshot.data;
|
|
195
|
-
}
|
|
196
|
-
return {};
|
|
197
|
-
}
|
|
198
|
-
/**
|
|
199
|
-
* Called when the `RouteReuseStrategy` instructs to detach the subtree
|
|
200
|
-
*/
|
|
201
|
-
detach() {
|
|
202
|
-
if (!this.activated)
|
|
203
|
-
throw new RuntimeError(4012 /* RuntimeErrorCode.OUTLET_NOT_ACTIVATED */, (typeof ngDevMode === 'undefined' || ngDevMode) && 'Outlet is not activated');
|
|
204
|
-
this.location.detach();
|
|
205
|
-
const cmp = this.activated;
|
|
206
|
-
this.activated = null;
|
|
207
|
-
this._activatedRoute = null;
|
|
208
|
-
this.detachEvents.emit(cmp.instance);
|
|
209
|
-
return cmp;
|
|
210
|
-
}
|
|
211
|
-
/**
|
|
212
|
-
* Called when the `RouteReuseStrategy` instructs to re-attach a previously detached subtree
|
|
213
|
-
*/
|
|
214
|
-
attach(ref, activatedRoute) {
|
|
215
|
-
this.activated = ref;
|
|
216
|
-
this._activatedRoute = activatedRoute;
|
|
217
|
-
this.location.insert(ref.hostView);
|
|
218
|
-
this.inputBinder?.bindActivatedRouteToOutletComponent(this);
|
|
219
|
-
this.attachEvents.emit(ref.instance);
|
|
220
|
-
}
|
|
221
|
-
deactivate() {
|
|
222
|
-
if (this.activated) {
|
|
223
|
-
const c = this.component;
|
|
224
|
-
this.activated.destroy();
|
|
225
|
-
this.activated = null;
|
|
226
|
-
this._activatedRoute = null;
|
|
227
|
-
this.deactivateEvents.emit(c);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
activateWith(activatedRoute, environmentInjector) {
|
|
231
|
-
if (this.isActivated) {
|
|
232
|
-
throw new RuntimeError(4013 /* RuntimeErrorCode.OUTLET_ALREADY_ACTIVATED */, (typeof ngDevMode === 'undefined' || ngDevMode) &&
|
|
233
|
-
'Cannot activate an already activated outlet');
|
|
234
|
-
}
|
|
235
|
-
this._activatedRoute = activatedRoute;
|
|
236
|
-
const location = this.location;
|
|
237
|
-
const snapshot = activatedRoute.snapshot;
|
|
238
|
-
const component = snapshot.component;
|
|
239
|
-
const childContexts = this.parentContexts.getOrCreateContext(this.name).children;
|
|
240
|
-
const injector = new OutletInjector(activatedRoute, childContexts, location.injector, this.routerOutletData);
|
|
241
|
-
this.activated = location.createComponent(component, {
|
|
242
|
-
index: location.length,
|
|
243
|
-
injector,
|
|
244
|
-
environmentInjector: environmentInjector,
|
|
245
|
-
});
|
|
246
|
-
// Calling `markForCheck` to make sure we will run the change detection when the
|
|
247
|
-
// `RouterOutlet` is inside a `ChangeDetectionStrategy.OnPush` component.
|
|
248
|
-
this.changeDetector.markForCheck();
|
|
249
|
-
this.inputBinder?.bindActivatedRouteToOutletComponent(this);
|
|
250
|
-
this.activateEvents.emit(this.activated.instance);
|
|
251
|
-
}
|
|
252
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: RouterOutlet, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
253
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "19.0.0-next.1", type: RouterOutlet, isStandalone: true, selector: "router-outlet", inputs: { name: { classPropertyName: "name", publicName: "name", isSignal: false, isRequired: false, transformFunction: null }, routerOutletData: { classPropertyName: "routerOutletData", publicName: "routerOutletData", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { activateEvents: "activate", deactivateEvents: "deactivate", attachEvents: "attach", detachEvents: "detach" }, exportAs: ["outlet"], usesOnChanges: true, ngImport: i0 }); }
|
|
254
|
-
}
|
|
255
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: RouterOutlet, decorators: [{
|
|
256
|
-
type: Directive,
|
|
257
|
-
args: [{
|
|
258
|
-
selector: 'router-outlet',
|
|
259
|
-
exportAs: 'outlet',
|
|
260
|
-
standalone: true,
|
|
261
|
-
}]
|
|
262
|
-
}], propDecorators: { name: [{
|
|
263
|
-
type: Input
|
|
264
|
-
}], activateEvents: [{
|
|
265
|
-
type: Output,
|
|
266
|
-
args: ['activate']
|
|
267
|
-
}], deactivateEvents: [{
|
|
268
|
-
type: Output,
|
|
269
|
-
args: ['deactivate']
|
|
270
|
-
}], attachEvents: [{
|
|
271
|
-
type: Output,
|
|
272
|
-
args: ['attach']
|
|
273
|
-
}], detachEvents: [{
|
|
274
|
-
type: Output,
|
|
275
|
-
args: ['detach']
|
|
276
|
-
}] } });
|
|
277
|
-
class OutletInjector {
|
|
278
|
-
/**
|
|
279
|
-
* This injector has a special handing for the `ActivatedRoute` and
|
|
280
|
-
* `ChildrenOutletContexts` tokens: it returns corresponding values for those
|
|
281
|
-
* tokens dynamically. This behavior is different from the regular injector logic,
|
|
282
|
-
* when we initialize and store a value, which is later returned for all inject
|
|
283
|
-
* requests.
|
|
284
|
-
*
|
|
285
|
-
* In some cases (e.g. when using `@defer`), this dynamic behavior requires special
|
|
286
|
-
* handling. This function allows to identify an instance of the `OutletInjector` and
|
|
287
|
-
* create an instance of it without referring to the class itself (so this logic can
|
|
288
|
-
* be invoked from the `core` package). This helps to retain dynamic behavior for the
|
|
289
|
-
* mentioned tokens.
|
|
290
|
-
*
|
|
291
|
-
* Note: it's a temporary solution and we should explore how to support this case better.
|
|
292
|
-
*/
|
|
293
|
-
__ngOutletInjector(parentInjector) {
|
|
294
|
-
return new OutletInjector(this.route, this.childContexts, parentInjector, this.outletData);
|
|
295
|
-
}
|
|
296
|
-
constructor(route, childContexts, parent, outletData) {
|
|
297
|
-
this.route = route;
|
|
298
|
-
this.childContexts = childContexts;
|
|
299
|
-
this.parent = parent;
|
|
300
|
-
this.outletData = outletData;
|
|
301
|
-
}
|
|
302
|
-
get(token, notFoundValue) {
|
|
303
|
-
if (token === ActivatedRoute) {
|
|
304
|
-
return this.route;
|
|
305
|
-
}
|
|
306
|
-
if (token === ChildrenOutletContexts) {
|
|
307
|
-
return this.childContexts;
|
|
308
|
-
}
|
|
309
|
-
if (token === ROUTER_OUTLET_DATA) {
|
|
310
|
-
return this.outletData;
|
|
311
|
-
}
|
|
312
|
-
return this.parent.get(token, notFoundValue);
|
|
313
|
-
}
|
|
314
|
-
}
|
|
315
|
-
export const INPUT_BINDER = new InjectionToken('');
|
|
316
|
-
/**
|
|
317
|
-
* Injectable used as a tree-shakable provider for opting in to binding router data to component
|
|
318
|
-
* inputs.
|
|
319
|
-
*
|
|
320
|
-
* The RouterOutlet registers itself with this service when an `ActivatedRoute` is attached or
|
|
321
|
-
* activated. When this happens, the service subscribes to the `ActivatedRoute` observables (params,
|
|
322
|
-
* queryParams, data) and sets the inputs of the component using `ComponentRef.setInput`.
|
|
323
|
-
* Importantly, when an input does not have an item in the route data with a matching key, this
|
|
324
|
-
* input is set to `undefined`. If it were not done this way, the previous information would be
|
|
325
|
-
* retained if the data got removed from the route (i.e. if a query parameter is removed).
|
|
326
|
-
*
|
|
327
|
-
* The `RouterOutlet` should unregister itself when destroyed via `unsubscribeFromRouteData` so that
|
|
328
|
-
* the subscriptions are cleaned up.
|
|
329
|
-
*/
|
|
330
|
-
export class RoutedComponentInputBinder {
|
|
331
|
-
constructor() {
|
|
332
|
-
this.outletDataSubscriptions = new Map();
|
|
333
|
-
}
|
|
334
|
-
bindActivatedRouteToOutletComponent(outlet) {
|
|
335
|
-
this.unsubscribeFromRouteData(outlet);
|
|
336
|
-
this.subscribeToRouteData(outlet);
|
|
337
|
-
}
|
|
338
|
-
unsubscribeFromRouteData(outlet) {
|
|
339
|
-
this.outletDataSubscriptions.get(outlet)?.unsubscribe();
|
|
340
|
-
this.outletDataSubscriptions.delete(outlet);
|
|
341
|
-
}
|
|
342
|
-
subscribeToRouteData(outlet) {
|
|
343
|
-
const { activatedRoute } = outlet;
|
|
344
|
-
const dataSubscription = combineLatest([
|
|
345
|
-
activatedRoute.queryParams,
|
|
346
|
-
activatedRoute.params,
|
|
347
|
-
activatedRoute.data,
|
|
348
|
-
])
|
|
349
|
-
.pipe(switchMap(([queryParams, params, data], index) => {
|
|
350
|
-
data = { ...queryParams, ...params, ...data };
|
|
351
|
-
// Get the first result from the data subscription synchronously so it's available to
|
|
352
|
-
// the component as soon as possible (and doesn't require a second change detection).
|
|
353
|
-
if (index === 0) {
|
|
354
|
-
return of(data);
|
|
355
|
-
}
|
|
356
|
-
// Promise.resolve is used to avoid synchronously writing the wrong data when
|
|
357
|
-
// two of the Observables in the `combineLatest` stream emit one after
|
|
358
|
-
// another.
|
|
359
|
-
return Promise.resolve(data);
|
|
360
|
-
}))
|
|
361
|
-
.subscribe((data) => {
|
|
362
|
-
// Outlet may have been deactivated or changed names to be associated with a different
|
|
363
|
-
// route
|
|
364
|
-
if (!outlet.isActivated ||
|
|
365
|
-
!outlet.activatedComponentRef ||
|
|
366
|
-
outlet.activatedRoute !== activatedRoute ||
|
|
367
|
-
activatedRoute.component === null) {
|
|
368
|
-
this.unsubscribeFromRouteData(outlet);
|
|
369
|
-
return;
|
|
370
|
-
}
|
|
371
|
-
const mirror = reflectComponentType(activatedRoute.component);
|
|
372
|
-
if (!mirror) {
|
|
373
|
-
this.unsubscribeFromRouteData(outlet);
|
|
374
|
-
return;
|
|
375
|
-
}
|
|
376
|
-
for (const { templateName } of mirror.inputs) {
|
|
377
|
-
outlet.activatedComponentRef.setInput(templateName, data[templateName]);
|
|
378
|
-
}
|
|
379
|
-
});
|
|
380
|
-
this.outletDataSubscriptions.set(outlet, dataSubscription);
|
|
381
|
-
}
|
|
382
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: RoutedComponentInputBinder, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
383
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: RoutedComponentInputBinder }); }
|
|
384
|
-
}
|
|
385
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: RoutedComponentInputBinder, decorators: [{
|
|
386
|
-
type: Injectable
|
|
387
|
-
}] });
|
|
388
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_outlet.js","sourceRoot":"","sources":["../../../../../../../packages/router/src/directives/router_outlet.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 {\n  ChangeDetectorRef,\n  ComponentRef,\n  Directive,\n  EnvironmentInjector,\n  EventEmitter,\n  inject,\n  Injectable,\n  InjectionToken,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  reflectComponentType,\n  SimpleChanges,\n  ViewContainerRef,\n  ɵRuntimeError as RuntimeError,\n  Signal,\n  input,\n  computed,\n} from '@angular/core';\nimport {combineLatest, of, Subscription} from 'rxjs';\nimport {switchMap} from 'rxjs/operators';\n\nimport {RuntimeErrorCode} from '../errors';\nimport {Data} from '../models';\nimport {ChildrenOutletContexts} from '../router_outlet_context';\nimport {ActivatedRoute} from '../router_state';\nimport {PRIMARY_OUTLET} from '../shared';\n\n/**\n * An `InjectionToken` provided by the `RouterOutlet` and can be set using the `routerOutletData`\n * input.\n *\n * When unset, this value is `null` by default.\n *\n * @usageNotes\n *\n * To set the data from the template of the component with `router-outlet`:\n * ```\n * <router-outlet [routerOutletData]=\"{name: 'Angular'}\" />\n * ```\n *\n * To read the data in the routed component:\n * ```\n * data = inject(ROUTER_OUTLET_DATA) as Signal<{name: string}>;\n * ```\n *\n * @publicApi\n */\nexport const ROUTER_OUTLET_DATA = new InjectionToken<Signal<unknown | undefined>>(\n  ngDevMode ? 'RouterOutlet data' : '',\n);\n\n/**\n * An interface that defines the contract for developing a component outlet for the `Router`.\n *\n * An outlet acts as a placeholder that Angular dynamically fills based on the current router state.\n *\n * A router outlet should register itself with the `Router` via\n * `ChildrenOutletContexts#onChildOutletCreated` and unregister with\n * `ChildrenOutletContexts#onChildOutletDestroyed`. When the `Router` identifies a matched `Route`,\n * it looks for a registered outlet in the `ChildrenOutletContexts` and activates it.\n *\n * @see {@link ChildrenOutletContexts}\n * @publicApi\n */\nexport interface RouterOutletContract {\n  /**\n   * Whether the given outlet is activated.\n   *\n   * An outlet is considered \"activated\" if it has an active component.\n   */\n  isActivated: boolean;\n\n  /** The instance of the activated component or `null` if the outlet is not activated. */\n  component: Object | null;\n\n  /**\n   * The `Data` of the `ActivatedRoute` snapshot.\n   */\n  activatedRouteData: Data;\n\n  /**\n   * The `ActivatedRoute` for the outlet or `null` if the outlet is not activated.\n   */\n  activatedRoute: ActivatedRoute | null;\n\n  /**\n   * Called by the `Router` when the outlet should activate (create a component).\n   */\n  activateWith(activatedRoute: ActivatedRoute, environmentInjector: EnvironmentInjector): void;\n\n  /**\n   * A request to destroy the currently activated component.\n   *\n   * When a `RouteReuseStrategy` indicates that an `ActivatedRoute` should be removed but stored for\n   * later re-use rather than destroyed, the `Router` will call `detach` instead.\n   */\n  deactivate(): void;\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to detach the subtree.\n   *\n   * This is similar to `deactivate`, but the activated component should _not_ be destroyed.\n   * Instead, it is returned so that it can be reattached later via the `attach` method.\n   */\n  detach(): ComponentRef<unknown>;\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to re-attach a previously detached subtree.\n   */\n  attach(ref: ComponentRef<unknown>, activatedRoute: ActivatedRoute): void;\n\n  /**\n   * Emits an activate event when a new component is instantiated\n   **/\n  activateEvents?: EventEmitter<unknown>;\n\n  /**\n   * Emits a deactivate event when a component is destroyed.\n   */\n  deactivateEvents?: EventEmitter<unknown>;\n\n  /**\n   * Emits an attached component instance when the `RouteReuseStrategy` instructs to re-attach a\n   * previously detached subtree.\n   **/\n  attachEvents?: EventEmitter<unknown>;\n\n  /**\n   * Emits a detached component instance when the `RouteReuseStrategy` instructs to detach the\n   * subtree.\n   */\n  detachEvents?: EventEmitter<unknown>;\n\n  /**\n   * Used to indicate that the outlet is able to bind data from the `Router` to the outlet\n   * component's inputs.\n   *\n   * When this is `undefined` or `false` and the developer has opted in to the\n   * feature using `withComponentInputBinding`, a warning will be logged in dev mode if this outlet\n   * is used in the application.\n   */\n  readonly supportsBindingToComponentInputs?: true;\n}\n\n/**\n * @description\n *\n * Acts as a placeholder that Angular dynamically fills based on the current router state.\n *\n * Each outlet can have a unique name, determined by the optional `name` attribute.\n * The name cannot be set or changed dynamically. If not set, default value is \"primary\".\n *\n * ```\n * <router-outlet></router-outlet>\n * <router-outlet name='left'></router-outlet>\n * <router-outlet name='right'></router-outlet>\n * ```\n *\n * Named outlets can be the targets of secondary routes.\n * The `Route` object for a secondary route has an `outlet` property to identify the target outlet:\n *\n * `{path: <base-path>, component: <component>, outlet: <target_outlet_name>}`\n *\n * Using named outlets and secondary routes, you can target multiple outlets in\n * the same `RouterLink` directive.\n *\n * The router keeps track of separate branches in a navigation tree for each named outlet and\n * generates a representation of that tree in the URL.\n * The URL for a secondary route uses the following syntax to specify both the primary and secondary\n * routes at the same time:\n *\n * `http://base-path/primary-route-path(outlet-name:route-path)`\n *\n * A router outlet emits an activate event when a new component is instantiated,\n * deactivate event when a component is destroyed.\n * An attached event emits when the `RouteReuseStrategy` instructs the outlet to reattach the\n * subtree, and the detached event emits when the `RouteReuseStrategy` instructs the outlet to\n * detach the subtree.\n *\n * ```\n * <router-outlet\n *   (activate)='onActivate($event)'\n *   (deactivate)='onDeactivate($event)'\n *   (attach)='onAttach($event)'\n *   (detach)='onDetach($event)'></router-outlet>\n * ```\n *\n * @see {@link RouterLink}\n * @see {@link Route}\n * @ngModule RouterModule\n *\n * @publicApi\n */\n@Directive({\n  selector: 'router-outlet',\n  exportAs: 'outlet',\n  standalone: true,\n})\nexport class RouterOutlet implements OnDestroy, OnInit, RouterOutletContract {\n  private activated: ComponentRef<any> | null = null;\n  /** @internal */\n  get activatedComponentRef(): ComponentRef<any> | null {\n    return this.activated;\n  }\n  private _activatedRoute: ActivatedRoute | null = null;\n  /**\n   * The name of the outlet\n   *\n   */\n  @Input() name = PRIMARY_OUTLET;\n\n  @Output('activate') activateEvents = new EventEmitter<any>();\n  @Output('deactivate') deactivateEvents = new EventEmitter<any>();\n  /**\n   * Emits an attached component instance when the `RouteReuseStrategy` instructs to re-attach a\n   * previously detached subtree.\n   **/\n  @Output('attach') attachEvents = new EventEmitter<unknown>();\n  /**\n   * Emits a detached component instance when the `RouteReuseStrategy` instructs to detach the\n   * subtree.\n   */\n  @Output('detach') detachEvents = new EventEmitter<unknown>();\n\n  /**\n   * Data that will be provided to the child injector through the `ROUTER_OUTLET_DATA` token.\n   *\n   * When unset, the value of the token is `undefined` by default.\n   */\n  readonly routerOutletData = input<unknown>(undefined);\n\n  private parentContexts = inject(ChildrenOutletContexts);\n  private location = inject(ViewContainerRef);\n  private changeDetector = inject(ChangeDetectorRef);\n  private inputBinder = inject(INPUT_BINDER, {optional: true});\n  /** @nodoc */\n  readonly supportsBindingToComponentInputs = true;\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['name']) {\n      const {firstChange, previousValue} = changes['name'];\n      if (firstChange) {\n        // The first change is handled by ngOnInit. Because ngOnChanges doesn't get called when no\n        // input is set at all, we need to centrally handle the first change there.\n        return;\n      }\n\n      // unregister with the old name\n      if (this.isTrackedInParentContexts(previousValue)) {\n        this.deactivate();\n        this.parentContexts.onChildOutletDestroyed(previousValue);\n      }\n      // register the new name\n      this.initializeOutletWithName();\n    }\n  }\n\n  /** @nodoc */\n  ngOnDestroy(): void {\n    // Ensure that the registered outlet is this one before removing it on the context.\n    if (this.isTrackedInParentContexts(this.name)) {\n      this.parentContexts.onChildOutletDestroyed(this.name);\n    }\n    this.inputBinder?.unsubscribeFromRouteData(this);\n  }\n\n  private isTrackedInParentContexts(outletName: string) {\n    return this.parentContexts.getContext(outletName)?.outlet === this;\n  }\n\n  /** @nodoc */\n  ngOnInit(): void {\n    this.initializeOutletWithName();\n  }\n\n  private initializeOutletWithName() {\n    this.parentContexts.onChildOutletCreated(this.name, this);\n    if (this.activated) {\n      return;\n    }\n\n    // If the outlet was not instantiated at the time the route got activated we need to populate\n    // the outlet when it is initialized (ie inside a NgIf)\n    const context = this.parentContexts.getContext(this.name);\n    if (context?.route) {\n      if (context.attachRef) {\n        // `attachRef` is populated when there is an existing component to mount\n        this.attach(context.attachRef, context.route);\n      } else {\n        // otherwise the component defined in the configuration is created\n        this.activateWith(context.route, context.injector);\n      }\n    }\n  }\n\n  get isActivated(): boolean {\n    return !!this.activated;\n  }\n\n  /**\n   * @returns The currently activated component instance.\n   * @throws An error if the outlet is not activated.\n   */\n  get component(): Object {\n    if (!this.activated)\n      throw new RuntimeError(\n        RuntimeErrorCode.OUTLET_NOT_ACTIVATED,\n        (typeof ngDevMode === 'undefined' || ngDevMode) && 'Outlet is not activated',\n      );\n    return this.activated.instance;\n  }\n\n  get activatedRoute(): ActivatedRoute {\n    if (!this.activated)\n      throw new RuntimeError(\n        RuntimeErrorCode.OUTLET_NOT_ACTIVATED,\n        (typeof ngDevMode === 'undefined' || ngDevMode) && 'Outlet is not activated',\n      );\n    return this._activatedRoute as ActivatedRoute;\n  }\n\n  get activatedRouteData(): Data {\n    if (this._activatedRoute) {\n      return this._activatedRoute.snapshot.data;\n    }\n    return {};\n  }\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to detach the subtree\n   */\n  detach(): ComponentRef<any> {\n    if (!this.activated)\n      throw new RuntimeError(\n        RuntimeErrorCode.OUTLET_NOT_ACTIVATED,\n        (typeof ngDevMode === 'undefined' || ngDevMode) && 'Outlet is not activated',\n      );\n    this.location.detach();\n    const cmp = this.activated;\n    this.activated = null;\n    this._activatedRoute = null;\n    this.detachEvents.emit(cmp.instance);\n    return cmp;\n  }\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to re-attach a previously detached subtree\n   */\n  attach(ref: ComponentRef<any>, activatedRoute: ActivatedRoute) {\n    this.activated = ref;\n    this._activatedRoute = activatedRoute;\n    this.location.insert(ref.hostView);\n    this.inputBinder?.bindActivatedRouteToOutletComponent(this);\n    this.attachEvents.emit(ref.instance);\n  }\n\n  deactivate(): void {\n    if (this.activated) {\n      const c = this.component;\n      this.activated.destroy();\n      this.activated = null;\n      this._activatedRoute = null;\n      this.deactivateEvents.emit(c);\n    }\n  }\n\n  activateWith(activatedRoute: ActivatedRoute, environmentInjector: EnvironmentInjector) {\n    if (this.isActivated) {\n      throw new RuntimeError(\n        RuntimeErrorCode.OUTLET_ALREADY_ACTIVATED,\n        (typeof ngDevMode === 'undefined' || ngDevMode) &&\n          'Cannot activate an already activated outlet',\n      );\n    }\n    this._activatedRoute = activatedRoute;\n    const location = this.location;\n    const snapshot = activatedRoute.snapshot;\n    const component = snapshot.component!;\n    const childContexts = this.parentContexts.getOrCreateContext(this.name).children;\n    const injector = new OutletInjector(\n      activatedRoute,\n      childContexts,\n      location.injector,\n      this.routerOutletData,\n    );\n\n    this.activated = location.createComponent(component, {\n      index: location.length,\n      injector,\n      environmentInjector: environmentInjector,\n    });\n    // Calling `markForCheck` to make sure we will run the change detection when the\n    // `RouterOutlet` is inside a `ChangeDetectionStrategy.OnPush` component.\n    this.changeDetector.markForCheck();\n    this.inputBinder?.bindActivatedRouteToOutletComponent(this);\n    this.activateEvents.emit(this.activated.instance);\n  }\n}\n\nclass OutletInjector implements Injector {\n  /**\n   * This injector has a special handing for the `ActivatedRoute` and\n   * `ChildrenOutletContexts` tokens: it returns corresponding values for those\n   * tokens dynamically. This behavior is different from the regular injector logic,\n   * when we initialize and store a value, which is later returned for all inject\n   * requests.\n   *\n   * In some cases (e.g. when using `@defer`), this dynamic behavior requires special\n   * handling. This function allows to identify an instance of the `OutletInjector` and\n   * create an instance of it without referring to the class itself (so this logic can\n   * be invoked from the `core` package). This helps to retain dynamic behavior for the\n   * mentioned tokens.\n   *\n   * Note: it's a temporary solution and we should explore how to support this case better.\n   */\n  private __ngOutletInjector(parentInjector: Injector) {\n    return new OutletInjector(this.route, this.childContexts, parentInjector, this.outletData);\n  }\n\n  constructor(\n    private route: ActivatedRoute,\n    private childContexts: ChildrenOutletContexts,\n    private parent: Injector,\n    private outletData: Signal<unknown>,\n  ) {}\n\n  get(token: any, notFoundValue?: any): any {\n    if (token === ActivatedRoute) {\n      return this.route;\n    }\n\n    if (token === ChildrenOutletContexts) {\n      return this.childContexts;\n    }\n\n    if (token === ROUTER_OUTLET_DATA) {\n      return this.outletData;\n    }\n\n    return this.parent.get(token, notFoundValue);\n  }\n}\n\nexport const INPUT_BINDER = new InjectionToken<RoutedComponentInputBinder>('');\n\n/**\n * Injectable used as a tree-shakable provider for opting in to binding router data to component\n * inputs.\n *\n * The RouterOutlet registers itself with this service when an `ActivatedRoute` is attached or\n * activated. When this happens, the service subscribes to the `ActivatedRoute` observables (params,\n * queryParams, data) and sets the inputs of the component using `ComponentRef.setInput`.\n * Importantly, when an input does not have an item in the route data with a matching key, this\n * input is set to `undefined`. If it were not done this way, the previous information would be\n * retained if the data got removed from the route (i.e. if a query parameter is removed).\n *\n * The `RouterOutlet` should unregister itself when destroyed via `unsubscribeFromRouteData` so that\n * the subscriptions are cleaned up.\n */\n@Injectable()\nexport class RoutedComponentInputBinder {\n  private outletDataSubscriptions = new Map<RouterOutlet, Subscription>();\n\n  bindActivatedRouteToOutletComponent(outlet: RouterOutlet) {\n    this.unsubscribeFromRouteData(outlet);\n    this.subscribeToRouteData(outlet);\n  }\n\n  unsubscribeFromRouteData(outlet: RouterOutlet) {\n    this.outletDataSubscriptions.get(outlet)?.unsubscribe();\n    this.outletDataSubscriptions.delete(outlet);\n  }\n\n  private subscribeToRouteData(outlet: RouterOutlet) {\n    const {activatedRoute} = outlet;\n    const dataSubscription = combineLatest([\n      activatedRoute.queryParams,\n      activatedRoute.params,\n      activatedRoute.data,\n    ])\n      .pipe(\n        switchMap(([queryParams, params, data], index) => {\n          data = {...queryParams, ...params, ...data};\n          // Get the first result from the data subscription synchronously so it's available to\n          // the component as soon as possible (and doesn't require a second change detection).\n          if (index === 0) {\n            return of(data);\n          }\n          // Promise.resolve is used to avoid synchronously writing the wrong data when\n          // two of the Observables in the `combineLatest` stream emit one after\n          // another.\n          return Promise.resolve(data);\n        }),\n      )\n      .subscribe((data) => {\n        // Outlet may have been deactivated or changed names to be associated with a different\n        // route\n        if (\n          !outlet.isActivated ||\n          !outlet.activatedComponentRef ||\n          outlet.activatedRoute !== activatedRoute ||\n          activatedRoute.component === null\n        ) {\n          this.unsubscribeFromRouteData(outlet);\n          return;\n        }\n\n        const mirror = reflectComponentType(activatedRoute.component);\n        if (!mirror) {\n          this.unsubscribeFromRouteData(outlet);\n          return;\n        }\n\n        for (const {templateName} of mirror.inputs) {\n          outlet.activatedComponentRef.setInput(templateName, data[templateName]);\n        }\n      });\n\n    this.outletDataSubscriptions.set(outlet, dataSubscription);\n  }\n}\n"]}
|
package/esm2022/src/errors.mjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcm91dGVyL3NyYy9lcnJvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuLyoqXG4gKiBUaGUgbGlzdCBvZiBlcnJvciBjb2RlcyB1c2VkIGluIHJ1bnRpbWUgY29kZSBvZiB0aGUgYHJvdXRlcmAgcGFja2FnZS5cbiAqIFJlc2VydmVkIGVycm9yIGNvZGUgcmFuZ2U6IDQwMDAtNDk5OS5cbiAqL1xuZXhwb3J0IGNvbnN0IGVudW0gUnVudGltZUVycm9yQ29kZSB7XG4gIE5BTUVEX09VVExFVF9SRURJUkVDVCA9IDQwMDAsXG4gIE1JU1NJTkdfUkVESVJFQ1QgPSA0MDAxLFxuICBOT19NQVRDSCA9IDQwMDIsXG4gIFJPT1RfU0VHTUVOVF9NQVRSSVhfUEFSQU1TID0gNDAwMyxcbiAgTUlTUExBQ0VEX09VVExFVFNfQ09NTUFORCA9IDQwMDQsXG4gIElOVkFMSURfRE9VQkxFX0RPVFMgPSA0MDA1LFxuICBUV09fU0VHTUVOVFNfV0lUSF9TQU1FX09VVExFVCA9IDQwMDYsXG4gIEZPUl9ST09UX0NBTExFRF9UV0lDRSA9IDQwMDcsXG4gIE5VTExJU0hfQ09NTUFORCA9IDQwMDgsXG4gIEVNUFRZX1BBVEhfV0lUSF9QQVJBTVMgPSA0MDA5LFxuICBVTlBBUlNBQkxFX1VSTCA9IDQwMTAsXG4gIFVORVhQRUNURURfVkFMVUVfSU5fVVJMID0gNDAxMSxcbiAgT1VUTEVUX05PVF9BQ1RJVkFURUQgPSA0MDEyLFxuICBPVVRMRVRfQUxSRUFEWV9BQ1RJVkFURUQgPSA0MDEzLFxuICBJTlZBTElEX1JPVVRFX0NPTkZJRyA9IDQwMTQsXG4gIElOVkFMSURfUk9PVF9VUkxfU0VHTUVOVCA9IDQwMTUsXG4gIElORklOSVRFX1JFRElSRUNUID0gNDAxNixcbiAgSU5WQUxJRF9ST1VURVJfTElOS19JTlBVVFMgPSA0MDE2LFxufVxuIl19
|