@angular/router 6.0.3 → 6.0.7
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/bundles/router-testing.umd.js +21 -15
- package/bundles/router-testing.umd.js.map +1 -1
- package/bundles/router-testing.umd.min.js +2 -2
- package/bundles/router-testing.umd.min.js.map +1 -1
- package/bundles/router-upgrade.umd.js +10 -1
- package/bundles/router-upgrade.umd.js.map +1 -1
- package/bundles/router-upgrade.umd.min.js +1 -1
- package/bundles/router-upgrade.umd.min.js.map +1 -1
- package/bundles/router.umd.js +348 -706
- package/bundles/router.umd.js.map +1 -1
- package/bundles/router.umd.min.js +18 -18
- package/bundles/router.umd.min.js.map +1 -1
- package/esm2015/index.js +2 -2
- package/esm2015/public_api.js +2 -2
- package/esm2015/src/components/empty_outlet.js +28 -0
- package/esm2015/src/config.js +13 -6
- package/esm2015/src/directives/router_link.js +29 -47
- package/esm2015/src/directives/router_link_active.js +9 -18
- package/esm2015/src/directives/router_outlet.js +8 -17
- package/esm2015/src/index.js +2 -2
- package/esm2015/src/private_export.js +2 -1
- package/esm2015/src/router.js +4 -4
- package/esm2015/src/router_config_loader.js +3 -3
- package/esm2015/src/router_module.js +11 -22
- package/esm2015/src/router_preloader.js +6 -13
- package/esm2015/src/version.js +1 -1
- package/esm2015/testing/src/router_testing_module.js +2 -20
- package/esm5/index.js +5 -1
- package/esm5/public_api.js +6 -1
- package/esm5/src/apply_redirects.js +14 -26
- package/esm5/src/components/empty_outlet.js +28 -0
- package/esm5/src/config.js +15 -6
- package/esm5/src/create_router_state.js +1 -1
- package/esm5/src/create_url_tree.js +2 -4
- package/esm5/src/directives/router_link.js +33 -33
- package/esm5/src/directives/router_link_active.js +9 -9
- package/esm5/src/directives/router_outlet.js +10 -22
- package/esm5/src/events.js +86 -340
- package/esm5/src/index.js +1 -1
- package/esm5/src/interfaces.js +1 -1
- package/esm5/src/pre_activation.js +12 -68
- package/esm5/src/private_export.js +2 -1
- package/esm5/src/recognize.js +5 -5
- package/esm5/src/route_reuse_strategy.js +3 -23
- package/esm5/src/router.js +49 -311
- package/esm5/src/router_config_loader.js +5 -4
- package/esm5/src/router_module.js +15 -44
- package/esm5/src/router_outlet_context.js +6 -46
- package/esm5/src/router_preloader.js +10 -71
- package/esm5/src/router_state.js +49 -231
- package/esm5/src/shared.js +1 -1
- package/esm5/src/url_handling_strategy.js +3 -23
- package/esm5/src/url_tree.js +33 -239
- package/esm5/src/utils/collection.js +1 -1
- package/esm5/src/utils/tree.js +6 -36
- package/esm5/src/version.js +7 -2
- package/esm5/testing/index.js +5 -1
- package/esm5/testing/public_api.js +6 -1
- package/esm5/testing/src/router_testing_module.js +7 -15
- package/esm5/testing/src/testing.js +6 -1
- package/esm5/upgrade/index.js +5 -1
- package/esm5/upgrade/public_api.js +6 -1
- package/esm5/upgrade/src/upgrade.js +1 -1
- package/fesm2015/router.js +100 -64
- package/fesm2015/router.js.map +1 -1
- package/fesm2015/testing.js +2 -4
- package/fesm2015/testing.js.map +1 -1
- package/fesm2015/upgrade.js +1 -1
- package/fesm2015/upgrade.js.map +1 -1
- package/fesm5/router.js +349 -708
- package/fesm5/router.js.map +1 -1
- package/fesm5/testing.js +21 -15
- package/fesm5/testing.js.map +1 -1
- package/fesm5/upgrade.js +10 -1
- package/fesm5/upgrade.js.map +1 -1
- package/package.json +4 -4
- package/router.metadata.json +1 -1
- package/src/components/empty_outlet.d.ts +11 -0
- package/src/config.d.ts +4 -1
- package/src/private_export.d.ts +1 -0
- package/testing.d.ts +0 -5
- package/testing.metadata.json +1 -1
- package/upgrade.d.ts +0 -5
- package/upgrade.metadata.json +1 -1
package/esm5/src/router_state.js
CHANGED
|
@@ -39,37 +39,11 @@ import { Tree, TreeNode } from './utils/tree';
|
|
|
39
39
|
*
|
|
40
40
|
*
|
|
41
41
|
*/
|
|
42
|
-
var /**
|
|
43
|
-
* @description
|
|
44
|
-
*
|
|
45
|
-
* Represents the state of the router.
|
|
46
|
-
*
|
|
47
|
-
* RouterState is a tree of activated routes. Every node in this tree knows about the "consumed" URL
|
|
48
|
-
* segments, the extracted parameters, and the resolved data.
|
|
49
|
-
*
|
|
50
|
-
* ### Example
|
|
51
|
-
*
|
|
52
|
-
* ```
|
|
53
|
-
* @Component({templateUrl:'template.html'})
|
|
54
|
-
* class MyComponent {
|
|
55
|
-
* constructor(router: Router) {
|
|
56
|
-
* const state: RouterState = router.routerState;
|
|
57
|
-
* const root: ActivatedRoute = state.root;
|
|
58
|
-
* const child = root.firstChild;
|
|
59
|
-
* const id: Observable<string> = child.params.map(p => p.id);
|
|
60
|
-
* //...
|
|
61
|
-
* }
|
|
62
|
-
* }
|
|
63
|
-
* ```
|
|
64
|
-
*
|
|
65
|
-
* See `ActivatedRoute` for more information.
|
|
66
|
-
*
|
|
67
|
-
*
|
|
68
|
-
*/
|
|
69
|
-
RouterState = /** @class */ (function (_super) {
|
|
42
|
+
var RouterState = /** @class */ (function (_super) {
|
|
70
43
|
tslib_1.__extends(RouterState, _super);
|
|
71
44
|
/** @internal */
|
|
72
|
-
function RouterState(root,
|
|
45
|
+
function RouterState(root,
|
|
46
|
+
/** The current snapshot of the router state */
|
|
73
47
|
snapshot) {
|
|
74
48
|
var _this = _super.call(this, root) || this;
|
|
75
49
|
_this.snapshot = snapshot;
|
|
@@ -79,33 +53,6 @@ RouterState = /** @class */ (function (_super) {
|
|
|
79
53
|
RouterState.prototype.toString = function () { return this.snapshot.toString(); };
|
|
80
54
|
return RouterState;
|
|
81
55
|
}(Tree));
|
|
82
|
-
/**
|
|
83
|
-
* @description
|
|
84
|
-
*
|
|
85
|
-
* Represents the state of the router.
|
|
86
|
-
*
|
|
87
|
-
* RouterState is a tree of activated routes. Every node in this tree knows about the "consumed" URL
|
|
88
|
-
* segments, the extracted parameters, and the resolved data.
|
|
89
|
-
*
|
|
90
|
-
* ### Example
|
|
91
|
-
*
|
|
92
|
-
* ```
|
|
93
|
-
* @Component({templateUrl:'template.html'})
|
|
94
|
-
* class MyComponent {
|
|
95
|
-
* constructor(router: Router) {
|
|
96
|
-
* const state: RouterState = router.routerState;
|
|
97
|
-
* const root: ActivatedRoute = state.root;
|
|
98
|
-
* const child = root.firstChild;
|
|
99
|
-
* const id: Observable<string> = child.params.map(p => p.id);
|
|
100
|
-
* //...
|
|
101
|
-
* }
|
|
102
|
-
* }
|
|
103
|
-
* ```
|
|
104
|
-
*
|
|
105
|
-
* See `ActivatedRoute` for more information.
|
|
106
|
-
*
|
|
107
|
-
*
|
|
108
|
-
*/
|
|
109
56
|
export { RouterState };
|
|
110
57
|
export function createEmptyState(urlTree, rootComponent) {
|
|
111
58
|
var snapshot = createEmptyStateSnapshot(urlTree, rootComponent);
|
|
@@ -146,35 +93,22 @@ export function createEmptyStateSnapshot(urlTree, rootComponent) {
|
|
|
146
93
|
*
|
|
147
94
|
*
|
|
148
95
|
*/
|
|
149
|
-
var /**
|
|
150
|
-
* @description
|
|
151
|
-
*
|
|
152
|
-
* Contains the information about a route associated with a component loaded in an
|
|
153
|
-
* outlet. An `ActivatedRoute` can also be used to traverse the router state tree.
|
|
154
|
-
*
|
|
155
|
-
* ```
|
|
156
|
-
* @Component({...})
|
|
157
|
-
* class MyComponent {
|
|
158
|
-
* constructor(route: ActivatedRoute) {
|
|
159
|
-
* const id: Observable<string> = route.params.map(p => p.id);
|
|
160
|
-
* const url: Observable<string> = route.url.map(segments => segments.join(''));
|
|
161
|
-
* // route.data includes both `data` and `resolve`
|
|
162
|
-
* const user = route.data.map(d => d.user);
|
|
163
|
-
* }
|
|
164
|
-
* }
|
|
165
|
-
* ```
|
|
166
|
-
*
|
|
167
|
-
*
|
|
168
|
-
*/
|
|
169
|
-
ActivatedRoute = /** @class */ (function () {
|
|
96
|
+
var ActivatedRoute = /** @class */ (function () {
|
|
170
97
|
/** @internal */
|
|
171
|
-
function ActivatedRoute(
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
98
|
+
function ActivatedRoute(
|
|
99
|
+
/** An observable of the URL segments matched by this route */
|
|
100
|
+
url,
|
|
101
|
+
/** An observable of the matrix parameters scoped to this route */
|
|
102
|
+
params,
|
|
103
|
+
/** An observable of the query parameters shared by all the routes */
|
|
104
|
+
queryParams,
|
|
105
|
+
/** An observable of the URL fragment shared by all the routes */
|
|
106
|
+
fragment,
|
|
107
|
+
/** An observable of the static and resolved data of this route. */
|
|
108
|
+
data,
|
|
109
|
+
/** The outlet name of the route. It's a constant */
|
|
110
|
+
outlet,
|
|
111
|
+
/** The component of the route. It's a constant */
|
|
178
112
|
// TODO(vsavkin): remove |string
|
|
179
113
|
component, futureSnapshot) {
|
|
180
114
|
this.url = url;
|
|
@@ -188,43 +122,37 @@ ActivatedRoute = /** @class */ (function () {
|
|
|
188
122
|
}
|
|
189
123
|
Object.defineProperty(ActivatedRoute.prototype, "routeConfig", {
|
|
190
124
|
/** The configuration used to match this route */
|
|
191
|
-
get:
|
|
192
|
-
function () { return this._futureSnapshot.routeConfig; },
|
|
125
|
+
get: function () { return this._futureSnapshot.routeConfig; },
|
|
193
126
|
enumerable: true,
|
|
194
127
|
configurable: true
|
|
195
128
|
});
|
|
196
129
|
Object.defineProperty(ActivatedRoute.prototype, "root", {
|
|
197
130
|
/** The root of the router state */
|
|
198
|
-
get:
|
|
199
|
-
function () { return this._routerState.root; },
|
|
131
|
+
get: function () { return this._routerState.root; },
|
|
200
132
|
enumerable: true,
|
|
201
133
|
configurable: true
|
|
202
134
|
});
|
|
203
135
|
Object.defineProperty(ActivatedRoute.prototype, "parent", {
|
|
204
136
|
/** The parent of this route in the router state tree */
|
|
205
|
-
get:
|
|
206
|
-
function () { return this._routerState.parent(this); },
|
|
137
|
+
get: function () { return this._routerState.parent(this); },
|
|
207
138
|
enumerable: true,
|
|
208
139
|
configurable: true
|
|
209
140
|
});
|
|
210
141
|
Object.defineProperty(ActivatedRoute.prototype, "firstChild", {
|
|
211
142
|
/** The first child of this route in the router state tree */
|
|
212
|
-
get:
|
|
213
|
-
function () { return this._routerState.firstChild(this); },
|
|
143
|
+
get: function () { return this._routerState.firstChild(this); },
|
|
214
144
|
enumerable: true,
|
|
215
145
|
configurable: true
|
|
216
146
|
});
|
|
217
147
|
Object.defineProperty(ActivatedRoute.prototype, "children", {
|
|
218
148
|
/** The children of this route in the router state tree */
|
|
219
|
-
get:
|
|
220
|
-
function () { return this._routerState.children(this); },
|
|
149
|
+
get: function () { return this._routerState.children(this); },
|
|
221
150
|
enumerable: true,
|
|
222
151
|
configurable: true
|
|
223
152
|
});
|
|
224
153
|
Object.defineProperty(ActivatedRoute.prototype, "pathFromRoot", {
|
|
225
154
|
/** The path from the root of the router state tree to this route */
|
|
226
|
-
get:
|
|
227
|
-
function () { return this._routerState.pathFromRoot(this); },
|
|
155
|
+
get: function () { return this._routerState.pathFromRoot(this); },
|
|
228
156
|
enumerable: true,
|
|
229
157
|
configurable: true
|
|
230
158
|
});
|
|
@@ -254,26 +182,6 @@ ActivatedRoute = /** @class */ (function () {
|
|
|
254
182
|
};
|
|
255
183
|
return ActivatedRoute;
|
|
256
184
|
}());
|
|
257
|
-
/**
|
|
258
|
-
* @description
|
|
259
|
-
*
|
|
260
|
-
* Contains the information about a route associated with a component loaded in an
|
|
261
|
-
* outlet. An `ActivatedRoute` can also be used to traverse the router state tree.
|
|
262
|
-
*
|
|
263
|
-
* ```
|
|
264
|
-
* @Component({...})
|
|
265
|
-
* class MyComponent {
|
|
266
|
-
* constructor(route: ActivatedRoute) {
|
|
267
|
-
* const id: Observable<string> = route.params.map(p => p.id);
|
|
268
|
-
* const url: Observable<string> = route.url.map(segments => segments.join(''));
|
|
269
|
-
* // route.data includes both `data` and `resolve`
|
|
270
|
-
* const user = route.data.map(d => d.user);
|
|
271
|
-
* }
|
|
272
|
-
* }
|
|
273
|
-
* ```
|
|
274
|
-
*
|
|
275
|
-
*
|
|
276
|
-
*/
|
|
277
185
|
export { ActivatedRoute };
|
|
278
186
|
/**
|
|
279
187
|
* Returns the inherited params, data, and resolve for a given route.
|
|
@@ -333,35 +241,22 @@ function flattenInherited(pathFromRoot) {
|
|
|
333
241
|
*
|
|
334
242
|
*
|
|
335
243
|
*/
|
|
336
|
-
var /**
|
|
337
|
-
* @description
|
|
338
|
-
*
|
|
339
|
-
* Contains the information about a route associated with a component loaded in an
|
|
340
|
-
* outlet at a particular moment in time. ActivatedRouteSnapshot can also be used to
|
|
341
|
-
* traverse the router state tree.
|
|
342
|
-
*
|
|
343
|
-
* ```
|
|
344
|
-
* @Component({templateUrl:'./my-component.html'})
|
|
345
|
-
* class MyComponent {
|
|
346
|
-
* constructor(route: ActivatedRoute) {
|
|
347
|
-
* const id: string = route.snapshot.params.id;
|
|
348
|
-
* const url: string = route.snapshot.url.join('');
|
|
349
|
-
* const user = route.snapshot.data.user;
|
|
350
|
-
* }
|
|
351
|
-
* }
|
|
352
|
-
* ```
|
|
353
|
-
*
|
|
354
|
-
*
|
|
355
|
-
*/
|
|
356
|
-
ActivatedRouteSnapshot = /** @class */ (function () {
|
|
244
|
+
var ActivatedRouteSnapshot = /** @class */ (function () {
|
|
357
245
|
/** @internal */
|
|
358
|
-
function ActivatedRouteSnapshot(
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
246
|
+
function ActivatedRouteSnapshot(
|
|
247
|
+
/** The URL segments matched by this route */
|
|
248
|
+
url,
|
|
249
|
+
/** The matrix parameters scoped to this route */
|
|
250
|
+
params,
|
|
251
|
+
/** The query parameters shared by all the routes */
|
|
252
|
+
queryParams,
|
|
253
|
+
/** The URL fragment shared by all the routes */
|
|
254
|
+
fragment,
|
|
255
|
+
/** The static and resolved data of this route */
|
|
256
|
+
data,
|
|
257
|
+
/** The outlet name of the route */
|
|
258
|
+
outlet,
|
|
259
|
+
/** The component of the route */
|
|
365
260
|
component, routeConfig, urlSegment, lastPathIndex, resolve) {
|
|
366
261
|
this.url = url;
|
|
367
262
|
this.params = params;
|
|
@@ -377,36 +272,31 @@ ActivatedRouteSnapshot = /** @class */ (function () {
|
|
|
377
272
|
}
|
|
378
273
|
Object.defineProperty(ActivatedRouteSnapshot.prototype, "root", {
|
|
379
274
|
/** The root of the router state */
|
|
380
|
-
get:
|
|
381
|
-
function () { return this._routerState.root; },
|
|
275
|
+
get: function () { return this._routerState.root; },
|
|
382
276
|
enumerable: true,
|
|
383
277
|
configurable: true
|
|
384
278
|
});
|
|
385
279
|
Object.defineProperty(ActivatedRouteSnapshot.prototype, "parent", {
|
|
386
280
|
/** The parent of this route in the router state tree */
|
|
387
|
-
get:
|
|
388
|
-
function () { return this._routerState.parent(this); },
|
|
281
|
+
get: function () { return this._routerState.parent(this); },
|
|
389
282
|
enumerable: true,
|
|
390
283
|
configurable: true
|
|
391
284
|
});
|
|
392
285
|
Object.defineProperty(ActivatedRouteSnapshot.prototype, "firstChild", {
|
|
393
286
|
/** The first child of this route in the router state tree */
|
|
394
|
-
get:
|
|
395
|
-
function () { return this._routerState.firstChild(this); },
|
|
287
|
+
get: function () { return this._routerState.firstChild(this); },
|
|
396
288
|
enumerable: true,
|
|
397
289
|
configurable: true
|
|
398
290
|
});
|
|
399
291
|
Object.defineProperty(ActivatedRouteSnapshot.prototype, "children", {
|
|
400
292
|
/** The children of this route in the router state tree */
|
|
401
|
-
get:
|
|
402
|
-
function () { return this._routerState.children(this); },
|
|
293
|
+
get: function () { return this._routerState.children(this); },
|
|
403
294
|
enumerable: true,
|
|
404
295
|
configurable: true
|
|
405
296
|
});
|
|
406
297
|
Object.defineProperty(ActivatedRouteSnapshot.prototype, "pathFromRoot", {
|
|
407
298
|
/** The path from the root of the router state tree to this route */
|
|
408
|
-
get:
|
|
409
|
-
function () { return this._routerState.pathFromRoot(this); },
|
|
299
|
+
get: function () { return this._routerState.pathFromRoot(this); },
|
|
410
300
|
enumerable: true,
|
|
411
301
|
configurable: true
|
|
412
302
|
});
|
|
@@ -437,26 +327,6 @@ ActivatedRouteSnapshot = /** @class */ (function () {
|
|
|
437
327
|
};
|
|
438
328
|
return ActivatedRouteSnapshot;
|
|
439
329
|
}());
|
|
440
|
-
/**
|
|
441
|
-
* @description
|
|
442
|
-
*
|
|
443
|
-
* Contains the information about a route associated with a component loaded in an
|
|
444
|
-
* outlet at a particular moment in time. ActivatedRouteSnapshot can also be used to
|
|
445
|
-
* traverse the router state tree.
|
|
446
|
-
*
|
|
447
|
-
* ```
|
|
448
|
-
* @Component({templateUrl:'./my-component.html'})
|
|
449
|
-
* class MyComponent {
|
|
450
|
-
* constructor(route: ActivatedRoute) {
|
|
451
|
-
* const id: string = route.snapshot.params.id;
|
|
452
|
-
* const url: string = route.snapshot.url.join('');
|
|
453
|
-
* const user = route.snapshot.data.user;
|
|
454
|
-
* }
|
|
455
|
-
* }
|
|
456
|
-
* ```
|
|
457
|
-
*
|
|
458
|
-
*
|
|
459
|
-
*/
|
|
460
330
|
export { ActivatedRouteSnapshot };
|
|
461
331
|
/**
|
|
462
332
|
* @description
|
|
@@ -484,36 +354,11 @@ export { ActivatedRouteSnapshot };
|
|
|
484
354
|
*
|
|
485
355
|
*
|
|
486
356
|
*/
|
|
487
|
-
var /**
|
|
488
|
-
* @description
|
|
489
|
-
*
|
|
490
|
-
* Represents the state of the router at a moment in time.
|
|
491
|
-
*
|
|
492
|
-
* This is a tree of activated route snapshots. Every node in this tree knows about
|
|
493
|
-
* the "consumed" URL segments, the extracted parameters, and the resolved data.
|
|
494
|
-
*
|
|
495
|
-
* ### Example
|
|
496
|
-
*
|
|
497
|
-
* ```
|
|
498
|
-
* @Component({templateUrl:'template.html'})
|
|
499
|
-
* class MyComponent {
|
|
500
|
-
* constructor(router: Router) {
|
|
501
|
-
* const state: RouterState = router.routerState;
|
|
502
|
-
* const snapshot: RouterStateSnapshot = state.snapshot;
|
|
503
|
-
* const root: ActivatedRouteSnapshot = snapshot.root;
|
|
504
|
-
* const child = root.firstChild;
|
|
505
|
-
* const id: Observable<string> = child.params.map(p => p.id);
|
|
506
|
-
* //...
|
|
507
|
-
* }
|
|
508
|
-
* }
|
|
509
|
-
* ```
|
|
510
|
-
*
|
|
511
|
-
*
|
|
512
|
-
*/
|
|
513
|
-
RouterStateSnapshot = /** @class */ (function (_super) {
|
|
357
|
+
var RouterStateSnapshot = /** @class */ (function (_super) {
|
|
514
358
|
tslib_1.__extends(RouterStateSnapshot, _super);
|
|
515
359
|
/** @internal */
|
|
516
|
-
function RouterStateSnapshot(
|
|
360
|
+
function RouterStateSnapshot(
|
|
361
|
+
/** The url from which this snapshot was created */
|
|
517
362
|
url, root) {
|
|
518
363
|
var _this = _super.call(this, root) || this;
|
|
519
364
|
_this.url = url;
|
|
@@ -523,32 +368,6 @@ RouterStateSnapshot = /** @class */ (function (_super) {
|
|
|
523
368
|
RouterStateSnapshot.prototype.toString = function () { return serializeNode(this._root); };
|
|
524
369
|
return RouterStateSnapshot;
|
|
525
370
|
}(Tree));
|
|
526
|
-
/**
|
|
527
|
-
* @description
|
|
528
|
-
*
|
|
529
|
-
* Represents the state of the router at a moment in time.
|
|
530
|
-
*
|
|
531
|
-
* This is a tree of activated route snapshots. Every node in this tree knows about
|
|
532
|
-
* the "consumed" URL segments, the extracted parameters, and the resolved data.
|
|
533
|
-
*
|
|
534
|
-
* ### Example
|
|
535
|
-
*
|
|
536
|
-
* ```
|
|
537
|
-
* @Component({templateUrl:'template.html'})
|
|
538
|
-
* class MyComponent {
|
|
539
|
-
* constructor(router: Router) {
|
|
540
|
-
* const state: RouterState = router.routerState;
|
|
541
|
-
* const snapshot: RouterStateSnapshot = state.snapshot;
|
|
542
|
-
* const root: ActivatedRouteSnapshot = snapshot.root;
|
|
543
|
-
* const child = root.firstChild;
|
|
544
|
-
* const id: Observable<string> = child.params.map(p => p.id);
|
|
545
|
-
* //...
|
|
546
|
-
* }
|
|
547
|
-
* }
|
|
548
|
-
* ```
|
|
549
|
-
*
|
|
550
|
-
*
|
|
551
|
-
*/
|
|
552
371
|
export { RouterStateSnapshot };
|
|
553
372
|
function setRouterState(state, node) {
|
|
554
373
|
node.value._routerState = state;
|
|
@@ -587,7 +406,6 @@ export function advanceActivatedRoute(route) {
|
|
|
587
406
|
else {
|
|
588
407
|
route.snapshot = route._futureSnapshot;
|
|
589
408
|
// this is for resolved data
|
|
590
|
-
// this is for resolved data
|
|
591
409
|
route.data.next(route._futureSnapshot.data);
|
|
592
410
|
}
|
|
593
411
|
}
|
|
@@ -595,7 +413,7 @@ export function equalParamsAndUrlSegments(a, b) {
|
|
|
595
413
|
var equalUrlParams = shallowEqual(a.params, b.params) && equalSegments(a.url, b.url);
|
|
596
414
|
var parentsMismatch = !a.parent !== !b.parent;
|
|
597
415
|
return equalUrlParams && !parentsMismatch &&
|
|
598
|
-
(!a.parent || equalParamsAndUrlSegments(a.parent,
|
|
416
|
+
(!a.parent || equalParamsAndUrlSegments(a.parent, b.parent));
|
|
599
417
|
}
|
|
600
418
|
|
|
601
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_state.js","sourceRoot":"","sources":["../../../../../../../../../packages/router/src/router_state.ts"],"names":[],"mappings":";;;;;;;;AASA,OAAO,EAAC,eAAe,EAAa,MAAM,MAAM,CAAC;AACjD,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAGnC,OAAO,EAAC,cAAc,EAAoB,iBAAiB,EAAC,MAAM,UAAU,CAAC;AAC7E,OAAO,EAAC,UAAU,EAA4B,aAAa,EAAC,MAAM,YAAY,CAAC;AAC/E,OAAO,EAAC,YAAY,EAAE,kBAAkB,EAAC,MAAM,oBAAoB,CAAC;AACpE,OAAO,EAAC,IAAI,EAAE,QAAQ,EAAC,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+B5C;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;IAAiC,uCAAoB;IACnD,gBAAgB;IAChB,qBACI,IAA8B;IAEvB,QAA6B;QAHxC,YAIE,kBAAM,IAAI,CAAC,SAEZ;QAHU,cAAQ,GAAR,QAAQ,CAAqB;QAEtC,cAAc,CAAc,KAAI,EAAE,IAAI,CAAC,CAAC;;KACzC;IAED,8BAAQ,GAAR,cAAqB,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,EAAE;sBAzDzD;EA+CiC,IAAI,EAWpC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAXD,uBAWC;AAED,MAAM,2BAA2B,OAAgB,EAAE,aAA8B;IAC/E,IAAM,QAAQ,GAAG,wBAAwB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAClE,IAAM,QAAQ,GAAG,IAAI,eAAe,CAAC,CAAC,IAAI,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;IAC/D,IAAM,WAAW,GAAG,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;IAC5C,IAAM,SAAS,GAAG,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;IAC1C,IAAM,gBAAgB,GAAG,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;IACjD,IAAM,QAAQ,GAAG,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;IACzC,IAAM,SAAS,GAAG,IAAI,cAAc,CAChC,QAAQ,EAAE,WAAW,EAAE,gBAAgB,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,aAAa,EAC3F,QAAQ,CAAC,IAAI,CAAC,CAAC;IACnB,SAAS,CAAC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC;IACnC,MAAM,CAAC,IAAI,WAAW,CAAC,IAAI,QAAQ,CAAiB,SAAS,EAAE,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;CAC/E;AAED,MAAM,mCACF,OAAgB,EAAE,aAA8B;IAClD,IAAM,WAAW,GAAG,EAAE,CAAC;IACvB,IAAM,SAAS,GAAG,EAAE,CAAC;IACrB,IAAM,gBAAgB,GAAG,EAAE,CAAC;IAC5B,IAAM,QAAQ,GAAG,EAAE,CAAC;IACpB,IAAM,SAAS,GAAG,IAAI,sBAAsB,CACxC,EAAE,EAAE,WAAW,EAAE,gBAAgB,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,aAAa,EAAE,IAAI,EAC3F,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC1B,MAAM,CAAC,IAAI,mBAAmB,CAAC,EAAE,EAAE,IAAI,QAAQ,CAAyB,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;CACzF;;;;;;;;;;;;;;;;;;;;;AAsBD;;;;;;;;;;;;;;;;;;;;AAAA;IAYE,gBAAgB;IAChB;IAEW,GAA6B;IAE7B,MAA0B;IAE1B,WAA+B;IAE/B,QAA4B;IAE5B,IAAsB;IAEtB,MAAc;;IAGd,SAAgC,EAAE,cAAsC;QAbxE,QAAG,GAAH,GAAG,CAA0B;QAE7B,WAAM,GAAN,MAAM,CAAoB;QAE1B,gBAAW,GAAX,WAAW,CAAoB;QAE/B,aAAQ,GAAR,QAAQ,CAAoB;QAE5B,SAAI,GAAJ,IAAI,CAAkB;QAEtB,WAAM,GAAN,MAAM,CAAQ;QAGd,cAAS,GAAT,SAAS,CAAuB;QACzC,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;KACvC;IAGD,sBAAI,uCAAW;QADf,iDAAiD;;QACjD,cAAgC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,EAAE;;;OAAA;IAG1E,sBAAI,gCAAI;QADR,mCAAmC;;QACnC,cAA6B,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;;;OAAA;IAG7D,sBAAI,kCAAM;QADV,wDAAwD;;QACxD,cAAoC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAG5E,sBAAI,sCAAU;QADd,6DAA6D;;QAC7D,cAAwC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAGpF,sBAAI,oCAAQ;QADZ,0DAA0D;;QAC1D,cAAmC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAG7E,sBAAI,wCAAY;QADhB,oEAAoE;;QACpE,cAAuC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAErF,sBAAI,oCAAQ;aAAZ;YACE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;gBACpB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,UAAC,CAAS,IAAe,OAAA,iBAAiB,CAAC,CAAC,CAAC,EAApB,CAAoB,CAAC,CAAC,CAAC;aACvF;YACD,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;SACvB;;;OAAA;IAED,sBAAI,yCAAa;aAAjB;YACE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;gBACzB,IAAI,CAAC,cAAc;oBACf,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,UAAC,CAAS,IAAe,OAAA,iBAAiB,CAAC,CAAC,CAAC,EAApB,CAAoB,CAAC,CAAC,CAAC;aAC/E;YACD,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;SAC5B;;;OAAA;IAED,iCAAQ,GAAR;QACE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,YAAU,IAAI,CAAC,eAAe,MAAG,CAAC;KACrF;yBA7KH;IA8KC,CAAA;;;;;;;;;;;;;;;;;;;;;AApED,0BAoEC;;;;;;AAgBD,MAAM,qCACF,KAA6B,EAC7B,yBAAkE;IAAlE,0CAAA,EAAA,uCAAkE;IACpE,IAAM,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;IAExC,IAAI,sBAAsB,GAAG,CAAC,CAAC;IAC/B,EAAE,CAAC,CAAC,yBAAyB,KAAK,QAAQ,CAAC,CAAC,CAAC;QAC3C,sBAAsB,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;QAEjD,OAAO,sBAAsB,IAAI,CAAC,EAAE,CAAC;YACnC,IAAM,OAAO,GAAG,YAAY,CAAC,sBAAsB,CAAC,CAAC;YACrD,IAAM,QAAM,GAAG,YAAY,CAAC,sBAAsB,GAAG,CAAC,CAAC,CAAC;;YAExD,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,WAAW,CAAC,IAAI,KAAK,EAAE,CAAC,CAAC,CAAC;gBAC3D,sBAAsB,EAAE,CAAC;;aAG1B;YAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,QAAM,CAAC,SAAS,CAAC,CAAC,CAAC;gBAC7B,sBAAsB,EAAE,CAAC;aAE1B;YAAC,IAAI,CAAC,CAAC;gBACN,KAAK,CAAC;aACP;SACF;KACF;IAED,MAAM,CAAC,gBAAgB,CAAC,YAAY,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;CACrE;;AAGD,0BAA0B,YAAsC;IAC9D,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,UAAC,GAAG,EAAE,IAAI;QACnC,IAAM,MAAM,wBAAO,GAAG,CAAC,MAAM,EAAK,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/C,IAAM,IAAI,wBAAO,GAAG,CAAC,IAAI,EAAK,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,IAAM,OAAO,wBAAO,GAAG,CAAC,OAAO,EAAK,IAAI,CAAC,aAAa,CAAC,CAAC;QACxD,MAAM,CAAC,EAAC,MAAM,QAAA,EAAE,IAAI,MAAA,EAAE,OAAO,SAAA,EAAC,CAAC;KAChC,EAAO,EAAC,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAC,CAAC,CAAC;CAC9C;;;;;;;;;;;;;;;;;;;;;AAsBD;;;;;;;;;;;;;;;;;;;;AAAA;IAkBE,gBAAgB;IAChB;IAEW,GAAiB;IAEjB,MAAc;IAEd,WAAmB;IAEnB,QAAgB;IAEhB,IAAU;IAEV,MAAc;IAEd,SAAgC,EAAE,WAAuB,EAAE,UAA2B,EAC7F,aAAqB,EAAE,OAAoB;QAbpC,QAAG,GAAH,GAAG,CAAc;QAEjB,WAAM,GAAN,MAAM,CAAQ;QAEd,gBAAW,GAAX,WAAW,CAAQ;QAEnB,aAAQ,GAAR,QAAQ,CAAQ;QAEhB,SAAI,GAAJ,IAAI,CAAM;QAEV,WAAM,GAAN,MAAM,CAAQ;QAEd,cAAS,GAAT,SAAS,CAAuB;QAEzC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;QACpC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;KACzB;IAGD,sBAAI,wCAAI;QADR,mCAAmC;;QACnC,cAAqC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;;;OAAA;IAGrE,sBAAI,0CAAM;QADV,wDAAwD;;QACxD,cAA4C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAGpF,sBAAI,8CAAU;QADd,6DAA6D;;QAC7D,cAAgD,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAG5F,sBAAI,4CAAQ;QADZ,0DAA0D;;QAC1D,cAA2C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAGrF,sBAAI,gDAAY;QADhB,oEAAoE;;QACpE,cAA+C,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,EAAE;;;OAAA;IAE7F,sBAAI,4CAAQ;aAAZ;YACE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;gBACpB,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aACjD;YACD,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;SACvB;;;OAAA;IAED,sBAAI,iDAAa;aAAjB;YACE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;gBACzB,IAAI,CAAC,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC3D;YACD,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;SAC5B;;;OAAA;IAED,yCAAQ,GAAR;QACE,IAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,QAAQ,EAAE,EAAlB,CAAkB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAClE,IAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9D,MAAM,CAAC,gBAAc,GAAG,iBAAY,OAAO,OAAI,CAAC;KACjD;iCAnUH;IAoUC,CAAA;;;;;;;;;;;;;;;;;;;;;AA3ED,kCA2EC;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4BD;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;IAAyC,+CAA4B;IACnE,gBAAgB;IAChB;IAEW,GAAW,EAAE,IAAsC;QAF9D,YAGE,kBAAM,IAAI,CAAC,SAEZ;QAHU,SAAG,GAAH,GAAG,CAAQ;QAEpB,cAAc,CAAsB,KAAI,EAAE,IAAI,CAAC,CAAC;;KACjD;IAED,sCAAQ,GAAR,cAAqB,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE;8BAzW1D;EAgWyC,IAAI,EAU5C,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;AAVD,+BAUC;AAED,wBAAuD,KAAQ,EAAE,IAAiB;IAChF,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC;IAChC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAA,CAAC,IAAI,OAAA,cAAc,CAAC,KAAK,EAAE,CAAC,CAAC,EAAxB,CAAwB,CAAC,CAAC;CACtD;AAED,uBAAuB,IAAsC;IAC3D,IAAM,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,QAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IACjG,MAAM,CAAC,KAAG,IAAI,CAAC,KAAK,GAAG,CAAG,CAAC;CAC5B;;;;;;AAOD,MAAM,gCAAgC,KAAqB;IACzD,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;QACnB,IAAM,eAAe,GAAG,KAAK,CAAC,QAAQ,CAAC;QACvC,IAAM,YAAY,GAAG,KAAK,CAAC,eAAe,CAAC;QAC3C,KAAK,CAAC,QAAQ,GAAG,YAAY,CAAC;QAC9B,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,eAAe,CAAC,WAAW,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACnE,KAAK,CAAC,WAAY,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;SACzD;QACD,EAAE,CAAC,CAAC,eAAe,CAAC,QAAQ,KAAK,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;YACjD,KAAK,CAAC,QAAS,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;SACnD;QACD,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,eAAe,CAAC,MAAM,EAAE,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACzD,KAAK,CAAC,MAAO,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;SAC/C;QACD,EAAE,CAAC,CAAC,CAAC,kBAAkB,CAAC,eAAe,CAAC,GAAG,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACzD,KAAK,CAAC,GAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;SACzC;QACD,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACrD,KAAK,CAAC,IAAK,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;SAC3C;KACF;IAAC,IAAI,CAAC,CAAC;QACN,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,eAAe,CAAC;;QAGvC,AADA,4BAA4B;QACtB,KAAK,CAAC,IAAK,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;KACpD;CACF;AAGD,MAAM,oCACF,CAAyB,EAAE,CAAyB;IACtD,IAAM,cAAc,GAAG,YAAY,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IACvF,IAAM,eAAe,GAAG,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;IAEhD,MAAM,CAAC,cAAc,IAAI,CAAC,eAAe;QACrC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,yBAAyB,CAAC,CAAC,CAAC,MAAM,EAAE,CAAA,CAAC,CAAC,MAAQ,CAAA,CAAC,CAAC,CAAC;CACpE","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Type} from '@angular/core';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {Data, ResolveData, Route} from './config';\nimport {PRIMARY_OUTLET, ParamMap, Params, convertToParamMap} from './shared';\nimport {UrlSegment, UrlSegmentGroup, UrlTree, equalSegments} from './url_tree';\nimport {shallowEqual, shallowEqualArrays} from './utils/collection';\nimport {Tree, TreeNode} from './utils/tree';\n\n\n\n/**\n * @description\n *\n * Represents the state of the router.\n *\n * RouterState is a tree of activated routes. Every node in this tree knows about the \"consumed\" URL\n * segments, the extracted parameters, and the resolved data.\n *\n * ### Example\n *\n * ```\n * @Component({templateUrl:'template.html'})\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state: RouterState = router.routerState;\n *     const root: ActivatedRoute = state.root;\n *     const child = root.firstChild;\n *     const id: Observable<string> = child.params.map(p => p.id);\n *     //...\n *   }\n * }\n * ```\n *\n * See `ActivatedRoute` for more information.\n *\n *\n */\nexport class RouterState extends Tree<ActivatedRoute> {\n  /** @internal */\n  constructor(\n      root: TreeNode<ActivatedRoute>,\n      /** The current snapshot of the router state */\n      public snapshot: RouterStateSnapshot) {\n    super(root);\n    setRouterState(<RouterState>this, root);\n  }\n\n  toString(): string { return this.snapshot.toString(); }\n}\n\nexport function createEmptyState(urlTree: UrlTree, rootComponent: Type<any>| null): RouterState {\n  const snapshot = createEmptyStateSnapshot(urlTree, rootComponent);\n  const emptyUrl = new BehaviorSubject([new UrlSegment('', {})]);\n  const emptyParams = new BehaviorSubject({});\n  const emptyData = new BehaviorSubject({});\n  const emptyQueryParams = new BehaviorSubject({});\n  const fragment = new BehaviorSubject('');\n  const activated = new ActivatedRoute(\n      emptyUrl, emptyParams, emptyQueryParams, fragment, emptyData, PRIMARY_OUTLET, rootComponent,\n      snapshot.root);\n  activated.snapshot = snapshot.root;\n  return new RouterState(new TreeNode<ActivatedRoute>(activated, []), snapshot);\n}\n\nexport function createEmptyStateSnapshot(\n    urlTree: UrlTree, rootComponent: Type<any>| null): RouterStateSnapshot {\n  const emptyParams = {};\n  const emptyData = {};\n  const emptyQueryParams = {};\n  const fragment = '';\n  const activated = new ActivatedRouteSnapshot(\n      [], emptyParams, emptyQueryParams, fragment, emptyData, PRIMARY_OUTLET, rootComponent, null,\n      urlTree.root, -1, {});\n  return new RouterStateSnapshot('', new TreeNode<ActivatedRouteSnapshot>(activated, []));\n}\n\n/**\n * @description\n *\n * Contains the information about a route associated with a component loaded in an\n * outlet.  An `ActivatedRoute` can also be used to traverse the router state tree.\n *\n * ```\n * @Component({...})\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: Observable<string> = route.params.map(p => p.id);\n *     const url: Observable<string> = route.url.map(segments => segments.join(''));\n *     // route.data includes both `data` and `resolve`\n *     const user = route.data.map(d => d.user);\n *   }\n * }\n * ```\n *\n *\n */\nexport class ActivatedRoute {\n  /** The current snapshot of this route */\n  snapshot: ActivatedRouteSnapshot;\n  /** @internal */\n  _futureSnapshot: ActivatedRouteSnapshot;\n  /** @internal */\n  _routerState: RouterState;\n  /** @internal */\n  _paramMap: Observable<ParamMap>;\n  /** @internal */\n  _queryParamMap: Observable<ParamMap>;\n\n  /** @internal */\n  constructor(\n      /** An observable of the URL segments matched by this route */\n      public url: Observable<UrlSegment[]>,\n      /** An observable of the matrix parameters scoped to this route */\n      public params: Observable<Params>,\n      /** An observable of the query parameters shared by all the routes */\n      public queryParams: Observable<Params>,\n      /** An observable of the URL fragment shared by all the routes */\n      public fragment: Observable<string>,\n      /** An observable of the static and resolved data of this route. */\n      public data: Observable<Data>,\n      /** The outlet name of the route. It's a constant */\n      public outlet: string,\n      /** The component of the route. It's a constant */\n      // TODO(vsavkin): remove |string\n      public component: Type<any>|string|null, futureSnapshot: ActivatedRouteSnapshot) {\n    this._futureSnapshot = futureSnapshot;\n  }\n\n  /** The configuration used to match this route */\n  get routeConfig(): Route|null { return this._futureSnapshot.routeConfig; }\n\n  /** The root of the router state */\n  get root(): ActivatedRoute { return this._routerState.root; }\n\n  /** The parent of this route in the router state tree */\n  get parent(): ActivatedRoute|null { return this._routerState.parent(this); }\n\n  /** The first child of this route in the router state tree */\n  get firstChild(): ActivatedRoute|null { return this._routerState.firstChild(this); }\n\n  /** The children of this route in the router state tree */\n  get children(): ActivatedRoute[] { return this._routerState.children(this); }\n\n  /** The path from the root of the router state tree to this route */\n  get pathFromRoot(): ActivatedRoute[] { return this._routerState.pathFromRoot(this); }\n\n  get paramMap(): Observable<ParamMap> {\n    if (!this._paramMap) {\n      this._paramMap = this.params.pipe(map((p: Params): ParamMap => convertToParamMap(p)));\n    }\n    return this._paramMap;\n  }\n\n  get queryParamMap(): Observable<ParamMap> {\n    if (!this._queryParamMap) {\n      this._queryParamMap =\n          this.queryParams.pipe(map((p: Params): ParamMap => convertToParamMap(p)));\n    }\n    return this._queryParamMap;\n  }\n\n  toString(): string {\n    return this.snapshot ? this.snapshot.toString() : `Future(${this._futureSnapshot})`;\n  }\n}\n\nexport type ParamsInheritanceStrategy = 'emptyOnly' | 'always';\n\n/** @internal */\nexport type Inherited = {\n  params: Params,\n  data: Data,\n  resolve: Data,\n};\n\n/**\n * Returns the inherited params, data, and resolve for a given route.\n * By default, this only inherits values up to the nearest path-less or component-less route.\n * @internal\n */\nexport function inheritedParamsDataResolve(\n    route: ActivatedRouteSnapshot,\n    paramsInheritanceStrategy: ParamsInheritanceStrategy = 'emptyOnly'): Inherited {\n  const pathFromRoot = route.pathFromRoot;\n\n  let inheritingStartingFrom = 0;\n  if (paramsInheritanceStrategy !== 'always') {\n    inheritingStartingFrom = pathFromRoot.length - 1;\n\n    while (inheritingStartingFrom >= 1) {\n      const current = pathFromRoot[inheritingStartingFrom];\n      const parent = pathFromRoot[inheritingStartingFrom - 1];\n      // current route is an empty path => inherits its parent's params and data\n      if (current.routeConfig && current.routeConfig.path === '') {\n        inheritingStartingFrom--;\n\n        // parent is componentless => current route should inherit its params and data\n      } else if (!parent.component) {\n        inheritingStartingFrom--;\n\n      } else {\n        break;\n      }\n    }\n  }\n\n  return flattenInherited(pathFromRoot.slice(inheritingStartingFrom));\n}\n\n/** @internal */\nfunction flattenInherited(pathFromRoot: ActivatedRouteSnapshot[]): Inherited {\n  return pathFromRoot.reduce((res, curr) => {\n    const params = {...res.params, ...curr.params};\n    const data = {...res.data, ...curr.data};\n    const resolve = {...res.resolve, ...curr._resolvedData};\n    return {params, data, resolve};\n  }, <any>{params: {}, data: {}, resolve: {}});\n}\n\n/**\n * @description\n *\n * Contains the information about a route associated with a component loaded in an\n * outlet at a particular moment in time. ActivatedRouteSnapshot can also be used to\n * traverse the router state tree.\n *\n * ```\n * @Component({templateUrl:'./my-component.html'})\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: string = route.snapshot.params.id;\n *     const url: string = route.snapshot.url.join('');\n *     const user = route.snapshot.data.user;\n *   }\n * }\n * ```\n *\n *\n */\nexport class ActivatedRouteSnapshot {\n  /** The configuration used to match this route **/\n  public readonly routeConfig: Route|null;\n  /** @internal **/\n  _urlSegment: UrlSegmentGroup;\n  /** @internal */\n  _lastPathIndex: number;\n  /** @internal */\n  _resolve: ResolveData;\n  /** @internal */\n  _resolvedData: Data;\n  /** @internal */\n  _routerState: RouterStateSnapshot;\n  /** @internal */\n  _paramMap: ParamMap;\n  /** @internal */\n  _queryParamMap: ParamMap;\n\n  /** @internal */\n  constructor(\n      /** The URL segments matched by this route */\n      public url: UrlSegment[],\n      /** The matrix parameters scoped to this route */\n      public params: Params,\n      /** The query parameters shared by all the routes */\n      public queryParams: Params,\n      /** The URL fragment shared by all the routes */\n      public fragment: string,\n      /** The static and resolved data of this route */\n      public data: Data,\n      /** The outlet name of the route */\n      public outlet: string,\n      /** The component of the route */\n      public component: Type<any>|string|null, routeConfig: Route|null, urlSegment: UrlSegmentGroup,\n      lastPathIndex: number, resolve: ResolveData) {\n    this.routeConfig = routeConfig;\n    this._urlSegment = urlSegment;\n    this._lastPathIndex = lastPathIndex;\n    this._resolve = resolve;\n  }\n\n  /** The root of the router state */\n  get root(): ActivatedRouteSnapshot { return this._routerState.root; }\n\n  /** The parent of this route in the router state tree */\n  get parent(): ActivatedRouteSnapshot|null { return this._routerState.parent(this); }\n\n  /** The first child of this route in the router state tree */\n  get firstChild(): ActivatedRouteSnapshot|null { return this._routerState.firstChild(this); }\n\n  /** The children of this route in the router state tree */\n  get children(): ActivatedRouteSnapshot[] { return this._routerState.children(this); }\n\n  /** The path from the root of the router state tree to this route */\n  get pathFromRoot(): ActivatedRouteSnapshot[] { return this._routerState.pathFromRoot(this); }\n\n  get paramMap(): ParamMap {\n    if (!this._paramMap) {\n      this._paramMap = convertToParamMap(this.params);\n    }\n    return this._paramMap;\n  }\n\n  get queryParamMap(): ParamMap {\n    if (!this._queryParamMap) {\n      this._queryParamMap = convertToParamMap(this.queryParams);\n    }\n    return this._queryParamMap;\n  }\n\n  toString(): string {\n    const url = this.url.map(segment => segment.toString()).join('/');\n    const matched = this.routeConfig ? this.routeConfig.path : '';\n    return `Route(url:'${url}', path:'${matched}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the state of the router at a moment in time.\n *\n * This is a tree of activated route snapshots. Every node in this tree knows about\n * the \"consumed\" URL segments, the extracted parameters, and the resolved data.\n *\n * ### Example\n *\n * ```\n * @Component({templateUrl:'template.html'})\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state: RouterState = router.routerState;\n *     const snapshot: RouterStateSnapshot = state.snapshot;\n *     const root: ActivatedRouteSnapshot = snapshot.root;\n *     const child = root.firstChild;\n *     const id: Observable<string> = child.params.map(p => p.id);\n *     //...\n *   }\n * }\n * ```\n *\n *\n */\nexport class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {\n  /** @internal */\n  constructor(\n      /** The url from which this snapshot was created */\n      public url: string, root: TreeNode<ActivatedRouteSnapshot>) {\n    super(root);\n    setRouterState(<RouterStateSnapshot>this, root);\n  }\n\n  toString(): string { return serializeNode(this._root); }\n}\n\nfunction setRouterState<U, T extends{_routerState: U}>(state: U, node: TreeNode<T>): void {\n  node.value._routerState = state;\n  node.children.forEach(c => setRouterState(state, c));\n}\n\nfunction serializeNode(node: TreeNode<ActivatedRouteSnapshot>): string {\n  const c = node.children.length > 0 ? ` { ${node.children.map(serializeNode).join(', ')} } ` : '';\n  return `${node.value}${c}`;\n}\n\n/**\n * The expectation is that the activate route is created with the right set of parameters.\n * So we push new values into the observables only when they are not the initial values.\n * And we detect that by checking if the snapshot field is set.\n */\nexport function advanceActivatedRoute(route: ActivatedRoute): void {\n  if (route.snapshot) {\n    const currentSnapshot = route.snapshot;\n    const nextSnapshot = route._futureSnapshot;\n    route.snapshot = nextSnapshot;\n    if (!shallowEqual(currentSnapshot.queryParams, nextSnapshot.queryParams)) {\n      (<any>route.queryParams).next(nextSnapshot.queryParams);\n    }\n    if (currentSnapshot.fragment !== nextSnapshot.fragment) {\n      (<any>route.fragment).next(nextSnapshot.fragment);\n    }\n    if (!shallowEqual(currentSnapshot.params, nextSnapshot.params)) {\n      (<any>route.params).next(nextSnapshot.params);\n    }\n    if (!shallowEqualArrays(currentSnapshot.url, nextSnapshot.url)) {\n      (<any>route.url).next(nextSnapshot.url);\n    }\n    if (!shallowEqual(currentSnapshot.data, nextSnapshot.data)) {\n      (<any>route.data).next(nextSnapshot.data);\n    }\n  } else {\n    route.snapshot = route._futureSnapshot;\n\n    // this is for resolved data\n    (<any>route.data).next(route._futureSnapshot.data);\n  }\n}\n\n\nexport function equalParamsAndUrlSegments(\n    a: ActivatedRouteSnapshot, b: ActivatedRouteSnapshot): boolean {\n  const equalUrlParams = shallowEqual(a.params, b.params) && equalSegments(a.url, b.url);\n  const parentsMismatch = !a.parent !== !b.parent;\n\n  return equalUrlParams && !parentsMismatch &&\n      (!a.parent || equalParamsAndUrlSegments(a.parent, b.parent !));\n}\n"]}
|
|
419
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_state.js","sourceRoot":"","sources":["../../../../../../../../../packages/router/src/router_state.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Type} from '@angular/core';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {Data, ResolveData, Route} from './config';\nimport {PRIMARY_OUTLET, ParamMap, Params, convertToParamMap} from './shared';\nimport {UrlSegment, UrlSegmentGroup, UrlTree, equalSegments} from './url_tree';\nimport {shallowEqual, shallowEqualArrays} from './utils/collection';\nimport {Tree, TreeNode} from './utils/tree';\n\n\n\n/**\n * @description\n *\n * Represents the state of the router.\n *\n * RouterState is a tree of activated routes. Every node in this tree knows about the \"consumed\" URL\n * segments, the extracted parameters, and the resolved data.\n *\n * ### Example\n *\n * ```\n * @Component({templateUrl:'template.html'})\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state: RouterState = router.routerState;\n *     const root: ActivatedRoute = state.root;\n *     const child = root.firstChild;\n *     const id: Observable<string> = child.params.map(p => p.id);\n *     //...\n *   }\n * }\n * ```\n *\n * See `ActivatedRoute` for more information.\n *\n *\n */\nexport class RouterState extends Tree<ActivatedRoute> {\n  /** @internal */\n  constructor(\n      root: TreeNode<ActivatedRoute>,\n      /** The current snapshot of the router state */\n      public snapshot: RouterStateSnapshot) {\n    super(root);\n    setRouterState(<RouterState>this, root);\n  }\n\n  toString(): string { return this.snapshot.toString(); }\n}\n\nexport function createEmptyState(urlTree: UrlTree, rootComponent: Type<any>| null): RouterState {\n  const snapshot = createEmptyStateSnapshot(urlTree, rootComponent);\n  const emptyUrl = new BehaviorSubject([new UrlSegment('', {})]);\n  const emptyParams = new BehaviorSubject({});\n  const emptyData = new BehaviorSubject({});\n  const emptyQueryParams = new BehaviorSubject({});\n  const fragment = new BehaviorSubject('');\n  const activated = new ActivatedRoute(\n      emptyUrl, emptyParams, emptyQueryParams, fragment, emptyData, PRIMARY_OUTLET, rootComponent,\n      snapshot.root);\n  activated.snapshot = snapshot.root;\n  return new RouterState(new TreeNode<ActivatedRoute>(activated, []), snapshot);\n}\n\nexport function createEmptyStateSnapshot(\n    urlTree: UrlTree, rootComponent: Type<any>| null): RouterStateSnapshot {\n  const emptyParams = {};\n  const emptyData = {};\n  const emptyQueryParams = {};\n  const fragment = '';\n  const activated = new ActivatedRouteSnapshot(\n      [], emptyParams, emptyQueryParams, fragment, emptyData, PRIMARY_OUTLET, rootComponent, null,\n      urlTree.root, -1, {});\n  return new RouterStateSnapshot('', new TreeNode<ActivatedRouteSnapshot>(activated, []));\n}\n\n/**\n * @description\n *\n * Contains the information about a route associated with a component loaded in an\n * outlet.  An `ActivatedRoute` can also be used to traverse the router state tree.\n *\n * ```\n * @Component({...})\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: Observable<string> = route.params.map(p => p.id);\n *     const url: Observable<string> = route.url.map(segments => segments.join(''));\n *     // route.data includes both `data` and `resolve`\n *     const user = route.data.map(d => d.user);\n *   }\n * }\n * ```\n *\n *\n */\nexport class ActivatedRoute {\n  /** The current snapshot of this route */\n  snapshot: ActivatedRouteSnapshot;\n  /** @internal */\n  _futureSnapshot: ActivatedRouteSnapshot;\n  /** @internal */\n  _routerState: RouterState;\n  /** @internal */\n  _paramMap: Observable<ParamMap>;\n  /** @internal */\n  _queryParamMap: Observable<ParamMap>;\n\n  /** @internal */\n  constructor(\n      /** An observable of the URL segments matched by this route */\n      public url: Observable<UrlSegment[]>,\n      /** An observable of the matrix parameters scoped to this route */\n      public params: Observable<Params>,\n      /** An observable of the query parameters shared by all the routes */\n      public queryParams: Observable<Params>,\n      /** An observable of the URL fragment shared by all the routes */\n      public fragment: Observable<string>,\n      /** An observable of the static and resolved data of this route. */\n      public data: Observable<Data>,\n      /** The outlet name of the route. It's a constant */\n      public outlet: string,\n      /** The component of the route. It's a constant */\n      // TODO(vsavkin): remove |string\n      public component: Type<any>|string|null, futureSnapshot: ActivatedRouteSnapshot) {\n    this._futureSnapshot = futureSnapshot;\n  }\n\n  /** The configuration used to match this route */\n  get routeConfig(): Route|null { return this._futureSnapshot.routeConfig; }\n\n  /** The root of the router state */\n  get root(): ActivatedRoute { return this._routerState.root; }\n\n  /** The parent of this route in the router state tree */\n  get parent(): ActivatedRoute|null { return this._routerState.parent(this); }\n\n  /** The first child of this route in the router state tree */\n  get firstChild(): ActivatedRoute|null { return this._routerState.firstChild(this); }\n\n  /** The children of this route in the router state tree */\n  get children(): ActivatedRoute[] { return this._routerState.children(this); }\n\n  /** The path from the root of the router state tree to this route */\n  get pathFromRoot(): ActivatedRoute[] { return this._routerState.pathFromRoot(this); }\n\n  get paramMap(): Observable<ParamMap> {\n    if (!this._paramMap) {\n      this._paramMap = this.params.pipe(map((p: Params): ParamMap => convertToParamMap(p)));\n    }\n    return this._paramMap;\n  }\n\n  get queryParamMap(): Observable<ParamMap> {\n    if (!this._queryParamMap) {\n      this._queryParamMap =\n          this.queryParams.pipe(map((p: Params): ParamMap => convertToParamMap(p)));\n    }\n    return this._queryParamMap;\n  }\n\n  toString(): string {\n    return this.snapshot ? this.snapshot.toString() : `Future(${this._futureSnapshot})`;\n  }\n}\n\nexport type ParamsInheritanceStrategy = 'emptyOnly' | 'always';\n\n/** @internal */\nexport type Inherited = {\n  params: Params,\n  data: Data,\n  resolve: Data,\n};\n\n/**\n * Returns the inherited params, data, and resolve for a given route.\n * By default, this only inherits values up to the nearest path-less or component-less route.\n * @internal\n */\nexport function inheritedParamsDataResolve(\n    route: ActivatedRouteSnapshot,\n    paramsInheritanceStrategy: ParamsInheritanceStrategy = 'emptyOnly'): Inherited {\n  const pathFromRoot = route.pathFromRoot;\n\n  let inheritingStartingFrom = 0;\n  if (paramsInheritanceStrategy !== 'always') {\n    inheritingStartingFrom = pathFromRoot.length - 1;\n\n    while (inheritingStartingFrom >= 1) {\n      const current = pathFromRoot[inheritingStartingFrom];\n      const parent = pathFromRoot[inheritingStartingFrom - 1];\n      // current route is an empty path => inherits its parent's params and data\n      if (current.routeConfig && current.routeConfig.path === '') {\n        inheritingStartingFrom--;\n\n        // parent is componentless => current route should inherit its params and data\n      } else if (!parent.component) {\n        inheritingStartingFrom--;\n\n      } else {\n        break;\n      }\n    }\n  }\n\n  return flattenInherited(pathFromRoot.slice(inheritingStartingFrom));\n}\n\n/** @internal */\nfunction flattenInherited(pathFromRoot: ActivatedRouteSnapshot[]): Inherited {\n  return pathFromRoot.reduce((res, curr) => {\n    const params = {...res.params, ...curr.params};\n    const data = {...res.data, ...curr.data};\n    const resolve = {...res.resolve, ...curr._resolvedData};\n    return {params, data, resolve};\n  }, <any>{params: {}, data: {}, resolve: {}});\n}\n\n/**\n * @description\n *\n * Contains the information about a route associated with a component loaded in an\n * outlet at a particular moment in time. ActivatedRouteSnapshot can also be used to\n * traverse the router state tree.\n *\n * ```\n * @Component({templateUrl:'./my-component.html'})\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: string = route.snapshot.params.id;\n *     const url: string = route.snapshot.url.join('');\n *     const user = route.snapshot.data.user;\n *   }\n * }\n * ```\n *\n *\n */\nexport class ActivatedRouteSnapshot {\n  /** The configuration used to match this route **/\n  public readonly routeConfig: Route|null;\n  /** @internal **/\n  _urlSegment: UrlSegmentGroup;\n  /** @internal */\n  _lastPathIndex: number;\n  /** @internal */\n  _resolve: ResolveData;\n  /** @internal */\n  _resolvedData: Data;\n  /** @internal */\n  _routerState: RouterStateSnapshot;\n  /** @internal */\n  _paramMap: ParamMap;\n  /** @internal */\n  _queryParamMap: ParamMap;\n\n  /** @internal */\n  constructor(\n      /** The URL segments matched by this route */\n      public url: UrlSegment[],\n      /** The matrix parameters scoped to this route */\n      public params: Params,\n      /** The query parameters shared by all the routes */\n      public queryParams: Params,\n      /** The URL fragment shared by all the routes */\n      public fragment: string,\n      /** The static and resolved data of this route */\n      public data: Data,\n      /** The outlet name of the route */\n      public outlet: string,\n      /** The component of the route */\n      public component: Type<any>|string|null, routeConfig: Route|null, urlSegment: UrlSegmentGroup,\n      lastPathIndex: number, resolve: ResolveData) {\n    this.routeConfig = routeConfig;\n    this._urlSegment = urlSegment;\n    this._lastPathIndex = lastPathIndex;\n    this._resolve = resolve;\n  }\n\n  /** The root of the router state */\n  get root(): ActivatedRouteSnapshot { return this._routerState.root; }\n\n  /** The parent of this route in the router state tree */\n  get parent(): ActivatedRouteSnapshot|null { return this._routerState.parent(this); }\n\n  /** The first child of this route in the router state tree */\n  get firstChild(): ActivatedRouteSnapshot|null { return this._routerState.firstChild(this); }\n\n  /** The children of this route in the router state tree */\n  get children(): ActivatedRouteSnapshot[] { return this._routerState.children(this); }\n\n  /** The path from the root of the router state tree to this route */\n  get pathFromRoot(): ActivatedRouteSnapshot[] { return this._routerState.pathFromRoot(this); }\n\n  get paramMap(): ParamMap {\n    if (!this._paramMap) {\n      this._paramMap = convertToParamMap(this.params);\n    }\n    return this._paramMap;\n  }\n\n  get queryParamMap(): ParamMap {\n    if (!this._queryParamMap) {\n      this._queryParamMap = convertToParamMap(this.queryParams);\n    }\n    return this._queryParamMap;\n  }\n\n  toString(): string {\n    const url = this.url.map(segment => segment.toString()).join('/');\n    const matched = this.routeConfig ? this.routeConfig.path : '';\n    return `Route(url:'${url}', path:'${matched}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the state of the router at a moment in time.\n *\n * This is a tree of activated route snapshots. Every node in this tree knows about\n * the \"consumed\" URL segments, the extracted parameters, and the resolved data.\n *\n * ### Example\n *\n * ```\n * @Component({templateUrl:'template.html'})\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state: RouterState = router.routerState;\n *     const snapshot: RouterStateSnapshot = state.snapshot;\n *     const root: ActivatedRouteSnapshot = snapshot.root;\n *     const child = root.firstChild;\n *     const id: Observable<string> = child.params.map(p => p.id);\n *     //...\n *   }\n * }\n * ```\n *\n *\n */\nexport class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {\n  /** @internal */\n  constructor(\n      /** The url from which this snapshot was created */\n      public url: string, root: TreeNode<ActivatedRouteSnapshot>) {\n    super(root);\n    setRouterState(<RouterStateSnapshot>this, root);\n  }\n\n  toString(): string { return serializeNode(this._root); }\n}\n\nfunction setRouterState<U, T extends{_routerState: U}>(state: U, node: TreeNode<T>): void {\n  node.value._routerState = state;\n  node.children.forEach(c => setRouterState(state, c));\n}\n\nfunction serializeNode(node: TreeNode<ActivatedRouteSnapshot>): string {\n  const c = node.children.length > 0 ? ` { ${node.children.map(serializeNode).join(', ')} } ` : '';\n  return `${node.value}${c}`;\n}\n\n/**\n * The expectation is that the activate route is created with the right set of parameters.\n * So we push new values into the observables only when they are not the initial values.\n * And we detect that by checking if the snapshot field is set.\n */\nexport function advanceActivatedRoute(route: ActivatedRoute): void {\n  if (route.snapshot) {\n    const currentSnapshot = route.snapshot;\n    const nextSnapshot = route._futureSnapshot;\n    route.snapshot = nextSnapshot;\n    if (!shallowEqual(currentSnapshot.queryParams, nextSnapshot.queryParams)) {\n      (<any>route.queryParams).next(nextSnapshot.queryParams);\n    }\n    if (currentSnapshot.fragment !== nextSnapshot.fragment) {\n      (<any>route.fragment).next(nextSnapshot.fragment);\n    }\n    if (!shallowEqual(currentSnapshot.params, nextSnapshot.params)) {\n      (<any>route.params).next(nextSnapshot.params);\n    }\n    if (!shallowEqualArrays(currentSnapshot.url, nextSnapshot.url)) {\n      (<any>route.url).next(nextSnapshot.url);\n    }\n    if (!shallowEqual(currentSnapshot.data, nextSnapshot.data)) {\n      (<any>route.data).next(nextSnapshot.data);\n    }\n  } else {\n    route.snapshot = route._futureSnapshot;\n\n    // this is for resolved data\n    (<any>route.data).next(route._futureSnapshot.data);\n  }\n}\n\n\nexport function equalParamsAndUrlSegments(\n    a: ActivatedRouteSnapshot, b: ActivatedRouteSnapshot): boolean {\n  const equalUrlParams = shallowEqual(a.params, b.params) && equalSegments(a.url, b.url);\n  const parentsMismatch = !a.parent !== !b.parent;\n\n  return equalUrlParams && !parentsMismatch &&\n      (!a.parent || equalParamsAndUrlSegments(a.parent, b.parent !));\n}\n"]}
|
package/esm5/src/shared.js
CHANGED
|
@@ -85,4 +85,4 @@ export function defaultUrlMatcher(segments, segmentGroup, route) {
|
|
|
85
85
|
return { consumed: segments.slice(0, parts.length), posParams: posParams };
|
|
86
86
|
}
|
|
87
87
|
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../../../../../../packages/router/src/shared.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {Route, UrlMatchResult} from './config';\nimport {UrlSegment, UrlSegmentGroup} from './url_tree';\n\n\n/**\n * @description\n *\n * Name of the primary outlet.\n *\n *\n */\nexport const PRIMARY_OUTLET = 'primary';\n\n/**\n * A collection of parameters.\n *\n *\n */\nexport type Params = {\n  [key: string]: any\n};\n\n/**\n * Matrix and Query parameters.\n *\n * `ParamMap` makes it easier to work with parameters as they could have either a single value or\n * multiple value. Because this should be known by the user, calling `get` or `getAll` returns the\n * correct type (either `string` or `string[]`).\n *\n * The API is inspired by the URLSearchParams interface.\n * see https://developer.mozilla.org/en-US/docs/Web/API/URLSearchParams\n *\n *\n */\nexport interface ParamMap {\n  has(name: string): boolean;\n  /**\n   * Return a single value for the given parameter name:\n   * - the value when the parameter has a single value,\n   * - the first value if the parameter has multiple values,\n   * - `null` when there is no such parameter.\n   */\n  get(name: string): string|null;\n  /**\n   * Return an array of values for the given parameter name.\n   *\n   * If there is no such parameter, an empty array is returned.\n   */\n  getAll(name: string): string[];\n\n  /** Name of the parameters */\n  readonly keys: string[];\n}\n\nclass ParamsAsMap implements ParamMap {\n  private params: Params;\n\n  constructor(params: Params) { this.params = params || {}; }\n\n  has(name: string): boolean { return this.params.hasOwnProperty(name); }\n\n  get(name: string): string|null {\n    if (this.has(name)) {\n      const v = this.params[name];\n      return Array.isArray(v) ? v[0] : v;\n    }\n\n    return null;\n  }\n\n  getAll(name: string): string[] {\n    if (this.has(name)) {\n      const v = this.params[name];\n      return Array.isArray(v) ? v : [v];\n    }\n\n    return [];\n  }\n\n  get keys(): string[] { return Object.keys(this.params); }\n}\n\n/**\n * Convert a `Params` instance to a `ParamMap`.\n *\n *\n */\nexport function convertToParamMap(params: Params): ParamMap {\n  return new ParamsAsMap(params);\n}\n\nconst NAVIGATION_CANCELING_ERROR = 'ngNavigationCancelingError';\n\nexport function navigationCancelingError(message: string) {\n  const error = Error('NavigationCancelingError: ' + message);\n  (error as any)[NAVIGATION_CANCELING_ERROR] = true;\n  return error;\n}\n\nexport function isNavigationCancelingError(error: Error) {\n  return error && (error as any)[NAVIGATION_CANCELING_ERROR];\n}\n\n// Matches the route configuration (`route`) against the actual URL (`segments`).\nexport function defaultUrlMatcher(\n    segments: UrlSegment[], segmentGroup: UrlSegmentGroup, route: Route): UrlMatchResult|null {\n  const parts = route.path !.split('/');\n\n  if (parts.length > segments.length) {\n    // The actual URL is shorter than the config, no match\n    return null;\n  }\n\n  if (route.pathMatch === 'full' &&\n      (segmentGroup.hasChildren() || parts.length < segments.length)) {\n    // The config is longer than the actual URL but we are looking for a full match, return null\n    return null;\n  }\n\n  const posParams: {[key: string]: UrlSegment} = {};\n\n  // Check each config part against the actual URL\n  for (let index = 0; index < parts.length; index++) {\n    const part = parts[index];\n    const segment = segments[index];\n    const isParameter = part.startsWith(':');\n    if (isParameter) {\n      posParams[part.substring(1)] = segment;\n    } else if (part !== segment.path) {\n      // The actual URL part does not match the config, no match\n      return null;\n    }\n  }\n\n  return {consumed: segments.slice(0, parts.length), posParams};\n}\n"]}
|
|
@@ -12,33 +12,16 @@
|
|
|
12
12
|
*
|
|
13
13
|
* @experimental
|
|
14
14
|
*/
|
|
15
|
-
var /**
|
|
16
|
-
* @description
|
|
17
|
-
*
|
|
18
|
-
* Provides a way to migrate AngularJS applications to Angular.
|
|
19
|
-
*
|
|
20
|
-
* @experimental
|
|
21
|
-
*/
|
|
22
|
-
UrlHandlingStrategy = /** @class */ (function () {
|
|
15
|
+
var UrlHandlingStrategy = /** @class */ (function () {
|
|
23
16
|
function UrlHandlingStrategy() {
|
|
24
17
|
}
|
|
25
18
|
return UrlHandlingStrategy;
|
|
26
19
|
}());
|
|
27
|
-
/**
|
|
28
|
-
* @description
|
|
29
|
-
*
|
|
30
|
-
* Provides a way to migrate AngularJS applications to Angular.
|
|
31
|
-
*
|
|
32
|
-
* @experimental
|
|
33
|
-
*/
|
|
34
20
|
export { UrlHandlingStrategy };
|
|
35
21
|
/**
|
|
36
22
|
* @experimental
|
|
37
23
|
*/
|
|
38
|
-
var /**
|
|
39
|
-
* @experimental
|
|
40
|
-
*/
|
|
41
|
-
DefaultUrlHandlingStrategy = /** @class */ (function () {
|
|
24
|
+
var DefaultUrlHandlingStrategy = /** @class */ (function () {
|
|
42
25
|
function DefaultUrlHandlingStrategy() {
|
|
43
26
|
}
|
|
44
27
|
DefaultUrlHandlingStrategy.prototype.shouldProcessUrl = function (url) { return true; };
|
|
@@ -46,9 +29,6 @@ DefaultUrlHandlingStrategy = /** @class */ (function () {
|
|
|
46
29
|
DefaultUrlHandlingStrategy.prototype.merge = function (newUrlPart, wholeUrl) { return newUrlPart; };
|
|
47
30
|
return DefaultUrlHandlingStrategy;
|
|
48
31
|
}());
|
|
49
|
-
/**
|
|
50
|
-
* @experimental
|
|
51
|
-
*/
|
|
52
32
|
export { DefaultUrlHandlingStrategy };
|
|
53
33
|
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXJsX2hhbmRsaW5nX3N0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcm91dGVyL3NyYy91cmxfaGFuZGxpbmdfc3RyYXRlZ3kudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBSUg7Ozs7OztHQU1HO0FBQ0g7SUFBQTtJQXFCQSxDQUFDO0lBQUQsMEJBQUM7QUFBRCxDQUFDLEFBckJELElBcUJDOztBQUVEOztHQUVHO0FBQ0g7SUFBQTtJQUlBLENBQUM7SUFIQyxxREFBZ0IsR0FBaEIsVUFBaUIsR0FBWSxJQUFhLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ3hELDRDQUFPLEdBQVAsVUFBUSxHQUFZLElBQWEsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDOUMsMENBQUssR0FBTCxVQUFNLFVBQW1CLEVBQUUsUUFBaUIsSUFBYSxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztJQUMvRSxpQ0FBQztBQUFELENBQUMsQUFKRCxJQUlDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge1VybFRyZWV9IGZyb20gJy4vdXJsX3RyZWUnO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvblxuICpcbiAqIFByb3ZpZGVzIGEgd2F5IHRvIG1pZ3JhdGUgQW5ndWxhckpTIGFwcGxpY2F0aW9ucyB0byBBbmd1bGFyLlxuICpcbiAqIEBleHBlcmltZW50YWxcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFVybEhhbmRsaW5nU3RyYXRlZ3kge1xuICAvKipcbiAgICogVGVsbHMgdGhlIHJvdXRlciBpZiB0aGlzIFVSTCBzaG91bGQgYmUgcHJvY2Vzc2VkLlxuICAgKlxuICAgKiBXaGVuIGl0IHJldHVybnMgdHJ1ZSwgdGhlIHJvdXRlciB3aWxsIGV4ZWN1dGUgdGhlIHJlZ3VsYXIgbmF2aWdhdGlvbi5cbiAgICogV2hlbiBpdCByZXR1cm5zIGZhbHNlLCB0aGUgcm91dGVyIHdpbGwgc2V0IHRoZSByb3V0ZXIgc3RhdGUgdG8gYW4gZW1wdHkgc3RhdGUuXG4gICAqIEFzIGEgcmVzdWx0LCBhbGwgdGhlIGFjdGl2ZSBjb21wb25lbnRzIHdpbGwgYmUgZGVzdHJveWVkLlxuICAgKlxuICAgKi9cbiAgYWJzdHJhY3Qgc2hvdWxkUHJvY2Vzc1VybCh1cmw6IFVybFRyZWUpOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBFeHRyYWN0cyB0aGUgcGFydCBvZiB0aGUgVVJMIHRoYXQgc2hvdWxkIGJlIGhhbmRsZWQgYnkgdGhlIHJvdXRlci5cbiAgICogVGhlIHJlc3Qgb2YgdGhlIFVSTCB3aWxsIHJlbWFpbiB1bnRvdWNoZWQuXG4gICAqL1xuICBhYnN0cmFjdCBleHRyYWN0KHVybDogVXJsVHJlZSk6IFVybFRyZWU7XG5cbiAgLyoqXG4gICAqIE1lcmdlcyB0aGUgVVJMIGZyYWdtZW50IHdpdGggdGhlIHJlc3Qgb2YgdGhlIFVSTC5cbiAgICovXG4gIGFic3RyYWN0IG1lcmdlKG5ld1VybFBhcnQ6IFVybFRyZWUsIHJhd1VybDogVXJsVHJlZSk6IFVybFRyZWU7XG59XG5cbi8qKlxuICogQGV4cGVyaW1lbnRhbFxuICovXG5leHBvcnQgY2xhc3MgRGVmYXVsdFVybEhhbmRsaW5nU3RyYXRlZ3kgaW1wbGVtZW50cyBVcmxIYW5kbGluZ1N0cmF0ZWd5IHtcbiAgc2hvdWxkUHJvY2Vzc1VybCh1cmw6IFVybFRyZWUpOiBib29sZWFuIHsgcmV0dXJuIHRydWU7IH1cbiAgZXh0cmFjdCh1cmw6IFVybFRyZWUpOiBVcmxUcmVlIHsgcmV0dXJuIHVybDsgfVxuICBtZXJnZShuZXdVcmxQYXJ0OiBVcmxUcmVlLCB3aG9sZVVybDogVXJsVHJlZSk6IFVybFRyZWUgeyByZXR1cm4gbmV3VXJsUGFydDsgfVxufSJdfQ==
|