[6a3a178] | 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 | /**
|
---|
| 9 | * Base for events the router goes through, as opposed to events tied to a specific
|
---|
| 10 | * route. Fired one time for any given navigation.
|
---|
| 11 | *
|
---|
| 12 | * The following code shows how a class subscribes to router events.
|
---|
| 13 | *
|
---|
| 14 | * ```ts
|
---|
| 15 | * import {Event, RouterEvent, Router} from '@angular/router';
|
---|
| 16 | *
|
---|
| 17 | * class MyService {
|
---|
| 18 | * constructor(public router: Router) {
|
---|
| 19 | * router.events.pipe(
|
---|
| 20 | * filter((e: Event): e is RouterEvent => e instanceof RouterEvent)
|
---|
| 21 | * ).subscribe((e: RouterEvent) => {
|
---|
| 22 | * // Do something
|
---|
| 23 | * });
|
---|
| 24 | * }
|
---|
| 25 | * }
|
---|
| 26 | * ```
|
---|
| 27 | *
|
---|
| 28 | * @see `Event`
|
---|
| 29 | * @see [Router events summary](guide/router-reference#router-events)
|
---|
| 30 | * @publicApi
|
---|
| 31 | */
|
---|
| 32 | export class RouterEvent {
|
---|
| 33 | constructor(
|
---|
| 34 | /** A unique ID that the router assigns to every router navigation. */
|
---|
| 35 | id,
|
---|
| 36 | /** The URL that is the destination for this navigation. */
|
---|
| 37 | url) {
|
---|
| 38 | this.id = id;
|
---|
| 39 | this.url = url;
|
---|
| 40 | }
|
---|
| 41 | }
|
---|
| 42 | /**
|
---|
| 43 | * An event triggered when a navigation starts.
|
---|
| 44 | *
|
---|
| 45 | * @publicApi
|
---|
| 46 | */
|
---|
| 47 | export class NavigationStart extends RouterEvent {
|
---|
| 48 | constructor(
|
---|
| 49 | /** @docsNotRequired */
|
---|
| 50 | id,
|
---|
| 51 | /** @docsNotRequired */
|
---|
| 52 | url,
|
---|
| 53 | /** @docsNotRequired */
|
---|
| 54 | navigationTrigger = 'imperative',
|
---|
| 55 | /** @docsNotRequired */
|
---|
| 56 | restoredState = null) {
|
---|
| 57 | super(id, url);
|
---|
| 58 | this.navigationTrigger = navigationTrigger;
|
---|
| 59 | this.restoredState = restoredState;
|
---|
| 60 | }
|
---|
| 61 | /** @docsNotRequired */
|
---|
| 62 | toString() {
|
---|
| 63 | return `NavigationStart(id: ${this.id}, url: '${this.url}')`;
|
---|
| 64 | }
|
---|
| 65 | }
|
---|
| 66 | /**
|
---|
| 67 | * An event triggered when a navigation ends successfully.
|
---|
| 68 | *
|
---|
| 69 | * @see `NavigationStart`
|
---|
| 70 | * @see `NavigationCancel`
|
---|
| 71 | * @see `NavigationError`
|
---|
| 72 | *
|
---|
| 73 | * @publicApi
|
---|
| 74 | */
|
---|
| 75 | export class NavigationEnd extends RouterEvent {
|
---|
| 76 | constructor(
|
---|
| 77 | /** @docsNotRequired */
|
---|
| 78 | id,
|
---|
| 79 | /** @docsNotRequired */
|
---|
| 80 | url,
|
---|
| 81 | /** @docsNotRequired */
|
---|
| 82 | urlAfterRedirects) {
|
---|
| 83 | super(id, url);
|
---|
| 84 | this.urlAfterRedirects = urlAfterRedirects;
|
---|
| 85 | }
|
---|
| 86 | /** @docsNotRequired */
|
---|
| 87 | toString() {
|
---|
| 88 | return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;
|
---|
| 89 | }
|
---|
| 90 | }
|
---|
| 91 | /**
|
---|
| 92 | * An event triggered when a navigation is canceled, directly or indirectly.
|
---|
| 93 | * This can happen for several reasons including when a route guard
|
---|
| 94 | * returns `false` or initiates a redirect by returning a `UrlTree`.
|
---|
| 95 | *
|
---|
| 96 | * @see `NavigationStart`
|
---|
| 97 | * @see `NavigationEnd`
|
---|
| 98 | * @see `NavigationError`
|
---|
| 99 | *
|
---|
| 100 | * @publicApi
|
---|
| 101 | */
|
---|
| 102 | export class NavigationCancel extends RouterEvent {
|
---|
| 103 | constructor(
|
---|
| 104 | /** @docsNotRequired */
|
---|
| 105 | id,
|
---|
| 106 | /** @docsNotRequired */
|
---|
| 107 | url,
|
---|
| 108 | /** @docsNotRequired */
|
---|
| 109 | reason) {
|
---|
| 110 | super(id, url);
|
---|
| 111 | this.reason = reason;
|
---|
| 112 | }
|
---|
| 113 | /** @docsNotRequired */
|
---|
| 114 | toString() {
|
---|
| 115 | return `NavigationCancel(id: ${this.id}, url: '${this.url}')`;
|
---|
| 116 | }
|
---|
| 117 | }
|
---|
| 118 | /**
|
---|
| 119 | * An event triggered when a navigation fails due to an unexpected error.
|
---|
| 120 | *
|
---|
| 121 | * @see `NavigationStart`
|
---|
| 122 | * @see `NavigationEnd`
|
---|
| 123 | * @see `NavigationCancel`
|
---|
| 124 | *
|
---|
| 125 | * @publicApi
|
---|
| 126 | */
|
---|
| 127 | export class NavigationError extends RouterEvent {
|
---|
| 128 | constructor(
|
---|
| 129 | /** @docsNotRequired */
|
---|
| 130 | id,
|
---|
| 131 | /** @docsNotRequired */
|
---|
| 132 | url,
|
---|
| 133 | /** @docsNotRequired */
|
---|
| 134 | error) {
|
---|
| 135 | super(id, url);
|
---|
| 136 | this.error = error;
|
---|
| 137 | }
|
---|
| 138 | /** @docsNotRequired */
|
---|
| 139 | toString() {
|
---|
| 140 | return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;
|
---|
| 141 | }
|
---|
| 142 | }
|
---|
| 143 | /**
|
---|
| 144 | * An event triggered when routes are recognized.
|
---|
| 145 | *
|
---|
| 146 | * @publicApi
|
---|
| 147 | */
|
---|
| 148 | export class RoutesRecognized extends RouterEvent {
|
---|
| 149 | constructor(
|
---|
| 150 | /** @docsNotRequired */
|
---|
| 151 | id,
|
---|
| 152 | /** @docsNotRequired */
|
---|
| 153 | url,
|
---|
| 154 | /** @docsNotRequired */
|
---|
| 155 | urlAfterRedirects,
|
---|
| 156 | /** @docsNotRequired */
|
---|
| 157 | state) {
|
---|
| 158 | super(id, url);
|
---|
| 159 | this.urlAfterRedirects = urlAfterRedirects;
|
---|
| 160 | this.state = state;
|
---|
| 161 | }
|
---|
| 162 | /** @docsNotRequired */
|
---|
| 163 | toString() {
|
---|
| 164 | return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
---|
| 165 | }
|
---|
| 166 | }
|
---|
| 167 | /**
|
---|
| 168 | * An event triggered at the start of the Guard phase of routing.
|
---|
| 169 | *
|
---|
| 170 | * @see `GuardsCheckEnd`
|
---|
| 171 | *
|
---|
| 172 | * @publicApi
|
---|
| 173 | */
|
---|
| 174 | export class GuardsCheckStart extends RouterEvent {
|
---|
| 175 | constructor(
|
---|
| 176 | /** @docsNotRequired */
|
---|
| 177 | id,
|
---|
| 178 | /** @docsNotRequired */
|
---|
| 179 | url,
|
---|
| 180 | /** @docsNotRequired */
|
---|
| 181 | urlAfterRedirects,
|
---|
| 182 | /** @docsNotRequired */
|
---|
| 183 | state) {
|
---|
| 184 | super(id, url);
|
---|
| 185 | this.urlAfterRedirects = urlAfterRedirects;
|
---|
| 186 | this.state = state;
|
---|
| 187 | }
|
---|
| 188 | toString() {
|
---|
| 189 | return `GuardsCheckStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
---|
| 190 | }
|
---|
| 191 | }
|
---|
| 192 | /**
|
---|
| 193 | * An event triggered at the end of the Guard phase of routing.
|
---|
| 194 | *
|
---|
| 195 | * @see `GuardsCheckStart`
|
---|
| 196 | *
|
---|
| 197 | * @publicApi
|
---|
| 198 | */
|
---|
| 199 | export class GuardsCheckEnd extends RouterEvent {
|
---|
| 200 | constructor(
|
---|
| 201 | /** @docsNotRequired */
|
---|
| 202 | id,
|
---|
| 203 | /** @docsNotRequired */
|
---|
| 204 | url,
|
---|
| 205 | /** @docsNotRequired */
|
---|
| 206 | urlAfterRedirects,
|
---|
| 207 | /** @docsNotRequired */
|
---|
| 208 | state,
|
---|
| 209 | /** @docsNotRequired */
|
---|
| 210 | shouldActivate) {
|
---|
| 211 | super(id, url);
|
---|
| 212 | this.urlAfterRedirects = urlAfterRedirects;
|
---|
| 213 | this.state = state;
|
---|
| 214 | this.shouldActivate = shouldActivate;
|
---|
| 215 | }
|
---|
| 216 | toString() {
|
---|
| 217 | return `GuardsCheckEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state}, shouldActivate: ${this.shouldActivate})`;
|
---|
| 218 | }
|
---|
| 219 | }
|
---|
| 220 | /**
|
---|
| 221 | * An event triggered at the start of the Resolve phase of routing.
|
---|
| 222 | *
|
---|
| 223 | * Runs in the "resolve" phase whether or not there is anything to resolve.
|
---|
| 224 | * In future, may change to only run when there are things to be resolved.
|
---|
| 225 | *
|
---|
| 226 | * @see `ResolveEnd`
|
---|
| 227 | *
|
---|
| 228 | * @publicApi
|
---|
| 229 | */
|
---|
| 230 | export class ResolveStart extends RouterEvent {
|
---|
| 231 | constructor(
|
---|
| 232 | /** @docsNotRequired */
|
---|
| 233 | id,
|
---|
| 234 | /** @docsNotRequired */
|
---|
| 235 | url,
|
---|
| 236 | /** @docsNotRequired */
|
---|
| 237 | urlAfterRedirects,
|
---|
| 238 | /** @docsNotRequired */
|
---|
| 239 | state) {
|
---|
| 240 | super(id, url);
|
---|
| 241 | this.urlAfterRedirects = urlAfterRedirects;
|
---|
| 242 | this.state = state;
|
---|
| 243 | }
|
---|
| 244 | toString() {
|
---|
| 245 | return `ResolveStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
---|
| 246 | }
|
---|
| 247 | }
|
---|
| 248 | /**
|
---|
| 249 | * An event triggered at the end of the Resolve phase of routing.
|
---|
| 250 | * @see `ResolveStart`.
|
---|
| 251 | *
|
---|
| 252 | * @publicApi
|
---|
| 253 | */
|
---|
| 254 | export class ResolveEnd extends RouterEvent {
|
---|
| 255 | constructor(
|
---|
| 256 | /** @docsNotRequired */
|
---|
| 257 | id,
|
---|
| 258 | /** @docsNotRequired */
|
---|
| 259 | url,
|
---|
| 260 | /** @docsNotRequired */
|
---|
| 261 | urlAfterRedirects,
|
---|
| 262 | /** @docsNotRequired */
|
---|
| 263 | state) {
|
---|
| 264 | super(id, url);
|
---|
| 265 | this.urlAfterRedirects = urlAfterRedirects;
|
---|
| 266 | this.state = state;
|
---|
| 267 | }
|
---|
| 268 | toString() {
|
---|
| 269 | return `ResolveEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
|
---|
| 270 | }
|
---|
| 271 | }
|
---|
| 272 | /**
|
---|
| 273 | * An event triggered before lazy loading a route configuration.
|
---|
| 274 | *
|
---|
| 275 | * @see `RouteConfigLoadEnd`
|
---|
| 276 | *
|
---|
| 277 | * @publicApi
|
---|
| 278 | */
|
---|
| 279 | export class RouteConfigLoadStart {
|
---|
| 280 | constructor(
|
---|
| 281 | /** @docsNotRequired */
|
---|
| 282 | route) {
|
---|
| 283 | this.route = route;
|
---|
| 284 | }
|
---|
| 285 | toString() {
|
---|
| 286 | return `RouteConfigLoadStart(path: ${this.route.path})`;
|
---|
| 287 | }
|
---|
| 288 | }
|
---|
| 289 | /**
|
---|
| 290 | * An event triggered when a route has been lazy loaded.
|
---|
| 291 | *
|
---|
| 292 | * @see `RouteConfigLoadStart`
|
---|
| 293 | *
|
---|
| 294 | * @publicApi
|
---|
| 295 | */
|
---|
| 296 | export class RouteConfigLoadEnd {
|
---|
| 297 | constructor(
|
---|
| 298 | /** @docsNotRequired */
|
---|
| 299 | route) {
|
---|
| 300 | this.route = route;
|
---|
| 301 | }
|
---|
| 302 | toString() {
|
---|
| 303 | return `RouteConfigLoadEnd(path: ${this.route.path})`;
|
---|
| 304 | }
|
---|
| 305 | }
|
---|
| 306 | /**
|
---|
| 307 | * An event triggered at the start of the child-activation
|
---|
| 308 | * part of the Resolve phase of routing.
|
---|
| 309 | * @see `ChildActivationEnd`
|
---|
| 310 | * @see `ResolveStart`
|
---|
| 311 | *
|
---|
| 312 | * @publicApi
|
---|
| 313 | */
|
---|
| 314 | export class ChildActivationStart {
|
---|
| 315 | constructor(
|
---|
| 316 | /** @docsNotRequired */
|
---|
| 317 | snapshot) {
|
---|
| 318 | this.snapshot = snapshot;
|
---|
| 319 | }
|
---|
| 320 | toString() {
|
---|
| 321 | const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';
|
---|
| 322 | return `ChildActivationStart(path: '${path}')`;
|
---|
| 323 | }
|
---|
| 324 | }
|
---|
| 325 | /**
|
---|
| 326 | * An event triggered at the end of the child-activation part
|
---|
| 327 | * of the Resolve phase of routing.
|
---|
| 328 | * @see `ChildActivationStart`
|
---|
| 329 | * @see `ResolveStart`
|
---|
| 330 | * @publicApi
|
---|
| 331 | */
|
---|
| 332 | export class ChildActivationEnd {
|
---|
| 333 | constructor(
|
---|
| 334 | /** @docsNotRequired */
|
---|
| 335 | snapshot) {
|
---|
| 336 | this.snapshot = snapshot;
|
---|
| 337 | }
|
---|
| 338 | toString() {
|
---|
| 339 | const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';
|
---|
| 340 | return `ChildActivationEnd(path: '${path}')`;
|
---|
| 341 | }
|
---|
| 342 | }
|
---|
| 343 | /**
|
---|
| 344 | * An event triggered at the start of the activation part
|
---|
| 345 | * of the Resolve phase of routing.
|
---|
| 346 | * @see `ActivationEnd`
|
---|
| 347 | * @see `ResolveStart`
|
---|
| 348 | *
|
---|
| 349 | * @publicApi
|
---|
| 350 | */
|
---|
| 351 | export class ActivationStart {
|
---|
| 352 | constructor(
|
---|
| 353 | /** @docsNotRequired */
|
---|
| 354 | snapshot) {
|
---|
| 355 | this.snapshot = snapshot;
|
---|
| 356 | }
|
---|
| 357 | toString() {
|
---|
| 358 | const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';
|
---|
| 359 | return `ActivationStart(path: '${path}')`;
|
---|
| 360 | }
|
---|
| 361 | }
|
---|
| 362 | /**
|
---|
| 363 | * An event triggered at the end of the activation part
|
---|
| 364 | * of the Resolve phase of routing.
|
---|
| 365 | * @see `ActivationStart`
|
---|
| 366 | * @see `ResolveStart`
|
---|
| 367 | *
|
---|
| 368 | * @publicApi
|
---|
| 369 | */
|
---|
| 370 | export class ActivationEnd {
|
---|
| 371 | constructor(
|
---|
| 372 | /** @docsNotRequired */
|
---|
| 373 | snapshot) {
|
---|
| 374 | this.snapshot = snapshot;
|
---|
| 375 | }
|
---|
| 376 | toString() {
|
---|
| 377 | const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || '';
|
---|
| 378 | return `ActivationEnd(path: '${path}')`;
|
---|
| 379 | }
|
---|
| 380 | }
|
---|
| 381 | /**
|
---|
| 382 | * An event triggered by scrolling.
|
---|
| 383 | *
|
---|
| 384 | * @publicApi
|
---|
| 385 | */
|
---|
| 386 | export class Scroll {
|
---|
| 387 | constructor(
|
---|
| 388 | /** @docsNotRequired */
|
---|
| 389 | routerEvent,
|
---|
| 390 | /** @docsNotRequired */
|
---|
| 391 | position,
|
---|
| 392 | /** @docsNotRequired */
|
---|
| 393 | anchor) {
|
---|
| 394 | this.routerEvent = routerEvent;
|
---|
| 395 | this.position = position;
|
---|
| 396 | this.anchor = anchor;
|
---|
| 397 | }
|
---|
| 398 | toString() {
|
---|
| 399 | const pos = this.position ? `${this.position[0]}, ${this.position[1]}` : null;
|
---|
| 400 | return `Scroll(anchor: '${this.anchor}', position: '${pos}')`;
|
---|
| 401 | }
|
---|
| 402 | }
|
---|
| 403 | //# 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 {Route} from './config';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\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';\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): e is RouterEvent => e instanceof RouterEvent)\n *     ).subscribe((e: RouterEvent) => {\n *       // Do something\n *     });\n *   }\n * }\n * ```\n *\n * @see `Event`\n * @see [Router events summary](guide/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 * An event triggered when a navigation starts.\n *\n * @publicApi\n */\nexport class NavigationStart extends RouterEvent {\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 `NavigationEnd`\n   * @see `NavigationCancel`\n   * @see `NavigationError`\n   */\n  navigationTrigger?: 'imperative'|'popstate'|'hashchange';\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: 'imperative'|'popstate'|'hashchange' = 'imperative',\n      /** @docsNotRequired */\n      restoredState: {[k: string]: any, navigationId: number}|null = null) {\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 `NavigationStart`\n * @see `NavigationCancel`\n * @see `NavigationError`\n *\n * @publicApi\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  override toString(): string {\n    return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${\n        this.urlAfterRedirects}')`;\n  }\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 `NavigationStart`\n * @see `NavigationEnd`\n * @see `NavigationError`\n *\n * @publicApi\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  override toString(): string {\n    return `NavigationCancel(id: ${this.id}, url: '${this.url}')`;\n  }\n}\n\n/**\n * An event triggered when a navigation fails due to an unexpected error.\n *\n * @see `NavigationStart`\n * @see `NavigationEnd`\n * @see `NavigationCancel`\n *\n * @publicApi\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  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  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  override toString(): string {\n    return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${\n        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 `GuardsCheckEnd`\n *\n * @publicApi\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  override toString(): string {\n    return `GuardsCheckStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${\n        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 `GuardsCheckStart`\n *\n * @publicApi\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  override toString(): string {\n    return `GuardsCheckEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${\n        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 `ResolveEnd`\n *\n * @publicApi\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  override toString(): string {\n    return `ResolveStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${\n        this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * An event triggered at the end of the Resolve phase of routing.\n * @see `ResolveStart`.\n *\n * @publicApi\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  override toString(): string {\n    return `ResolveEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${\n        this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\n/**\n * An event triggered before lazy loading a route configuration.\n *\n * @see `RouteConfigLoadEnd`\n *\n * @publicApi\n */\nexport class RouteConfigLoadStart {\n  constructor(\n      /** @docsNotRequired */\n      public route: Route) {}\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 `RouteConfigLoadStart`\n *\n * @publicApi\n */\nexport class RouteConfigLoadEnd {\n  constructor(\n      /** @docsNotRequired */\n      public route: Route) {}\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  `ChildActivationEnd`\n * @see `ResolveStart`\n *\n * @publicApi\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 * An event triggered at the end of the child-activation part\n * of the Resolve phase of routing.\n * @see `ChildActivationStart`\n * @see `ResolveStart`\n * @publicApi\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 * An event triggered at the start of the activation part\n * of the Resolve phase of routing.\n * @see `ActivationEnd`\n * @see `ResolveStart`\n *\n * @publicApi\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 * An event triggered at the end of the activation part\n * of the Resolve phase of routing.\n * @see `ActivationStart`\n * @see `ResolveStart`\n *\n * @publicApi\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 * An event triggered by scrolling.\n *\n * @publicApi\n */\nexport class Scroll {\n  constructor(\n      /** @docsNotRequired */\n      readonly routerEvent: NavigationEnd,\n\n      /** @docsNotRequired */\n      readonly position: [number, number]|null,\n\n      /** @docsNotRequired */\n      readonly anchor: string|null) {}\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\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/router#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 = RouterEvent|RouteConfigLoadStart|RouteConfigLoadEnd|ChildActivationStart|\n    ChildActivationEnd|ActivationStart|ActivationEnd|Scroll;\n"]} |
---|