@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.
Files changed (84) hide show
  1. package/bundles/router-testing.umd.js +21 -15
  2. package/bundles/router-testing.umd.js.map +1 -1
  3. package/bundles/router-testing.umd.min.js +2 -2
  4. package/bundles/router-testing.umd.min.js.map +1 -1
  5. package/bundles/router-upgrade.umd.js +10 -1
  6. package/bundles/router-upgrade.umd.js.map +1 -1
  7. package/bundles/router-upgrade.umd.min.js +1 -1
  8. package/bundles/router-upgrade.umd.min.js.map +1 -1
  9. package/bundles/router.umd.js +348 -706
  10. package/bundles/router.umd.js.map +1 -1
  11. package/bundles/router.umd.min.js +18 -18
  12. package/bundles/router.umd.min.js.map +1 -1
  13. package/esm2015/index.js +2 -2
  14. package/esm2015/public_api.js +2 -2
  15. package/esm2015/src/components/empty_outlet.js +28 -0
  16. package/esm2015/src/config.js +13 -6
  17. package/esm2015/src/directives/router_link.js +29 -47
  18. package/esm2015/src/directives/router_link_active.js +9 -18
  19. package/esm2015/src/directives/router_outlet.js +8 -17
  20. package/esm2015/src/index.js +2 -2
  21. package/esm2015/src/private_export.js +2 -1
  22. package/esm2015/src/router.js +4 -4
  23. package/esm2015/src/router_config_loader.js +3 -3
  24. package/esm2015/src/router_module.js +11 -22
  25. package/esm2015/src/router_preloader.js +6 -13
  26. package/esm2015/src/version.js +1 -1
  27. package/esm2015/testing/src/router_testing_module.js +2 -20
  28. package/esm5/index.js +5 -1
  29. package/esm5/public_api.js +6 -1
  30. package/esm5/src/apply_redirects.js +14 -26
  31. package/esm5/src/components/empty_outlet.js +28 -0
  32. package/esm5/src/config.js +15 -6
  33. package/esm5/src/create_router_state.js +1 -1
  34. package/esm5/src/create_url_tree.js +2 -4
  35. package/esm5/src/directives/router_link.js +33 -33
  36. package/esm5/src/directives/router_link_active.js +9 -9
  37. package/esm5/src/directives/router_outlet.js +10 -22
  38. package/esm5/src/events.js +86 -340
  39. package/esm5/src/index.js +1 -1
  40. package/esm5/src/interfaces.js +1 -1
  41. package/esm5/src/pre_activation.js +12 -68
  42. package/esm5/src/private_export.js +2 -1
  43. package/esm5/src/recognize.js +5 -5
  44. package/esm5/src/route_reuse_strategy.js +3 -23
  45. package/esm5/src/router.js +49 -311
  46. package/esm5/src/router_config_loader.js +5 -4
  47. package/esm5/src/router_module.js +15 -44
  48. package/esm5/src/router_outlet_context.js +6 -46
  49. package/esm5/src/router_preloader.js +10 -71
  50. package/esm5/src/router_state.js +49 -231
  51. package/esm5/src/shared.js +1 -1
  52. package/esm5/src/url_handling_strategy.js +3 -23
  53. package/esm5/src/url_tree.js +33 -239
  54. package/esm5/src/utils/collection.js +1 -1
  55. package/esm5/src/utils/tree.js +6 -36
  56. package/esm5/src/version.js +7 -2
  57. package/esm5/testing/index.js +5 -1
  58. package/esm5/testing/public_api.js +6 -1
  59. package/esm5/testing/src/router_testing_module.js +7 -15
  60. package/esm5/testing/src/testing.js +6 -1
  61. package/esm5/upgrade/index.js +5 -1
  62. package/esm5/upgrade/public_api.js +6 -1
  63. package/esm5/upgrade/src/upgrade.js +1 -1
  64. package/fesm2015/router.js +100 -64
  65. package/fesm2015/router.js.map +1 -1
  66. package/fesm2015/testing.js +2 -4
  67. package/fesm2015/testing.js.map +1 -1
  68. package/fesm2015/upgrade.js +1 -1
  69. package/fesm2015/upgrade.js.map +1 -1
  70. package/fesm5/router.js +349 -708
  71. package/fesm5/router.js.map +1 -1
  72. package/fesm5/testing.js +21 -15
  73. package/fesm5/testing.js.map +1 -1
  74. package/fesm5/upgrade.js +10 -1
  75. package/fesm5/upgrade.js.map +1 -1
  76. package/package.json +4 -4
  77. package/router.metadata.json +1 -1
  78. package/src/components/empty_outlet.d.ts +11 -0
  79. package/src/config.d.ts +4 -1
  80. package/src/private_export.d.ts +1 -0
  81. package/testing.d.ts +0 -5
  82. package/testing.metadata.json +1 -1
  83. package/upgrade.d.ts +0 -5
  84. package/upgrade.metadata.json +1 -1
@@ -26,55 +26,17 @@ import * as tslib_1 from "tslib";
26
26
  *
27
27
  * @experimental
28
28
  */
29
- var /**
30
- * @description
31
- *
32
- * Base for events the Router goes through, as opposed to events tied to a specific
33
- * Route. `RouterEvent`s will only be fired one time for any given navigation.
34
- *
35
- * Example:
36
- *
37
- * ```
38
- * class MyService {
39
- * constructor(public router: Router, logger: Logger) {
40
- * router.events.filter(e => e instanceof RouterEvent).subscribe(e => {
41
- * logger.log(e.id, e.url);
42
- * });
43
- * }
44
- * }
45
- * ```
46
- *
47
- * @experimental
48
- */
49
- RouterEvent = /** @class */ (function () {
50
- function RouterEvent(/** @docsNotRequired */
51
- id, /** @docsNotRequired */
29
+ var RouterEvent = /** @class */ (function () {
30
+ function RouterEvent(
31
+ /** @docsNotRequired */
32
+ id,
33
+ /** @docsNotRequired */
52
34
  url) {
53
35
  this.id = id;
54
36
  this.url = url;
55
37
  }
56
38
  return RouterEvent;
57
39
  }());
58
- /**
59
- * @description
60
- *
61
- * Base for events the Router goes through, as opposed to events tied to a specific
62
- * Route. `RouterEvent`s will only be fired one time for any given navigation.
63
- *
64
- * Example:
65
- *
66
- * ```
67
- * class MyService {
68
- * constructor(public router: Router, logger: Logger) {
69
- * router.events.filter(e => e instanceof RouterEvent).subscribe(e => {
70
- * logger.log(e.id, e.url);
71
- * });
72
- * }
73
- * }
74
- * ```
75
- *
76
- * @experimental
77
- */
78
40
  export { RouterEvent };
79
41
  /**
80
42
  * @description
@@ -83,22 +45,15 @@ export { RouterEvent };
83
45
  *
84
46
  *
85
47
  */
86
- var /**
87
- * @description
88
- *
89
- * Represents an event triggered when a navigation starts.
90
- *
91
- *
92
- */
93
- NavigationStart = /** @class */ (function (_super) {
48
+ var NavigationStart = /** @class */ (function (_super) {
94
49
  tslib_1.__extends(NavigationStart, _super);
95
- function NavigationStart(/** @docsNotRequired */
50
+ function NavigationStart(
96
51
  /** @docsNotRequired */
97
- id, /** @docsNotRequired */
52
+ id,
98
53
  /** @docsNotRequired */
99
- url, /** @docsNotRequired */
54
+ url,
100
55
  /** @docsNotRequired */
101
- navigationTrigger, /** @docsNotRequired */
56
+ navigationTrigger,
102
57
  /** @docsNotRequired */
103
58
  restoredState) {
104
59
  /** @docsNotRequired */
@@ -111,18 +66,9 @@ NavigationStart = /** @class */ (function (_super) {
111
66
  return _this;
112
67
  }
113
68
  /** @docsNotRequired */
114
- /** @docsNotRequired */
115
- NavigationStart.prototype.toString = /** @docsNotRequired */
116
- function () { return "NavigationStart(id: " + this.id + ", url: '" + this.url + "')"; };
69
+ NavigationStart.prototype.toString = function () { return "NavigationStart(id: " + this.id + ", url: '" + this.url + "')"; };
117
70
  return NavigationStart;
118
71
  }(RouterEvent));
119
- /**
120
- * @description
121
- *
122
- * Represents an event triggered when a navigation starts.
123
- *
124
- *
125
- */
126
72
  export { NavigationStart };
127
73
  /**
128
74
  * @description
@@ -131,40 +77,25 @@ export { NavigationStart };
131
77
  *
132
78
  *
133
79
  */
134
- var /**
135
- * @description
136
- *
137
- * Represents an event triggered when a navigation ends successfully.
138
- *
139
- *
140
- */
141
- NavigationEnd = /** @class */ (function (_super) {
80
+ var NavigationEnd = /** @class */ (function (_super) {
142
81
  tslib_1.__extends(NavigationEnd, _super);
143
- function NavigationEnd(/** @docsNotRequired */
82
+ function NavigationEnd(
83
+ /** @docsNotRequired */
84
+ id,
144
85
  /** @docsNotRequired */
145
- id, /** @docsNotRequired */
86
+ url,
146
87
  /** @docsNotRequired */
147
- url, /** @docsNotRequired */
148
88
  urlAfterRedirects) {
149
89
  var _this = _super.call(this, id, url) || this;
150
90
  _this.urlAfterRedirects = urlAfterRedirects;
151
91
  return _this;
152
92
  }
153
93
  /** @docsNotRequired */
154
- /** @docsNotRequired */
155
- NavigationEnd.prototype.toString = /** @docsNotRequired */
156
- function () {
94
+ NavigationEnd.prototype.toString = function () {
157
95
  return "NavigationEnd(id: " + this.id + ", url: '" + this.url + "', urlAfterRedirects: '" + this.urlAfterRedirects + "')";
158
96
  };
159
97
  return NavigationEnd;
160
98
  }(RouterEvent));
161
- /**
162
- * @description
163
- *
164
- * Represents an event triggered when a navigation ends successfully.
165
- *
166
- *
167
- */
168
99
  export { NavigationEnd };
169
100
  /**
170
101
  * @description
@@ -173,38 +104,23 @@ export { NavigationEnd };
173
104
  *
174
105
  *
175
106
  */
176
- var /**
177
- * @description
178
- *
179
- * Represents an event triggered when a navigation is canceled.
180
- *
181
- *
182
- */
183
- NavigationCancel = /** @class */ (function (_super) {
107
+ var NavigationCancel = /** @class */ (function (_super) {
184
108
  tslib_1.__extends(NavigationCancel, _super);
185
- function NavigationCancel(/** @docsNotRequired */
109
+ function NavigationCancel(
110
+ /** @docsNotRequired */
111
+ id,
186
112
  /** @docsNotRequired */
187
- id, /** @docsNotRequired */
113
+ url,
188
114
  /** @docsNotRequired */
189
- url, /** @docsNotRequired */
190
115
  reason) {
191
116
  var _this = _super.call(this, id, url) || this;
192
117
  _this.reason = reason;
193
118
  return _this;
194
119
  }
195
120
  /** @docsNotRequired */
196
- /** @docsNotRequired */
197
- NavigationCancel.prototype.toString = /** @docsNotRequired */
198
- function () { return "NavigationCancel(id: " + this.id + ", url: '" + this.url + "')"; };
121
+ NavigationCancel.prototype.toString = function () { return "NavigationCancel(id: " + this.id + ", url: '" + this.url + "')"; };
199
122
  return NavigationCancel;
200
123
  }(RouterEvent));
201
- /**
202
- * @description
203
- *
204
- * Represents an event triggered when a navigation is canceled.
205
- *
206
- *
207
- */
208
124
  export { NavigationCancel };
209
125
  /**
210
126
  * @description
@@ -213,40 +129,25 @@ export { NavigationCancel };
213
129
  *
214
130
  *
215
131
  */
216
- var /**
217
- * @description
218
- *
219
- * Represents an event triggered when a navigation fails due to an unexpected error.
220
- *
221
- *
222
- */
223
- NavigationError = /** @class */ (function (_super) {
132
+ var NavigationError = /** @class */ (function (_super) {
224
133
  tslib_1.__extends(NavigationError, _super);
225
- function NavigationError(/** @docsNotRequired */
134
+ function NavigationError(
226
135
  /** @docsNotRequired */
227
- id, /** @docsNotRequired */
136
+ id,
137
+ /** @docsNotRequired */
138
+ url,
228
139
  /** @docsNotRequired */
229
- url, /** @docsNotRequired */
230
140
  error) {
231
141
  var _this = _super.call(this, id, url) || this;
232
142
  _this.error = error;
233
143
  return _this;
234
144
  }
235
145
  /** @docsNotRequired */
236
- /** @docsNotRequired */
237
- NavigationError.prototype.toString = /** @docsNotRequired */
238
- function () {
146
+ NavigationError.prototype.toString = function () {
239
147
  return "NavigationError(id: " + this.id + ", url: '" + this.url + "', error: " + this.error + ")";
240
148
  };
241
149
  return NavigationError;
242
150
  }(RouterEvent));
243
- /**
244
- * @description
245
- *
246
- * Represents an event triggered when a navigation fails due to an unexpected error.
247
- *
248
- *
249
- */
250
151
  export { NavigationError };
251
152
  /**
252
153
  * @description
@@ -255,21 +156,16 @@ export { NavigationError };
255
156
  *
256
157
  *
257
158
  */
258
- var /**
259
- * @description
260
- *
261
- * Represents an event triggered when routes are recognized.
262
- *
263
- *
264
- */
265
- RoutesRecognized = /** @class */ (function (_super) {
159
+ var RoutesRecognized = /** @class */ (function (_super) {
266
160
  tslib_1.__extends(RoutesRecognized, _super);
267
- function RoutesRecognized(/** @docsNotRequired */
161
+ function RoutesRecognized(
162
+ /** @docsNotRequired */
163
+ id,
164
+ /** @docsNotRequired */
165
+ url,
268
166
  /** @docsNotRequired */
269
- id, /** @docsNotRequired */
167
+ urlAfterRedirects,
270
168
  /** @docsNotRequired */
271
- url, /** @docsNotRequired */
272
- urlAfterRedirects, /** @docsNotRequired */
273
169
  state) {
274
170
  var _this = _super.call(this, id, url) || this;
275
171
  _this.urlAfterRedirects = urlAfterRedirects;
@@ -277,20 +173,11 @@ RoutesRecognized = /** @class */ (function (_super) {
277
173
  return _this;
278
174
  }
279
175
  /** @docsNotRequired */
280
- /** @docsNotRequired */
281
- RoutesRecognized.prototype.toString = /** @docsNotRequired */
282
- function () {
176
+ RoutesRecognized.prototype.toString = function () {
283
177
  return "RoutesRecognized(id: " + this.id + ", url: '" + this.url + "', urlAfterRedirects: '" + this.urlAfterRedirects + "', state: " + this.state + ")";
284
178
  };
285
179
  return RoutesRecognized;
286
180
  }(RouterEvent));
287
- /**
288
- * @description
289
- *
290
- * Represents an event triggered when routes are recognized.
291
- *
292
- *
293
- */
294
181
  export { RoutesRecognized };
295
182
  /**
296
183
  * @description
@@ -299,21 +186,16 @@ export { RoutesRecognized };
299
186
  *
300
187
  * @experimental
301
188
  */
302
- var /**
303
- * @description
304
- *
305
- * Represents the start of the Guard phase of routing.
306
- *
307
- * @experimental
308
- */
309
- GuardsCheckStart = /** @class */ (function (_super) {
189
+ var GuardsCheckStart = /** @class */ (function (_super) {
310
190
  tslib_1.__extends(GuardsCheckStart, _super);
311
- function GuardsCheckStart(/** @docsNotRequired */
191
+ function GuardsCheckStart(
312
192
  /** @docsNotRequired */
313
- id, /** @docsNotRequired */
193
+ id,
194
+ /** @docsNotRequired */
195
+ url,
196
+ /** @docsNotRequired */
197
+ urlAfterRedirects,
314
198
  /** @docsNotRequired */
315
- url, /** @docsNotRequired */
316
- urlAfterRedirects, /** @docsNotRequired */
317
199
  state) {
318
200
  var _this = _super.call(this, id, url) || this;
319
201
  _this.urlAfterRedirects = urlAfterRedirects;
@@ -325,13 +207,6 @@ GuardsCheckStart = /** @class */ (function (_super) {
325
207
  };
326
208
  return GuardsCheckStart;
327
209
  }(RouterEvent));
328
- /**
329
- * @description
330
- *
331
- * Represents the start of the Guard phase of routing.
332
- *
333
- * @experimental
334
- */
335
210
  export { GuardsCheckStart };
336
211
  /**
337
212
  * @description
@@ -340,22 +215,18 @@ export { GuardsCheckStart };
340
215
  *
341
216
  * @experimental
342
217
  */
343
- var /**
344
- * @description
345
- *
346
- * Represents the end of the Guard phase of routing.
347
- *
348
- * @experimental
349
- */
350
- GuardsCheckEnd = /** @class */ (function (_super) {
218
+ var GuardsCheckEnd = /** @class */ (function (_super) {
351
219
  tslib_1.__extends(GuardsCheckEnd, _super);
352
- function GuardsCheckEnd(/** @docsNotRequired */
220
+ function GuardsCheckEnd(
221
+ /** @docsNotRequired */
222
+ id,
223
+ /** @docsNotRequired */
224
+ url,
353
225
  /** @docsNotRequired */
354
- id, /** @docsNotRequired */
226
+ urlAfterRedirects,
227
+ /** @docsNotRequired */
228
+ state,
355
229
  /** @docsNotRequired */
356
- url, /** @docsNotRequired */
357
- urlAfterRedirects, /** @docsNotRequired */
358
- state, /** @docsNotRequired */
359
230
  shouldActivate) {
360
231
  var _this = _super.call(this, id, url) || this;
361
232
  _this.urlAfterRedirects = urlAfterRedirects;
@@ -368,13 +239,6 @@ GuardsCheckEnd = /** @class */ (function (_super) {
368
239
  };
369
240
  return GuardsCheckEnd;
370
241
  }(RouterEvent));
371
- /**
372
- * @description
373
- *
374
- * Represents the end of the Guard phase of routing.
375
- *
376
- * @experimental
377
- */
378
242
  export { GuardsCheckEnd };
379
243
  /**
380
244
  * @description
@@ -386,24 +250,16 @@ export { GuardsCheckEnd };
386
250
  *
387
251
  * @experimental
388
252
  */
389
- var /**
390
- * @description
391
- *
392
- * Represents the start of the Resolve phase of routing. The timing of this
393
- * event may change, thus it's experimental. In the current iteration it will run
394
- * in the "resolve" phase whether there's things to resolve or not. In the future this
395
- * behavior may change to only run when there are things to be resolved.
396
- *
397
- * @experimental
398
- */
399
- ResolveStart = /** @class */ (function (_super) {
253
+ var ResolveStart = /** @class */ (function (_super) {
400
254
  tslib_1.__extends(ResolveStart, _super);
401
- function ResolveStart(/** @docsNotRequired */
255
+ function ResolveStart(
256
+ /** @docsNotRequired */
257
+ id,
402
258
  /** @docsNotRequired */
403
- id, /** @docsNotRequired */
259
+ url,
260
+ /** @docsNotRequired */
261
+ urlAfterRedirects,
404
262
  /** @docsNotRequired */
405
- url, /** @docsNotRequired */
406
- urlAfterRedirects, /** @docsNotRequired */
407
263
  state) {
408
264
  var _this = _super.call(this, id, url) || this;
409
265
  _this.urlAfterRedirects = urlAfterRedirects;
@@ -415,16 +271,6 @@ ResolveStart = /** @class */ (function (_super) {
415
271
  };
416
272
  return ResolveStart;
417
273
  }(RouterEvent));
418
- /**
419
- * @description
420
- *
421
- * Represents the start of the Resolve phase of routing. The timing of this
422
- * event may change, thus it's experimental. In the current iteration it will run
423
- * in the "resolve" phase whether there's things to resolve or not. In the future this
424
- * behavior may change to only run when there are things to be resolved.
425
- *
426
- * @experimental
427
- */
428
274
  export { ResolveStart };
429
275
  /**
430
276
  * @description
@@ -434,22 +280,16 @@ export { ResolveStart };
434
280
  *
435
281
  * @experimental
436
282
  */
437
- var /**
438
- * @description
439
- *
440
- * Represents the end of the Resolve phase of routing. See note on
441
- * `ResolveStart` for use of this experimental API.
442
- *
443
- * @experimental
444
- */
445
- ResolveEnd = /** @class */ (function (_super) {
283
+ var ResolveEnd = /** @class */ (function (_super) {
446
284
  tslib_1.__extends(ResolveEnd, _super);
447
- function ResolveEnd(/** @docsNotRequired */
285
+ function ResolveEnd(
286
+ /** @docsNotRequired */
287
+ id,
288
+ /** @docsNotRequired */
289
+ url,
448
290
  /** @docsNotRequired */
449
- id, /** @docsNotRequired */
291
+ urlAfterRedirects,
450
292
  /** @docsNotRequired */
451
- url, /** @docsNotRequired */
452
- urlAfterRedirects, /** @docsNotRequired */
453
293
  state) {
454
294
  var _this = _super.call(this, id, url) || this;
455
295
  _this.urlAfterRedirects = urlAfterRedirects;
@@ -461,14 +301,6 @@ ResolveEnd = /** @class */ (function (_super) {
461
301
  };
462
302
  return ResolveEnd;
463
303
  }(RouterEvent));
464
- /**
465
- * @description
466
- *
467
- * Represents the end of the Resolve phase of routing. See note on
468
- * `ResolveStart` for use of this experimental API.
469
- *
470
- * @experimental
471
- */
472
304
  export { ResolveEnd };
473
305
  /**
474
306
  * @description
@@ -477,28 +309,15 @@ export { ResolveEnd };
477
309
  *
478
310
  * @experimental
479
311
  */
480
- var /**
481
- * @description
482
- *
483
- * Represents an event triggered before lazy loading a route config.
484
- *
485
- * @experimental
486
- */
487
- RouteConfigLoadStart = /** @class */ (function () {
488
- function RouteConfigLoadStart(/** @docsNotRequired */
312
+ var RouteConfigLoadStart = /** @class */ (function () {
313
+ function RouteConfigLoadStart(
314
+ /** @docsNotRequired */
489
315
  route) {
490
316
  this.route = route;
491
317
  }
492
318
  RouteConfigLoadStart.prototype.toString = function () { return "RouteConfigLoadStart(path: " + this.route.path + ")"; };
493
319
  return RouteConfigLoadStart;
494
320
  }());
495
- /**
496
- * @description
497
- *
498
- * Represents an event triggered before lazy loading a route config.
499
- *
500
- * @experimental
501
- */
502
321
  export { RouteConfigLoadStart };
503
322
  /**
504
323
  * @description
@@ -507,28 +326,15 @@ export { RouteConfigLoadStart };
507
326
  *
508
327
  * @experimental
509
328
  */
510
- var /**
511
- * @description
512
- *
513
- * Represents an event triggered when a route has been lazy loaded.
514
- *
515
- * @experimental
516
- */
517
- RouteConfigLoadEnd = /** @class */ (function () {
518
- function RouteConfigLoadEnd(/** @docsNotRequired */
329
+ var RouteConfigLoadEnd = /** @class */ (function () {
330
+ function RouteConfigLoadEnd(
331
+ /** @docsNotRequired */
519
332
  route) {
520
333
  this.route = route;
521
334
  }
522
335
  RouteConfigLoadEnd.prototype.toString = function () { return "RouteConfigLoadEnd(path: " + this.route.path + ")"; };
523
336
  return RouteConfigLoadEnd;
524
337
  }());
525
- /**
526
- * @description
527
- *
528
- * Represents an event triggered when a route has been lazy loaded.
529
- *
530
- * @experimental
531
- */
532
338
  export { RouteConfigLoadEnd };
533
339
  /**
534
340
  * @description
@@ -538,16 +344,9 @@ export { RouteConfigLoadEnd };
538
344
  *
539
345
  * @experimental
540
346
  */
541
- var /**
542
- * @description
543
- *
544
- * Represents the start of end of the Resolve phase of routing. See note on
545
- * `ChildActivationEnd` for use of this experimental API.
546
- *
547
- * @experimental
548
- */
549
- ChildActivationStart = /** @class */ (function () {
550
- function ChildActivationStart(/** @docsNotRequired */
347
+ var ChildActivationStart = /** @class */ (function () {
348
+ function ChildActivationStart(
349
+ /** @docsNotRequired */
551
350
  snapshot) {
552
351
  this.snapshot = snapshot;
553
352
  }
@@ -557,14 +356,6 @@ ChildActivationStart = /** @class */ (function () {
557
356
  };
558
357
  return ChildActivationStart;
559
358
  }());
560
- /**
561
- * @description
562
- *
563
- * Represents the start of end of the Resolve phase of routing. See note on
564
- * `ChildActivationEnd` for use of this experimental API.
565
- *
566
- * @experimental
567
- */
568
359
  export { ChildActivationStart };
569
360
  /**
570
361
  * @description
@@ -574,16 +365,9 @@ export { ChildActivationStart };
574
365
  *
575
366
  * @experimental
576
367
  */
577
- var /**
578
- * @description
579
- *
580
- * Represents the start of end of the Resolve phase of routing. See note on
581
- * `ChildActivationStart` for use of this experimental API.
582
- *
583
- * @experimental
584
- */
585
- ChildActivationEnd = /** @class */ (function () {
586
- function ChildActivationEnd(/** @docsNotRequired */
368
+ var ChildActivationEnd = /** @class */ (function () {
369
+ function ChildActivationEnd(
370
+ /** @docsNotRequired */
587
371
  snapshot) {
588
372
  this.snapshot = snapshot;
589
373
  }
@@ -593,14 +377,6 @@ ChildActivationEnd = /** @class */ (function () {
593
377
  };
594
378
  return ChildActivationEnd;
595
379
  }());
596
- /**
597
- * @description
598
- *
599
- * Represents the start of end of the Resolve phase of routing. See note on
600
- * `ChildActivationStart` for use of this experimental API.
601
- *
602
- * @experimental
603
- */
604
380
  export { ChildActivationEnd };
605
381
  /**
606
382
  * @description
@@ -610,16 +386,9 @@ export { ChildActivationEnd };
610
386
  *
611
387
  * @experimental
612
388
  */
613
- var /**
614
- * @description
615
- *
616
- * Represents the start of end of the Resolve phase of routing. See note on
617
- * `ActivationEnd` for use of this experimental API.
618
- *
619
- * @experimental
620
- */
621
- ActivationStart = /** @class */ (function () {
622
- function ActivationStart(/** @docsNotRequired */
389
+ var ActivationStart = /** @class */ (function () {
390
+ function ActivationStart(
391
+ /** @docsNotRequired */
623
392
  snapshot) {
624
393
  this.snapshot = snapshot;
625
394
  }
@@ -629,14 +398,6 @@ ActivationStart = /** @class */ (function () {
629
398
  };
630
399
  return ActivationStart;
631
400
  }());
632
- /**
633
- * @description
634
- *
635
- * Represents the start of end of the Resolve phase of routing. See note on
636
- * `ActivationEnd` for use of this experimental API.
637
- *
638
- * @experimental
639
- */
640
401
  export { ActivationStart };
641
402
  /**
642
403
  * @description
@@ -646,16 +407,9 @@ export { ActivationStart };
646
407
  *
647
408
  * @experimental
648
409
  */
649
- var /**
650
- * @description
651
- *
652
- * Represents the start of end of the Resolve phase of routing. See note on
653
- * `ActivationStart` for use of this experimental API.
654
- *
655
- * @experimental
656
- */
657
- ActivationEnd = /** @class */ (function () {
658
- function ActivationEnd(/** @docsNotRequired */
410
+ var ActivationEnd = /** @class */ (function () {
411
+ function ActivationEnd(
412
+ /** @docsNotRequired */
659
413
  snapshot) {
660
414
  this.snapshot = snapshot;
661
415
  }
@@ -665,14 +419,6 @@ ActivationEnd = /** @class */ (function () {
665
419
  };
666
420
  return ActivationEnd;
667
421
  }());
668
- /**
669
- * @description
670
- *
671
- * Represents the start of end of the Resolve phase of routing. See note on
672
- * `ActivationStart` for use of this experimental API.
673
- *
674
- * @experimental
675
- */
676
422
  export { ActivationEnd };
677
423
 
678
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../../../../../../../packages/router/src/events.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} from './config';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\n\n/**\n * @description\n *\n * Identifies the trigger of the navigation.\n *\n * * 'imperative'--triggered by `router.navigateByUrl` or `router.navigate`.\n * * 'popstate'--triggered by a popstate event\n * * 'hashchange'--triggered by a hashchange event\n *\n * @experimental\n */\nexport type NavigationTrigger = 'imperative' | 'popstate' | 'hashchange';\n\n/**\n * @description\n *\n * Base for events the Router goes through, as opposed to events tied to a specific\n * Route. `RouterEvent`s will only be fired one time for any given navigation.\n *\n * Example:\n *\n * ```\n * class MyService {\n *   constructor(public router: Router, logger: Logger) {\n *     router.events.filter(e => e instanceof RouterEvent).subscribe(e => {\n *       logger.log(e.id, e.url);\n *     });\n *   }\n * }\n * ```\n *\n * @experimental\n */\nexport class RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      public id: number,\n      /** @docsNotRequired */\n      public url: string) {}\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation starts.\n *\n *\n */\nexport class NavigationStart extends RouterEvent {\n  /**\n   * Identifies the trigger of the navigation.\n   *\n   * * 'imperative'--triggered by `router.navigateByUrl` or `router.navigate`.\n   * * 'popstate'--triggered by a popstate event\n   * * 'hashchange'--triggered by a hashchange event\n   */\n  navigationTrigger?: 'imperative'|'popstate'|'hashchange';\n\n  /**\n   * This contains the navigation id that pushed the history record that the router navigates\n   * back to. This is not null only when the navigation is triggered by a popstate event.\n   *\n   * The router assigns a navigationId to every router transition/navigation. Even when the user\n   * clicks on the back button in the browser, a new navigation id will be created. So from\n   * the perspective of the router, the router never \"goes back\". By using the `restoredState`\n   * and its navigationId, you can implement behavior that differentiates between creating new\n   * states\n   * and popstate events. In the latter case you can restore some remembered state (e.g., scroll\n   * position).\n   */\n  restoredState?: {navigationId: number}|null;\n\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      navigationTrigger: 'imperative'|'popstate'|'hashchange' = 'imperative',\n      /** @docsNotRequired */\n      restoredState: {navigationId: number}|null = null) {\n    super(id, url);\n    this.navigationTrigger = navigationTrigger;\n    this.restoredState = restoredState;\n  }\n\n  /** @docsNotRequired */\n  toString(): string { return `NavigationStart(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation ends successfully.\n *\n *\n */\nexport class NavigationEnd extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string {\n    return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation is canceled.\n *\n *\n */\nexport class NavigationCancel extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public reason: string) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string { return `NavigationCancel(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation fails due to an unexpected error.\n *\n *\n */\nexport class NavigationError extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public error: any) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string {\n    return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when routes are recognized.\n *\n *\n */\nexport class RoutesRecognized extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string {\n    return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of the Guard phase of routing.\n *\n * @experimental\n */\nexport class GuardsCheckStart extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `GuardsCheckStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the end of the Guard phase of routing.\n *\n * @experimental\n */\nexport class GuardsCheckEnd extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot,\n      /** @docsNotRequired */\n      public shouldActivate: boolean) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `GuardsCheckEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state}, shouldActivate: ${this.shouldActivate})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of the Resolve phase of routing. The timing of this\n * event may change, thus it's experimental. In the current iteration it will run\n * in the \"resolve\" phase whether there's things to resolve or not. In the future this\n * behavior may change to only run when there are things to be resolved.\n *\n * @experimental\n */\nexport class ResolveStart extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `ResolveStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the end of the Resolve phase of routing. See note on\n * `ResolveStart` for use of this experimental API.\n *\n * @experimental\n */\nexport class ResolveEnd extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `ResolveEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents an event triggered before lazy loading a route config.\n *\n * @experimental\n */\nexport class RouteConfigLoadStart {\n  constructor(\n      /** @docsNotRequired */\n      public route: Route) {}\n  toString(): string { return `RouteConfigLoadStart(path: ${this.route.path})`; }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a route has been lazy loaded.\n *\n * @experimental\n */\nexport class RouteConfigLoadEnd {\n  constructor(\n      /** @docsNotRequired */\n      public route: Route) {}\n  toString(): string { return `RouteConfigLoadEnd(path: ${this.route.path})`; }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ChildActivationEnd` for use of this experimental API.\n *\n * @experimental\n */\nexport class ChildActivationStart {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ChildActivationStart(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ChildActivationStart` for use of this experimental API.\n *\n * @experimental\n */\nexport class ChildActivationEnd {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ChildActivationEnd(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ActivationEnd` for use of this experimental API.\n *\n * @experimental\n */\nexport class ActivationStart {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ActivationStart(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ActivationStart` for use of this experimental API.\n *\n * @experimental\n */\nexport class ActivationEnd {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ActivationEnd(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents a router event, allowing you to track the lifecycle of the router.\n *\n * The sequence of router events is:\n *\n * - `NavigationStart`,\n * - `RouteConfigLoadStart`,\n * - `RouteConfigLoadEnd`,\n * - `RoutesRecognized`,\n * - `GuardsCheckStart`,\n * - `ChildActivationStart`,\n * - `ActivationStart`,\n * - `GuardsCheckEnd`,\n * - `ResolveStart`,\n * - `ResolveEnd`,\n * - `ActivationEnd`\n * - `ChildActivationEnd`\n * - `NavigationEnd`,\n * - `NavigationCancel`,\n * - `NavigationError`\n *\n *\n */\nexport type Event = RouterEvent | RouteConfigLoadStart | RouteConfigLoadEnd | ChildActivationStart |\n    ChildActivationEnd | ActivationStart | ActivationEnd;\n"]}
424
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../../../../../../../packages/router/src/events.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} from './config';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\n\n/**\n * @description\n *\n * Identifies the trigger of the navigation.\n *\n * * 'imperative'--triggered by `router.navigateByUrl` or `router.navigate`.\n * * 'popstate'--triggered by a popstate event\n * * 'hashchange'--triggered by a hashchange event\n *\n * @experimental\n */\nexport type NavigationTrigger = 'imperative' | 'popstate' | 'hashchange';\n\n/**\n * @description\n *\n * Base for events the Router goes through, as opposed to events tied to a specific\n * Route. `RouterEvent`s will only be fired one time for any given navigation.\n *\n * Example:\n *\n * ```\n * class MyService {\n *   constructor(public router: Router, logger: Logger) {\n *     router.events.filter(e => e instanceof RouterEvent).subscribe(e => {\n *       logger.log(e.id, e.url);\n *     });\n *   }\n * }\n * ```\n *\n * @experimental\n */\nexport class RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      public id: number,\n      /** @docsNotRequired */\n      public url: string) {}\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation starts.\n *\n *\n */\nexport class NavigationStart extends RouterEvent {\n  /**\n   * Identifies the trigger of the navigation.\n   *\n   * * 'imperative'--triggered by `router.navigateByUrl` or `router.navigate`.\n   * * 'popstate'--triggered by a popstate event\n   * * 'hashchange'--triggered by a hashchange event\n   */\n  navigationTrigger?: 'imperative'|'popstate'|'hashchange';\n\n  /**\n   * This contains the navigation id that pushed the history record that the router navigates\n   * back to. This is not null only when the navigation is triggered by a popstate event.\n   *\n   * The router assigns a navigationId to every router transition/navigation. Even when the user\n   * clicks on the back button in the browser, a new navigation id will be created. So from\n   * the perspective of the router, the router never \"goes back\". By using the `restoredState`\n   * and its navigationId, you can implement behavior that differentiates between creating new\n   * states\n   * and popstate events. In the latter case you can restore some remembered state (e.g., scroll\n   * position).\n   */\n  restoredState?: {navigationId: number}|null;\n\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      navigationTrigger: 'imperative'|'popstate'|'hashchange' = 'imperative',\n      /** @docsNotRequired */\n      restoredState: {navigationId: number}|null = null) {\n    super(id, url);\n    this.navigationTrigger = navigationTrigger;\n    this.restoredState = restoredState;\n  }\n\n  /** @docsNotRequired */\n  toString(): string { return `NavigationStart(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation ends successfully.\n *\n *\n */\nexport class NavigationEnd extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string {\n    return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation is canceled.\n *\n *\n */\nexport class NavigationCancel extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public reason: string) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string { return `NavigationCancel(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a navigation fails due to an unexpected error.\n *\n *\n */\nexport class NavigationError extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public error: any) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string {\n    return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when routes are recognized.\n *\n *\n */\nexport class RoutesRecognized extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  toString(): string {\n    return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of the Guard phase of routing.\n *\n * @experimental\n */\nexport class GuardsCheckStart extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `GuardsCheckStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the end of the Guard phase of routing.\n *\n * @experimental\n */\nexport class GuardsCheckEnd extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot,\n      /** @docsNotRequired */\n      public shouldActivate: boolean) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `GuardsCheckEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state}, shouldActivate: ${this.shouldActivate})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of the Resolve phase of routing. The timing of this\n * event may change, thus it's experimental. In the current iteration it will run\n * in the \"resolve\" phase whether there's things to resolve or not. In the future this\n * behavior may change to only run when there are things to be resolved.\n *\n * @experimental\n */\nexport class ResolveStart extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `ResolveStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the end of the Resolve phase of routing. See note on\n * `ResolveStart` for use of this experimental API.\n *\n * @experimental\n */\nexport class ResolveEnd extends RouterEvent {\n  constructor(\n      /** @docsNotRequired */\n      id: number,\n      /** @docsNotRequired */\n      url: string,\n      /** @docsNotRequired */\n      public urlAfterRedirects: string,\n      /** @docsNotRequired */\n      public state: RouterStateSnapshot) {\n    super(id, url);\n  }\n\n  toString(): string {\n    return `ResolveEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * @description\n *\n * Represents an event triggered before lazy loading a route config.\n *\n * @experimental\n */\nexport class RouteConfigLoadStart {\n  constructor(\n      /** @docsNotRequired */\n      public route: Route) {}\n  toString(): string { return `RouteConfigLoadStart(path: ${this.route.path})`; }\n}\n\n/**\n * @description\n *\n * Represents an event triggered when a route has been lazy loaded.\n *\n * @experimental\n */\nexport class RouteConfigLoadEnd {\n  constructor(\n      /** @docsNotRequired */\n      public route: Route) {}\n  toString(): string { return `RouteConfigLoadEnd(path: ${this.route.path})`; }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ChildActivationEnd` for use of this experimental API.\n *\n * @experimental\n */\nexport class ChildActivationStart {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ChildActivationStart(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ChildActivationStart` for use of this experimental API.\n *\n * @experimental\n */\nexport class ChildActivationEnd {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ChildActivationEnd(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ActivationEnd` for use of this experimental API.\n *\n * @experimental\n */\nexport class ActivationStart {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ActivationStart(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents the start of end of the Resolve phase of routing. See note on\n * `ActivationStart` for use of this experimental API.\n *\n * @experimental\n */\nexport class ActivationEnd {\n  constructor(\n      /** @docsNotRequired */\n      public snapshot: ActivatedRouteSnapshot) {}\n  toString(): string {\n    const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';\n    return `ActivationEnd(path: '${path}')`;\n  }\n}\n\n/**\n * @description\n *\n * Represents a router event, allowing you to track the lifecycle of the router.\n *\n * The sequence of router events is:\n *\n * - `NavigationStart`,\n * - `RouteConfigLoadStart`,\n * - `RouteConfigLoadEnd`,\n * - `RoutesRecognized`,\n * - `GuardsCheckStart`,\n * - `ChildActivationStart`,\n * - `ActivationStart`,\n * - `GuardsCheckEnd`,\n * - `ResolveStart`,\n * - `ResolveEnd`,\n * - `ActivationEnd`\n * - `ChildActivationEnd`\n * - `NavigationEnd`,\n * - `NavigationCancel`,\n * - `NavigationError`\n *\n *\n */\nexport type Event = RouterEvent | RouteConfigLoadStart | RouteConfigLoadEnd | ChildActivationStart |\n    ChildActivationEnd | ActivationStart | ActivationEnd;\n"]}