@angular/router 19.0.0-next.0 → 19.0.0-next.2
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/README.md +1 -1
- package/fesm2022/router.mjs +86 -96
- package/fesm2022/router.mjs.map +1 -1
- package/fesm2022/testing.mjs +11 -11
- package/fesm2022/upgrade.mjs +1 -1
- package/index.d.ts +1 -1
- package/package.json +4 -10
- package/testing/index.d.ts +1 -1
- package/upgrade/index.d.ts +1 -1
- package/esm2022/index.mjs +0 -13
- package/esm2022/public_api.mjs +0 -15
- package/esm2022/router.mjs +0 -5
- package/esm2022/src/apply_redirects.mjs +0 -124
- package/esm2022/src/components/empty_outlet.mjs +0 -49
- package/esm2022/src/create_router_state.mjs +0 -52
- package/esm2022/src/create_url_tree.mjs +0 -420
- package/esm2022/src/directives/router_link.mjs +0 -361
- package/esm2022/src/directives/router_link_active.mjs +0 -237
- package/esm2022/src/directives/router_outlet.mjs +0 -388
- package/esm2022/src/errors.mjs +0 -2
- package/esm2022/src/events.mjs +0 -588
- package/esm2022/src/index.mjs +0 -31
- package/esm2022/src/models.mjs +0 -45
- package/esm2022/src/models_deprecated.mjs +0 -9
- package/esm2022/src/navigation_canceling_error.mjs +0 -33
- package/esm2022/src/navigation_transition.mjs +0 -437
- package/esm2022/src/operators/activate_routes.mjs +0 -190
- package/esm2022/src/operators/check_guards.mjs +0 -157
- package/esm2022/src/operators/prioritized_guard_value.mjs +0 -40
- package/esm2022/src/operators/recognize.mjs +0 -15
- package/esm2022/src/operators/resolve_data.mjs +0 -92
- package/esm2022/src/operators/switch_tap.mjs +0 -25
- package/esm2022/src/page_title_strategy.mjs +0 -89
- package/esm2022/src/private_export.mjs +0 -12
- package/esm2022/src/provide_router.mjs +0 -549
- package/esm2022/src/recognize.mjs +0 -321
- package/esm2022/src/route_reuse_strategy.mjs +0 -79
- package/esm2022/src/router.mjs +0 -571
- package/esm2022/src/router_config.mjs +0 -18
- package/esm2022/src/router_config_loader.mjs +0 -137
- package/esm2022/src/router_module.mjs +0 -226
- package/esm2022/src/router_outlet_context.mjs +0 -90
- package/esm2022/src/router_preloader.mjs +0 -162
- package/esm2022/src/router_scroller.mjs +0 -111
- package/esm2022/src/router_state.mjs +0 -419
- package/esm2022/src/shared.mjs +0 -97
- package/esm2022/src/statemanager/state_manager.mjs +0 -200
- package/esm2022/src/url_handling_strategy.mjs +0 -45
- package/esm2022/src/url_tree.mjs +0 -643
- package/esm2022/src/utils/collection.mjs +0 -75
- package/esm2022/src/utils/config.mjs +0 -191
- package/esm2022/src/utils/config_matching.mjs +0 -150
- package/esm2022/src/utils/functional_guards.mjs +0 -69
- package/esm2022/src/utils/navigations.mjs +0 -44
- package/esm2022/src/utils/preactivation.mjs +0 -154
- package/esm2022/src/utils/tree.mjs +0 -94
- package/esm2022/src/utils/type_guards.mjs +0 -46
- package/esm2022/src/utils/view_transition.mjs +0 -61
- package/esm2022/src/version.mjs +0 -18
- package/esm2022/testing/index.mjs +0 -13
- package/esm2022/testing/public_api.mjs +0 -15
- package/esm2022/testing/src/router_testing_harness.mjs +0 -127
- package/esm2022/testing/src/router_testing_module.mjs +0 -75
- package/esm2022/testing/src/testing.mjs +0 -15
- package/esm2022/testing/testing.mjs +0 -5
- package/esm2022/upgrade/index.mjs +0 -13
- package/esm2022/upgrade/public_api.mjs +0 -15
- package/esm2022/upgrade/src/upgrade.mjs +0 -128
- package/esm2022/upgrade/upgrade.mjs +0 -5
package/esm2022/src/events.mjs
DELETED
|
@@ -1,588 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
export const IMPERATIVE_NAVIGATION = 'imperative';
|
|
9
|
-
/**
|
|
10
|
-
* Identifies the type of a router event.
|
|
11
|
-
*
|
|
12
|
-
* @publicApi
|
|
13
|
-
*/
|
|
14
|
-
export var EventType;
|
|
15
|
-
(function (EventType) {
|
|
16
|
-
EventType[EventType["NavigationStart"] = 0] = "NavigationStart";
|
|
17
|
-
EventType[EventType["NavigationEnd"] = 1] = "NavigationEnd";
|
|
18
|
-
EventType[EventType["NavigationCancel"] = 2] = "NavigationCancel";
|
|
19
|
-
EventType[EventType["NavigationError"] = 3] = "NavigationError";
|
|
20
|
-
EventType[EventType["RoutesRecognized"] = 4] = "RoutesRecognized";
|
|
21
|
-
EventType[EventType["ResolveStart"] = 5] = "ResolveStart";
|
|
22
|
-
EventType[EventType["ResolveEnd"] = 6] = "ResolveEnd";
|
|
23
|
-
EventType[EventType["GuardsCheckStart"] = 7] = "GuardsCheckStart";
|
|
24
|
-
EventType[EventType["GuardsCheckEnd"] = 8] = "GuardsCheckEnd";
|
|
25
|
-
EventType[EventType["RouteConfigLoadStart"] = 9] = "RouteConfigLoadStart";
|
|
26
|
-
EventType[EventType["RouteConfigLoadEnd"] = 10] = "RouteConfigLoadEnd";
|
|
27
|
-
EventType[EventType["ChildActivationStart"] = 11] = "ChildActivationStart";
|
|
28
|
-
EventType[EventType["ChildActivationEnd"] = 12] = "ChildActivationEnd";
|
|
29
|
-
EventType[EventType["ActivationStart"] = 13] = "ActivationStart";
|
|
30
|
-
EventType[EventType["ActivationEnd"] = 14] = "ActivationEnd";
|
|
31
|
-
EventType[EventType["Scroll"] = 15] = "Scroll";
|
|
32
|
-
EventType[EventType["NavigationSkipped"] = 16] = "NavigationSkipped";
|
|
33
|
-
})(EventType || (EventType = {}));
|
|
34
|
-
/**
|
|
35
|
-
* Base for events the router goes through, as opposed to events tied to a specific
|
|
36
|
-
* route. Fired one time for any given navigation.
|
|
37
|
-
*
|
|
38
|
-
* The following code shows how a class subscribes to router events.
|
|
39
|
-
*
|
|
40
|
-
* ```ts
|
|
41
|
-
* import {Event, RouterEvent, Router} from '@angular/router';
|
|
42
|
-
*
|
|
43
|
-
* class MyService {
|
|
44
|
-
* constructor(public router: Router) {
|
|
45
|
-
* router.events.pipe(
|
|
46
|
-
* filter((e: Event | RouterEvent): e is RouterEvent => e instanceof RouterEvent)
|
|
47
|
-
* ).subscribe((e: RouterEvent) => {
|
|
48
|
-
* // Do something
|
|
49
|
-
* });
|
|
50
|
-
* }
|
|
51
|
-
* }
|
|
52
|
-
* ```
|
|
53
|
-
*
|
|
54
|
-
* @see {@link Event}
|
|
55
|
-
* @see [Router events summary](guide/routing/router-reference#router-events)
|
|
56
|
-
* @publicApi
|
|
57
|
-
*/
|
|
58
|
-
export class RouterEvent {
|
|
59
|
-
constructor(
|
|
60
|
-
/** A unique ID that the router assigns to every router navigation. */
|
|
61
|
-
id,
|
|
62
|
-
/** The URL that is the destination for this navigation. */
|
|
63
|
-
url) {
|
|
64
|
-
this.id = id;
|
|
65
|
-
this.url = url;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
/**
|
|
69
|
-
* An event triggered when a navigation starts.
|
|
70
|
-
*
|
|
71
|
-
* @publicApi
|
|
72
|
-
*/
|
|
73
|
-
export class NavigationStart extends RouterEvent {
|
|
74
|
-
constructor(
|
|
75
|
-
/** @docsNotRequired */
|
|
76
|
-
id,
|
|
77
|
-
/** @docsNotRequired */
|
|
78
|
-
url,
|
|
79
|
-
/** @docsNotRequired */
|
|
80
|
-
navigationTrigger = 'imperative',
|
|
81
|
-
/** @docsNotRequired */
|
|
82
|
-
restoredState = null) {
|
|
83
|
-
super(id, url);
|
|
84
|
-
this.type = EventType.NavigationStart;
|
|
85
|
-
this.navigationTrigger = navigationTrigger;
|
|
86
|
-
this.restoredState = restoredState;
|
|
87
|
-
}
|
|
88
|
-
/** @docsNotRequired */
|
|
89
|
-
toString() {
|
|
90
|
-
return `NavigationStart(id: ${this.id}, url: '${this.url}')`;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
/**
|
|
94
|
-
* An event triggered when a navigation ends successfully.
|
|
95
|
-
*
|
|
96
|
-
* @see {@link NavigationStart}
|
|
97
|
-
* @see {@link NavigationCancel}
|
|
98
|
-
* @see {@link NavigationError}
|
|
99
|
-
*
|
|
100
|
-
* @publicApi
|
|
101
|
-
*/
|
|
102
|
-
export class NavigationEnd extends RouterEvent {
|
|
103
|
-
constructor(
|
|
104
|
-
/** @docsNotRequired */
|
|
105
|
-
id,
|
|
106
|
-
/** @docsNotRequired */
|
|
107
|
-
url,
|
|
108
|
-
/** @docsNotRequired */
|
|
109
|
-
urlAfterRedirects) {
|
|
110
|
-
super(id, url);
|
|
111
|
-
this.urlAfterRedirects = urlAfterRedirects;
|
|
112
|
-
this.type = EventType.NavigationEnd;
|
|
113
|
-
}
|
|
114
|
-
/** @docsNotRequired */
|
|
115
|
-
toString() {
|
|
116
|
-
return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
/**
|
|
120
|
-
* A code for the `NavigationCancel` event of the `Router` to indicate the
|
|
121
|
-
* reason a navigation failed.
|
|
122
|
-
*
|
|
123
|
-
* @publicApi
|
|
124
|
-
*/
|
|
125
|
-
export var NavigationCancellationCode;
|
|
126
|
-
(function (NavigationCancellationCode) {
|
|
127
|
-
/**
|
|
128
|
-
* A navigation failed because a guard returned a `UrlTree` to redirect.
|
|
129
|
-
*/
|
|
130
|
-
NavigationCancellationCode[NavigationCancellationCode["Redirect"] = 0] = "Redirect";
|
|
131
|
-
/**
|
|
132
|
-
* A navigation failed because a more recent navigation started.
|
|
133
|
-
*/
|
|
134
|
-
NavigationCancellationCode[NavigationCancellationCode["SupersededByNewNavigation"] = 1] = "SupersededByNewNavigation";
|
|
135
|
-
/**
|
|
136
|
-
* A navigation failed because one of the resolvers completed without emitting a value.
|
|
137
|
-
*/
|
|
138
|
-
NavigationCancellationCode[NavigationCancellationCode["NoDataFromResolver"] = 2] = "NoDataFromResolver";
|
|
139
|
-
/**
|
|
140
|
-
* A navigation failed because a guard returned `false`.
|
|
141
|
-
*/
|
|
142
|
-
NavigationCancellationCode[NavigationCancellationCode["GuardRejected"] = 3] = "GuardRejected";
|
|
143
|
-
})(NavigationCancellationCode || (NavigationCancellationCode = {}));
|
|
144
|
-
/**
|
|
145
|
-
* A code for the `NavigationSkipped` event of the `Router` to indicate the
|
|
146
|
-
* reason a navigation was skipped.
|
|
147
|
-
*
|
|
148
|
-
* @publicApi
|
|
149
|
-
*/
|
|
150
|
-
export var NavigationSkippedCode;
|
|
151
|
-
(function (NavigationSkippedCode) {
|
|
152
|
-
/**
|
|
153
|
-
* A navigation was skipped because the navigation URL was the same as the current Router URL.
|
|
154
|
-
*/
|
|
155
|
-
NavigationSkippedCode[NavigationSkippedCode["IgnoredSameUrlNavigation"] = 0] = "IgnoredSameUrlNavigation";
|
|
156
|
-
/**
|
|
157
|
-
* A navigation was skipped because the configured `UrlHandlingStrategy` return `false` for both
|
|
158
|
-
* the current Router URL and the target of the navigation.
|
|
159
|
-
*
|
|
160
|
-
* @see {@link UrlHandlingStrategy}
|
|
161
|
-
*/
|
|
162
|
-
NavigationSkippedCode[NavigationSkippedCode["IgnoredByUrlHandlingStrategy"] = 1] = "IgnoredByUrlHandlingStrategy";
|
|
163
|
-
})(NavigationSkippedCode || (NavigationSkippedCode = {}));
|
|
164
|
-
/**
|
|
165
|
-
* An event triggered when a navigation is canceled, directly or indirectly.
|
|
166
|
-
* This can happen for several reasons including when a route guard
|
|
167
|
-
* returns `false` or initiates a redirect by returning a `UrlTree`.
|
|
168
|
-
*
|
|
169
|
-
* @see {@link NavigationStart}
|
|
170
|
-
* @see {@link NavigationEnd}
|
|
171
|
-
* @see {@link NavigationError}
|
|
172
|
-
*
|
|
173
|
-
* @publicApi
|
|
174
|
-
*/
|
|
175
|
-
export class NavigationCancel extends RouterEvent {
|
|
176
|
-
constructor(
|
|
177
|
-
/** @docsNotRequired */
|
|
178
|
-
id,
|
|
179
|
-
/** @docsNotRequired */
|
|
180
|
-
url,
|
|
181
|
-
/**
|
|
182
|
-
* A description of why the navigation was cancelled. For debug purposes only. Use `code`
|
|
183
|
-
* instead for a stable cancellation reason that can be used in production.
|
|
184
|
-
*/
|
|
185
|
-
reason,
|
|
186
|
-
/**
|
|
187
|
-
* A code to indicate why the navigation was canceled. This cancellation code is stable for
|
|
188
|
-
* the reason and can be relied on whereas the `reason` string could change and should not be
|
|
189
|
-
* used in production.
|
|
190
|
-
*/
|
|
191
|
-
code) {
|
|
192
|
-
super(id, url);
|
|
193
|
-
this.reason = reason;
|
|
194
|
-
this.code = code;
|
|
195
|
-
this.type = EventType.NavigationCancel;
|
|
196
|
-
}
|
|
197
|
-
/** @docsNotRequired */
|
|
198
|
-
toString() {
|
|
199
|
-
return `NavigationCancel(id: ${this.id}, url: '${this.url}')`;
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
/**
|
|
203
|
-
* An event triggered when a navigation is skipped.
|
|
204
|
-
* This can happen for a couple reasons including onSameUrlHandling
|
|
205
|
-
* is set to `ignore` and the navigation URL is not different than the
|
|
206
|
-
* current state.
|
|
207
|
-
*
|
|
208
|
-
* @publicApi
|
|
209
|
-
*/
|
|
210
|
-
export class NavigationSkipped extends RouterEvent {
|
|
211
|
-
constructor(
|
|
212
|
-
/** @docsNotRequired */
|
|
213
|
-
id,
|
|
214
|
-
/** @docsNotRequired */
|
|
215
|
-
url,
|
|
216
|
-
/**
|
|
217
|
-
* A description of why the navigation was skipped. For debug purposes only. Use `code`
|
|
218
|
-
* instead for a stable skipped reason that can be used in production.
|
|
219
|
-
*/
|
|
220
|
-
reason,
|
|
221
|
-
/**
|
|
222
|
-
* A code to indicate why the navigation was skipped. This code is stable for
|
|
223
|
-
* the reason and can be relied on whereas the `reason` string could change and should not be
|
|
224
|
-
* used in production.
|
|
225
|
-
*/
|
|
226
|
-
code) {
|
|
227
|
-
super(id, url);
|
|
228
|
-
this.reason = reason;
|
|
229
|
-
this.code = code;
|
|
230
|
-
this.type = EventType.NavigationSkipped;
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* An event triggered when a navigation fails due to an unexpected error.
|
|
235
|
-
*
|
|
236
|
-
* @see {@link NavigationStart}
|
|
237
|
-
* @see {@link NavigationEnd}
|
|
238
|
-
* @see {@link NavigationCancel}
|
|
239
|
-
*
|
|
240
|
-
* @publicApi
|
|
241
|
-
*/
|
|
242
|
-
export class NavigationError extends RouterEvent {
|
|
243
|
-
constructor(
|
|
244
|
-
/** @docsNotRequired */
|
|
245
|
-
id,
|
|
246
|
-
/** @docsNotRequired */
|
|
247
|
-
url,
|
|
248
|
-
/** @docsNotRequired */
|
|
249
|
-
error,
|
|
250
|
-
/**
|
|
251
|
-
* The target of the navigation when the error occurred.
|
|
252
|
-
*
|
|
253
|
-
* Note that this can be `undefined` because an error could have occurred before the
|
|
254
|
-
* `RouterStateSnapshot` was created for the navigation.
|
|
255
|
-
*/
|
|
256
|
-
target) {
|
|
257
|
-
super(id, url);
|
|
258
|
-
this.error = error;
|
|
259
|
-
this.target = target;
|
|
260
|
-
this.type = EventType.NavigationError;
|
|
261
|
-
}
|
|
262
|
-
/** @docsNotRequired */
|
|
263
|
-
toString() {
|
|
264
|
-
return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
/**
|
|
268
|
-
* An event triggered when routes are recognized.
|
|
269
|
-
*
|
|
270
|
-
* @publicApi
|
|
271
|
-
*/
|
|
272
|
-
export class RoutesRecognized extends RouterEvent {
|
|
273
|
-
constructor(
|
|
274
|
-
/** @docsNotRequired */
|
|
275
|
-
id,
|
|
276
|
-
/** @docsNotRequired */
|
|
277
|
-
url,
|
|
278
|
-
/** @docsNotRequired */
|
|
279
|
-
urlAfterRedirects,
|
|
280
|
-
/** @docsNotRequired */
|
|
281
|
-
state) {
|
|
282
|
-
super(id, url);
|
|
283
|
-
this.urlAfterRedirects = urlAfterRedirects;
|
|
284
|
-
this.state = state;
|
|
285
|
-
this.type = EventType.RoutesRecognized;
|
|
286
|
-
}
|
|
287
|
-
/** @docsNotRequired */
|
|
288
|
-
toString() {
|
|
289
|
-
return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
|
290
|
-
}
|
|
291
|
-
}
|
|
292
|
-
/**
|
|
293
|
-
* An event triggered at the start of the Guard phase of routing.
|
|
294
|
-
*
|
|
295
|
-
* @see {@link GuardsCheckEnd}
|
|
296
|
-
*
|
|
297
|
-
* @publicApi
|
|
298
|
-
*/
|
|
299
|
-
export class GuardsCheckStart extends RouterEvent {
|
|
300
|
-
constructor(
|
|
301
|
-
/** @docsNotRequired */
|
|
302
|
-
id,
|
|
303
|
-
/** @docsNotRequired */
|
|
304
|
-
url,
|
|
305
|
-
/** @docsNotRequired */
|
|
306
|
-
urlAfterRedirects,
|
|
307
|
-
/** @docsNotRequired */
|
|
308
|
-
state) {
|
|
309
|
-
super(id, url);
|
|
310
|
-
this.urlAfterRedirects = urlAfterRedirects;
|
|
311
|
-
this.state = state;
|
|
312
|
-
this.type = EventType.GuardsCheckStart;
|
|
313
|
-
}
|
|
314
|
-
toString() {
|
|
315
|
-
return `GuardsCheckStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
/**
|
|
319
|
-
* An event triggered at the end of the Guard phase of routing.
|
|
320
|
-
*
|
|
321
|
-
* @see {@link GuardsCheckStart}
|
|
322
|
-
*
|
|
323
|
-
* @publicApi
|
|
324
|
-
*/
|
|
325
|
-
export class GuardsCheckEnd extends RouterEvent {
|
|
326
|
-
constructor(
|
|
327
|
-
/** @docsNotRequired */
|
|
328
|
-
id,
|
|
329
|
-
/** @docsNotRequired */
|
|
330
|
-
url,
|
|
331
|
-
/** @docsNotRequired */
|
|
332
|
-
urlAfterRedirects,
|
|
333
|
-
/** @docsNotRequired */
|
|
334
|
-
state,
|
|
335
|
-
/** @docsNotRequired */
|
|
336
|
-
shouldActivate) {
|
|
337
|
-
super(id, url);
|
|
338
|
-
this.urlAfterRedirects = urlAfterRedirects;
|
|
339
|
-
this.state = state;
|
|
340
|
-
this.shouldActivate = shouldActivate;
|
|
341
|
-
this.type = EventType.GuardsCheckEnd;
|
|
342
|
-
}
|
|
343
|
-
toString() {
|
|
344
|
-
return `GuardsCheckEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state}, shouldActivate: ${this.shouldActivate})`;
|
|
345
|
-
}
|
|
346
|
-
}
|
|
347
|
-
/**
|
|
348
|
-
* An event triggered at the start of the Resolve phase of routing.
|
|
349
|
-
*
|
|
350
|
-
* Runs in the "resolve" phase whether or not there is anything to resolve.
|
|
351
|
-
* In future, may change to only run when there are things to be resolved.
|
|
352
|
-
*
|
|
353
|
-
* @see {@link ResolveEnd}
|
|
354
|
-
*
|
|
355
|
-
* @publicApi
|
|
356
|
-
*/
|
|
357
|
-
export class ResolveStart extends RouterEvent {
|
|
358
|
-
constructor(
|
|
359
|
-
/** @docsNotRequired */
|
|
360
|
-
id,
|
|
361
|
-
/** @docsNotRequired */
|
|
362
|
-
url,
|
|
363
|
-
/** @docsNotRequired */
|
|
364
|
-
urlAfterRedirects,
|
|
365
|
-
/** @docsNotRequired */
|
|
366
|
-
state) {
|
|
367
|
-
super(id, url);
|
|
368
|
-
this.urlAfterRedirects = urlAfterRedirects;
|
|
369
|
-
this.state = state;
|
|
370
|
-
this.type = EventType.ResolveStart;
|
|
371
|
-
}
|
|
372
|
-
toString() {
|
|
373
|
-
return `ResolveStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
|
374
|
-
}
|
|
375
|
-
}
|
|
376
|
-
/**
|
|
377
|
-
* An event triggered at the end of the Resolve phase of routing.
|
|
378
|
-
* @see {@link ResolveStart}
|
|
379
|
-
*
|
|
380
|
-
* @publicApi
|
|
381
|
-
*/
|
|
382
|
-
export class ResolveEnd extends RouterEvent {
|
|
383
|
-
constructor(
|
|
384
|
-
/** @docsNotRequired */
|
|
385
|
-
id,
|
|
386
|
-
/** @docsNotRequired */
|
|
387
|
-
url,
|
|
388
|
-
/** @docsNotRequired */
|
|
389
|
-
urlAfterRedirects,
|
|
390
|
-
/** @docsNotRequired */
|
|
391
|
-
state) {
|
|
392
|
-
super(id, url);
|
|
393
|
-
this.urlAfterRedirects = urlAfterRedirects;
|
|
394
|
-
this.state = state;
|
|
395
|
-
this.type = EventType.ResolveEnd;
|
|
396
|
-
}
|
|
397
|
-
toString() {
|
|
398
|
-
return `ResolveEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
|
399
|
-
}
|
|
400
|
-
}
|
|
401
|
-
/**
|
|
402
|
-
* An event triggered before lazy loading a route configuration.
|
|
403
|
-
*
|
|
404
|
-
* @see {@link RouteConfigLoadEnd}
|
|
405
|
-
*
|
|
406
|
-
* @publicApi
|
|
407
|
-
*/
|
|
408
|
-
export class RouteConfigLoadStart {
|
|
409
|
-
constructor(
|
|
410
|
-
/** @docsNotRequired */
|
|
411
|
-
route) {
|
|
412
|
-
this.route = route;
|
|
413
|
-
this.type = EventType.RouteConfigLoadStart;
|
|
414
|
-
}
|
|
415
|
-
toString() {
|
|
416
|
-
return `RouteConfigLoadStart(path: ${this.route.path})`;
|
|
417
|
-
}
|
|
418
|
-
}
|
|
419
|
-
/**
|
|
420
|
-
* An event triggered when a route has been lazy loaded.
|
|
421
|
-
*
|
|
422
|
-
* @see {@link RouteConfigLoadStart}
|
|
423
|
-
*
|
|
424
|
-
* @publicApi
|
|
425
|
-
*/
|
|
426
|
-
export class RouteConfigLoadEnd {
|
|
427
|
-
constructor(
|
|
428
|
-
/** @docsNotRequired */
|
|
429
|
-
route) {
|
|
430
|
-
this.route = route;
|
|
431
|
-
this.type = EventType.RouteConfigLoadEnd;
|
|
432
|
-
}
|
|
433
|
-
toString() {
|
|
434
|
-
return `RouteConfigLoadEnd(path: ${this.route.path})`;
|
|
435
|
-
}
|
|
436
|
-
}
|
|
437
|
-
/**
|
|
438
|
-
* An event triggered at the start of the child-activation
|
|
439
|
-
* part of the Resolve phase of routing.
|
|
440
|
-
* @see {@link ChildActivationEnd}
|
|
441
|
-
* @see {@link ResolveStart}
|
|
442
|
-
*
|
|
443
|
-
* @publicApi
|
|
444
|
-
*/
|
|
445
|
-
export class ChildActivationStart {
|
|
446
|
-
constructor(
|
|
447
|
-
/** @docsNotRequired */
|
|
448
|
-
snapshot) {
|
|
449
|
-
this.snapshot = snapshot;
|
|
450
|
-
this.type = EventType.ChildActivationStart;
|
|
451
|
-
}
|
|
452
|
-
toString() {
|
|
453
|
-
const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';
|
|
454
|
-
return `ChildActivationStart(path: '${path}')`;
|
|
455
|
-
}
|
|
456
|
-
}
|
|
457
|
-
/**
|
|
458
|
-
* An event triggered at the end of the child-activation part
|
|
459
|
-
* of the Resolve phase of routing.
|
|
460
|
-
* @see {@link ChildActivationStart}
|
|
461
|
-
* @see {@link ResolveStart}
|
|
462
|
-
* @publicApi
|
|
463
|
-
*/
|
|
464
|
-
export class ChildActivationEnd {
|
|
465
|
-
constructor(
|
|
466
|
-
/** @docsNotRequired */
|
|
467
|
-
snapshot) {
|
|
468
|
-
this.snapshot = snapshot;
|
|
469
|
-
this.type = EventType.ChildActivationEnd;
|
|
470
|
-
}
|
|
471
|
-
toString() {
|
|
472
|
-
const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';
|
|
473
|
-
return `ChildActivationEnd(path: '${path}')`;
|
|
474
|
-
}
|
|
475
|
-
}
|
|
476
|
-
/**
|
|
477
|
-
* An event triggered at the start of the activation part
|
|
478
|
-
* of the Resolve phase of routing.
|
|
479
|
-
* @see {@link ActivationEnd}
|
|
480
|
-
* @see {@link ResolveStart}
|
|
481
|
-
*
|
|
482
|
-
* @publicApi
|
|
483
|
-
*/
|
|
484
|
-
export class ActivationStart {
|
|
485
|
-
constructor(
|
|
486
|
-
/** @docsNotRequired */
|
|
487
|
-
snapshot) {
|
|
488
|
-
this.snapshot = snapshot;
|
|
489
|
-
this.type = EventType.ActivationStart;
|
|
490
|
-
}
|
|
491
|
-
toString() {
|
|
492
|
-
const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';
|
|
493
|
-
return `ActivationStart(path: '${path}')`;
|
|
494
|
-
}
|
|
495
|
-
}
|
|
496
|
-
/**
|
|
497
|
-
* An event triggered at the end of the activation part
|
|
498
|
-
* of the Resolve phase of routing.
|
|
499
|
-
* @see {@link ActivationStart}
|
|
500
|
-
* @see {@link ResolveStart}
|
|
501
|
-
*
|
|
502
|
-
* @publicApi
|
|
503
|
-
*/
|
|
504
|
-
export class ActivationEnd {
|
|
505
|
-
constructor(
|
|
506
|
-
/** @docsNotRequired */
|
|
507
|
-
snapshot) {
|
|
508
|
-
this.snapshot = snapshot;
|
|
509
|
-
this.type = EventType.ActivationEnd;
|
|
510
|
-
}
|
|
511
|
-
toString() {
|
|
512
|
-
const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';
|
|
513
|
-
return `ActivationEnd(path: '${path}')`;
|
|
514
|
-
}
|
|
515
|
-
}
|
|
516
|
-
/**
|
|
517
|
-
* An event triggered by scrolling.
|
|
518
|
-
*
|
|
519
|
-
* @publicApi
|
|
520
|
-
*/
|
|
521
|
-
export class Scroll {
|
|
522
|
-
constructor(
|
|
523
|
-
/** @docsNotRequired */
|
|
524
|
-
routerEvent,
|
|
525
|
-
/** @docsNotRequired */
|
|
526
|
-
position,
|
|
527
|
-
/** @docsNotRequired */
|
|
528
|
-
anchor) {
|
|
529
|
-
this.routerEvent = routerEvent;
|
|
530
|
-
this.position = position;
|
|
531
|
-
this.anchor = anchor;
|
|
532
|
-
this.type = EventType.Scroll;
|
|
533
|
-
}
|
|
534
|
-
toString() {
|
|
535
|
-
const pos = this.position ? `${this.position[0]}, ${this.position[1]}` : null;
|
|
536
|
-
return `Scroll(anchor: '${this.anchor}', position: '${pos}')`;
|
|
537
|
-
}
|
|
538
|
-
}
|
|
539
|
-
export class BeforeActivateRoutes {
|
|
540
|
-
}
|
|
541
|
-
export class RedirectRequest {
|
|
542
|
-
constructor(url, navigationBehaviorOptions) {
|
|
543
|
-
this.url = url;
|
|
544
|
-
this.navigationBehaviorOptions = navigationBehaviorOptions;
|
|
545
|
-
}
|
|
546
|
-
}
|
|
547
|
-
export function stringifyEvent(routerEvent) {
|
|
548
|
-
switch (routerEvent.type) {
|
|
549
|
-
case EventType.ActivationEnd:
|
|
550
|
-
return `ActivationEnd(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;
|
|
551
|
-
case EventType.ActivationStart:
|
|
552
|
-
return `ActivationStart(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;
|
|
553
|
-
case EventType.ChildActivationEnd:
|
|
554
|
-
return `ChildActivationEnd(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;
|
|
555
|
-
case EventType.ChildActivationStart:
|
|
556
|
-
return `ChildActivationStart(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;
|
|
557
|
-
case EventType.GuardsCheckEnd:
|
|
558
|
-
return `GuardsCheckEnd(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state}, shouldActivate: ${routerEvent.shouldActivate})`;
|
|
559
|
-
case EventType.GuardsCheckStart:
|
|
560
|
-
return `GuardsCheckStart(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;
|
|
561
|
-
case EventType.NavigationCancel:
|
|
562
|
-
return `NavigationCancel(id: ${routerEvent.id}, url: '${routerEvent.url}')`;
|
|
563
|
-
case EventType.NavigationSkipped:
|
|
564
|
-
return `NavigationSkipped(id: ${routerEvent.id}, url: '${routerEvent.url}')`;
|
|
565
|
-
case EventType.NavigationEnd:
|
|
566
|
-
return `NavigationEnd(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}')`;
|
|
567
|
-
case EventType.NavigationError:
|
|
568
|
-
return `NavigationError(id: ${routerEvent.id}, url: '${routerEvent.url}', error: ${routerEvent.error})`;
|
|
569
|
-
case EventType.NavigationStart:
|
|
570
|
-
return `NavigationStart(id: ${routerEvent.id}, url: '${routerEvent.url}')`;
|
|
571
|
-
case EventType.ResolveEnd:
|
|
572
|
-
return `ResolveEnd(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;
|
|
573
|
-
case EventType.ResolveStart:
|
|
574
|
-
return `ResolveStart(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;
|
|
575
|
-
case EventType.RouteConfigLoadEnd:
|
|
576
|
-
return `RouteConfigLoadEnd(path: ${routerEvent.route.path})`;
|
|
577
|
-
case EventType.RouteConfigLoadStart:
|
|
578
|
-
return `RouteConfigLoadStart(path: ${routerEvent.route.path})`;
|
|
579
|
-
case EventType.RoutesRecognized:
|
|
580
|
-
return `RoutesRecognized(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;
|
|
581
|
-
case EventType.Scroll:
|
|
582
|
-
const pos = routerEvent.position
|
|
583
|
-
? `${routerEvent.position[0]}, ${routerEvent.position[1]}`
|
|
584
|
-
: null;
|
|
585
|
-
return `Scroll(anchor: '${routerEvent.anchor}', position: '${pos}')`;
|
|
586
|
-
}
|
|
587
|
-
}
|
|
588
|
-
//# 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 LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {NavigationBehaviorOptions, Route} from './models';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\nimport {UrlTree} from './url_tree';\n\n/**\n * Identifies the call or event that triggered a 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 * @publicApi\n */\nexport type NavigationTrigger = 'imperative' | 'popstate' | 'hashchange';\nexport const IMPERATIVE_NAVIGATION = 'imperative';\n\n/**\n * Identifies the type of a router event.\n *\n * @publicApi\n */\nexport enum EventType {\n  NavigationStart,\n  NavigationEnd,\n  NavigationCancel,\n  NavigationError,\n  RoutesRecognized,\n  ResolveStart,\n  ResolveEnd,\n  GuardsCheckStart,\n  GuardsCheckEnd,\n  RouteConfigLoadStart,\n  RouteConfigLoadEnd,\n  ChildActivationStart,\n  ChildActivationEnd,\n  ActivationStart,\n  ActivationEnd,\n  Scroll,\n  NavigationSkipped,\n}\n\n/**\n * Base for events the router goes through, as opposed to events tied to a specific\n * route. Fired one time for any given navigation.\n *\n * The following code shows how a class subscribes to router events.\n *\n * ```ts\n * import {Event, RouterEvent, Router} from '@angular/router';\n *\n * class MyService {\n *   constructor(public router: Router) {\n *     router.events.pipe(\n *        filter((e: Event | RouterEvent): e is RouterEvent => e instanceof RouterEvent)\n *     ).subscribe((e: RouterEvent) => {\n *       // Do something\n *     });\n *   }\n * }\n * ```\n *\n * @see {@link Event}\n * @see [Router events summary](guide/routing/router-reference#router-events)\n * @publicApi\n */\nexport class RouterEvent {\n  constructor(\n    /** A unique ID that the router assigns to every router navigation. */\n    public id: number,\n    /** The URL that is the destination for this navigation. */\n    public url: string,\n  ) {}\n}\n\n/**\n * An event triggered when a navigation starts.\n *\n * @publicApi\n */\nexport class NavigationStart extends RouterEvent {\n  readonly type = EventType.NavigationStart;\n\n  /**\n   * Identifies the call or event that triggered the navigation.\n   * An `imperative` trigger is a call to `router.navigateByUrl()` or `router.navigate()`.\n   *\n   * @see {@link NavigationEnd}\n   * @see {@link NavigationCancel}\n   * @see {@link NavigationError}\n   */\n  navigationTrigger?: NavigationTrigger;\n\n  /**\n   * The navigation state that was previously supplied to the `pushState` call,\n   * when the navigation is triggered by a `popstate` event. Otherwise null.\n   *\n   * The state object is defined by `NavigationExtras`, and contains any\n   * developer-defined state value, as well as a unique ID that\n   * the router assigns to every router transition/navigation.\n   *\n   * From the perspective of the router, the router never \"goes back\".\n   * When the user clicks on the back button in the browser,\n   * a new navigation ID is created.\n   *\n   * Use the ID in this previous-state object to differentiate between a newly created\n   * state and one returned to by a `popstate` event, so that you can restore some\n   * remembered state, such as scroll position.\n   *\n   */\n  restoredState?: {[k: string]: any; navigationId: number} | null;\n\n  constructor(\n    /** @docsNotRequired */\n    id: number,\n    /** @docsNotRequired */\n    url: string,\n    /** @docsNotRequired */\n    navigationTrigger: NavigationTrigger = 'imperative',\n    /** @docsNotRequired */\n    restoredState: {[k: string]: any; navigationId: number} | null = null,\n  ) {\n    super(id, url);\n    this.navigationTrigger = navigationTrigger;\n    this.restoredState = restoredState;\n  }\n\n  /** @docsNotRequired */\n  override toString(): string {\n    return `NavigationStart(id: ${this.id}, url: '${this.url}')`;\n  }\n}\n\n/**\n * An event triggered when a navigation ends successfully.\n *\n * @see {@link NavigationStart}\n * @see {@link NavigationCancel}\n * @see {@link NavigationError}\n *\n * @publicApi\n */\nexport class NavigationEnd extends RouterEvent {\n  readonly type = EventType.NavigationEnd;\n\n  constructor(\n    /** @docsNotRequired */\n    id: number,\n    /** @docsNotRequired */\n    url: string,\n    /** @docsNotRequired */\n    public urlAfterRedirects: string,\n  ) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  override toString(): string {\n    return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;\n  }\n}\n\n/**\n * A code for the `NavigationCancel` event of the `Router` to indicate the\n * reason a navigation failed.\n *\n * @publicApi\n */\nexport enum NavigationCancellationCode {\n  /**\n   * A navigation failed because a guard returned a `UrlTree` to redirect.\n   */\n  Redirect,\n  /**\n   * A navigation failed because a more recent navigation started.\n   */\n  SupersededByNewNavigation,\n  /**\n   * A navigation failed because one of the resolvers completed without emitting a value.\n   */\n  NoDataFromResolver,\n  /**\n   * A navigation failed because a guard returned `false`.\n   */\n  GuardRejected,\n}\n\n/**\n * A code for the `NavigationSkipped` event of the `Router` to indicate the\n * reason a navigation was skipped.\n *\n * @publicApi\n */\nexport enum NavigationSkippedCode {\n  /**\n   * A navigation was skipped because the navigation URL was the same as the current Router URL.\n   */\n  IgnoredSameUrlNavigation,\n  /**\n   * A navigation was skipped because the configured `UrlHandlingStrategy` return `false` for both\n   * the current Router URL and the target of the navigation.\n   *\n   * @see {@link UrlHandlingStrategy}\n   */\n  IgnoredByUrlHandlingStrategy,\n}\n\n/**\n * An event triggered when a navigation is canceled, directly or indirectly.\n * This can happen for several reasons including when a route guard\n * returns `false` or initiates a redirect by returning a `UrlTree`.\n *\n * @see {@link NavigationStart}\n * @see {@link NavigationEnd}\n * @see {@link NavigationError}\n *\n * @publicApi\n */\nexport class NavigationCancel extends RouterEvent {\n  readonly type = EventType.NavigationCancel;\n\n  constructor(\n    /** @docsNotRequired */\n    id: number,\n    /** @docsNotRequired */\n    url: string,\n    /**\n     * A description of why the navigation was cancelled. For debug purposes only. Use `code`\n     * instead for a stable cancellation reason that can be used in production.\n     */\n    public reason: string,\n    /**\n     * A code to indicate why the navigation was canceled. This cancellation code is stable for\n     * the reason and can be relied on whereas the `reason` string could change and should not be\n     * used in production.\n     */\n    readonly code?: NavigationCancellationCode,\n  ) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  override toString(): string {\n    return `NavigationCancel(id: ${this.id}, url: '${this.url}')`;\n  }\n}\n\n/**\n * An event triggered when a navigation is skipped.\n * This can happen for a couple reasons including onSameUrlHandling\n * is set to `ignore` and the navigation URL is not different than the\n * current state.\n *\n * @publicApi\n */\nexport class NavigationSkipped extends RouterEvent {\n  readonly type = EventType.NavigationSkipped;\n\n  constructor(\n    /** @docsNotRequired */\n    id: number,\n    /** @docsNotRequired */\n    url: string,\n    /**\n     * A description of why the navigation was skipped. For debug purposes only. Use `code`\n     * instead for a stable skipped reason that can be used in production.\n     */\n    public reason: string,\n    /**\n     * A code to indicate why the navigation was skipped. This code is stable for\n     * the reason and can be relied on whereas the `reason` string could change and should not be\n     * used in production.\n     */\n    readonly code?: NavigationSkippedCode,\n  ) {\n    super(id, url);\n  }\n}\n\n/**\n * An event triggered when a navigation fails due to an unexpected error.\n *\n * @see {@link NavigationStart}\n * @see {@link NavigationEnd}\n * @see {@link NavigationCancel}\n *\n * @publicApi\n */\nexport class NavigationError extends RouterEvent {\n  readonly type = EventType.NavigationError;\n\n  constructor(\n    /** @docsNotRequired */\n    id: number,\n    /** @docsNotRequired */\n    url: string,\n    /** @docsNotRequired */\n    public error: any,\n    /**\n     * The target of the navigation when the error occurred.\n     *\n     * Note that this can be `undefined` because an error could have occurred before the\n     * `RouterStateSnapshot` was created for the navigation.\n     */\n    readonly target?: RouterStateSnapshot,\n  ) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  override toString(): string {\n    return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;\n  }\n}\n\n/**\n * An event triggered when routes are recognized.\n *\n * @publicApi\n */\nexport class RoutesRecognized extends RouterEvent {\n  readonly type = EventType.RoutesRecognized;\n\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  ) {\n    super(id, url);\n  }\n\n  /** @docsNotRequired */\n  override toString(): string {\n    return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * An event triggered at the start of the Guard phase of routing.\n *\n * @see {@link GuardsCheckEnd}\n *\n * @publicApi\n */\nexport class GuardsCheckStart extends RouterEvent {\n  readonly type = EventType.GuardsCheckStart;\n\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  ) {\n    super(id, url);\n  }\n\n  override toString(): string {\n    return `GuardsCheckStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * An event triggered at the end of the Guard phase of routing.\n *\n * @see {@link GuardsCheckStart}\n *\n * @publicApi\n */\nexport class GuardsCheckEnd extends RouterEvent {\n  readonly type = EventType.GuardsCheckEnd;\n\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  ) {\n    super(id, url);\n  }\n\n  override 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 * An event triggered at the start of the Resolve phase of routing.\n *\n * Runs in the \"resolve\" phase whether or not there is anything to resolve.\n * In future, may change to only run when there are things to be resolved.\n *\n * @see {@link ResolveEnd}\n *\n * @publicApi\n */\nexport class ResolveStart extends RouterEvent {\n  readonly type = EventType.ResolveStart;\n\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  ) {\n    super(id, url);\n  }\n\n  override toString(): string {\n    return `ResolveStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * An event triggered at the end of the Resolve phase of routing.\n * @see {@link ResolveStart}\n *\n * @publicApi\n */\nexport class ResolveEnd extends RouterEvent {\n  readonly type = EventType.ResolveEnd;\n\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  ) {\n    super(id, url);\n  }\n\n  override toString(): string {\n    return `ResolveEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * An event triggered before lazy loading a route configuration.\n *\n * @see {@link RouteConfigLoadEnd}\n *\n * @publicApi\n */\nexport class RouteConfigLoadStart {\n  readonly type = EventType.RouteConfigLoadStart;\n\n  constructor(\n    /** @docsNotRequired */\n    public route: Route,\n  ) {}\n  toString(): string {\n    return `RouteConfigLoadStart(path: ${this.route.path})`;\n  }\n}\n\n/**\n * An event triggered when a route has been lazy loaded.\n *\n * @see {@link RouteConfigLoadStart}\n *\n * @publicApi\n */\nexport class RouteConfigLoadEnd {\n  readonly type = EventType.RouteConfigLoadEnd;\n\n  constructor(\n    /** @docsNotRequired */\n    public route: Route,\n  ) {}\n  toString(): string {\n    return `RouteConfigLoadEnd(path: ${this.route.path})`;\n  }\n}\n\n/**\n * An event triggered at the start of the child-activation\n * part of the Resolve phase of routing.\n * @see {@link ChildActivationEnd}\n * @see {@link ResolveStart}\n *\n * @publicApi\n */\nexport class ChildActivationStart {\n  readonly type = EventType.ChildActivationStart;\n\n  constructor(\n    /** @docsNotRequired */\n    public snapshot: ActivatedRouteSnapshot,\n  ) {}\n  toString(): string {\n    const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';\n    return `ChildActivationStart(path: '${path}')`;\n  }\n}\n\n/**\n * An event triggered at the end of the child-activation part\n * of the Resolve phase of routing.\n * @see {@link ChildActivationStart}\n * @see {@link ResolveStart}\n * @publicApi\n */\nexport class ChildActivationEnd {\n  readonly type = EventType.ChildActivationEnd;\n\n  constructor(\n    /** @docsNotRequired */\n    public snapshot: ActivatedRouteSnapshot,\n  ) {}\n  toString(): string {\n    const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';\n    return `ChildActivationEnd(path: '${path}')`;\n  }\n}\n\n/**\n * An event triggered at the start of the activation part\n * of the Resolve phase of routing.\n * @see {@link ActivationEnd}\n * @see {@link ResolveStart}\n *\n * @publicApi\n */\nexport class ActivationStart {\n  readonly type = EventType.ActivationStart;\n\n  constructor(\n    /** @docsNotRequired */\n    public snapshot: ActivatedRouteSnapshot,\n  ) {}\n  toString(): string {\n    const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';\n    return `ActivationStart(path: '${path}')`;\n  }\n}\n\n/**\n * An event triggered at the end of the activation part\n * of the Resolve phase of routing.\n * @see {@link ActivationStart}\n * @see {@link ResolveStart}\n *\n * @publicApi\n */\nexport class ActivationEnd {\n  readonly type = EventType.ActivationEnd;\n\n  constructor(\n    /** @docsNotRequired */\n    public snapshot: ActivatedRouteSnapshot,\n  ) {}\n  toString(): string {\n    const path = (this.snapshot.routeConfig && this.snapshot.routeConfig.path) || '';\n    return `ActivationEnd(path: '${path}')`;\n  }\n}\n\n/**\n * An event triggered by scrolling.\n *\n * @publicApi\n */\nexport class Scroll {\n  readonly type = EventType.Scroll;\n\n  constructor(\n    /** @docsNotRequired */\n    readonly routerEvent: NavigationEnd | NavigationSkipped,\n\n    /** @docsNotRequired */\n    readonly position: [number, number] | null,\n\n    /** @docsNotRequired */\n    readonly anchor: string | null,\n  ) {}\n\n  toString(): string {\n    const pos = this.position ? `${this.position[0]}, ${this.position[1]}` : null;\n    return `Scroll(anchor: '${this.anchor}', position: '${pos}')`;\n  }\n}\n\nexport class BeforeActivateRoutes {}\nexport class RedirectRequest {\n  constructor(\n    readonly url: UrlTree,\n    readonly navigationBehaviorOptions: NavigationBehaviorOptions | undefined,\n  ) {}\n}\nexport type PrivateRouterEvents = BeforeActivateRoutes | RedirectRequest;\n\n/**\n * Router events that allow you to track the lifecycle of the router.\n *\n * The events occur in the following sequence:\n *\n * * [NavigationStart](api/router/NavigationStart): Navigation starts.\n * * [RouteConfigLoadStart](api/router/RouteConfigLoadStart): Before\n * the router [lazy loads](guide/routing/common-router-tasks#lazy-loading) a route configuration.\n * * [RouteConfigLoadEnd](api/router/RouteConfigLoadEnd): After a route has been lazy loaded.\n * * [RoutesRecognized](api/router/RoutesRecognized): When the router parses the URL\n * and the routes are recognized.\n * * [GuardsCheckStart](api/router/GuardsCheckStart): When the router begins the *guards*\n * phase of routing.\n * * [ChildActivationStart](api/router/ChildActivationStart): When the router\n * begins activating a route's children.\n * * [ActivationStart](api/router/ActivationStart): When the router begins activating a route.\n * * [GuardsCheckEnd](api/router/GuardsCheckEnd): When the router finishes the *guards*\n * phase of routing successfully.\n * * [ResolveStart](api/router/ResolveStart): When the router begins the *resolve*\n * phase of routing.\n * * [ResolveEnd](api/router/ResolveEnd): When the router finishes the *resolve*\n * phase of routing successfully.\n * * [ChildActivationEnd](api/router/ChildActivationEnd): When the router finishes\n * activating a route's children.\n * * [ActivationEnd](api/router/ActivationEnd): When the router finishes activating a route.\n * * [NavigationEnd](api/router/NavigationEnd): When navigation ends successfully.\n * * [NavigationCancel](api/router/NavigationCancel): When navigation is canceled.\n * * [NavigationError](api/router/NavigationError): When navigation fails\n * due to an unexpected error.\n * * [Scroll](api/router/Scroll): When the user scrolls.\n *\n * @publicApi\n */\nexport type Event =\n  | NavigationStart\n  | NavigationEnd\n  | NavigationCancel\n  | NavigationError\n  | RoutesRecognized\n  | GuardsCheckStart\n  | GuardsCheckEnd\n  | RouteConfigLoadStart\n  | RouteConfigLoadEnd\n  | ChildActivationStart\n  | ChildActivationEnd\n  | ActivationStart\n  | ActivationEnd\n  | Scroll\n  | ResolveStart\n  | ResolveEnd\n  | NavigationSkipped;\n\nexport function stringifyEvent(routerEvent: Event): string {\n  switch (routerEvent.type) {\n    case EventType.ActivationEnd:\n      return `ActivationEnd(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;\n    case EventType.ActivationStart:\n      return `ActivationStart(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;\n    case EventType.ChildActivationEnd:\n      return `ChildActivationEnd(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;\n    case EventType.ChildActivationStart:\n      return `ChildActivationStart(path: '${routerEvent.snapshot.routeConfig?.path || ''}')`;\n    case EventType.GuardsCheckEnd:\n      return `GuardsCheckEnd(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state}, shouldActivate: ${routerEvent.shouldActivate})`;\n    case EventType.GuardsCheckStart:\n      return `GuardsCheckStart(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;\n    case EventType.NavigationCancel:\n      return `NavigationCancel(id: ${routerEvent.id}, url: '${routerEvent.url}')`;\n    case EventType.NavigationSkipped:\n      return `NavigationSkipped(id: ${routerEvent.id}, url: '${routerEvent.url}')`;\n    case EventType.NavigationEnd:\n      return `NavigationEnd(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}')`;\n    case EventType.NavigationError:\n      return `NavigationError(id: ${routerEvent.id}, url: '${routerEvent.url}', error: ${routerEvent.error})`;\n    case EventType.NavigationStart:\n      return `NavigationStart(id: ${routerEvent.id}, url: '${routerEvent.url}')`;\n    case EventType.ResolveEnd:\n      return `ResolveEnd(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;\n    case EventType.ResolveStart:\n      return `ResolveStart(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;\n    case EventType.RouteConfigLoadEnd:\n      return `RouteConfigLoadEnd(path: ${routerEvent.route.path})`;\n    case EventType.RouteConfigLoadStart:\n      return `RouteConfigLoadStart(path: ${routerEvent.route.path})`;\n    case EventType.RoutesRecognized:\n      return `RoutesRecognized(id: ${routerEvent.id}, url: '${routerEvent.url}', urlAfterRedirects: '${routerEvent.urlAfterRedirects}', state: ${routerEvent.state})`;\n    case EventType.Scroll:\n      const pos = routerEvent.position\n        ? `${routerEvent.position[0]}, ${routerEvent.position[1]}`\n        : null;\n      return `Scroll(anchor: '${routerEvent.anchor}', position: '${pos}')`;\n  }\n}\n"]}
|