UNPKG

@angular/router

Version:
650 lines (649 loc) • 37.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ /** @typedef {?} */ var NavigationTrigger; export { NavigationTrigger }; /** * \@description * * Base for events the Router goes through, as opposed to events tied to a specific * Route. `RouterEvent`s will only be fired one time for any given navigation. * * Example: * * ``` * class MyService { * constructor(public router: Router, logger: Logger) { * router.events.filter(e => e instanceof RouterEvent).subscribe(e => { * logger.log(e.id, e.url); * }); * } * } * ``` * * \@publicApi */ export class RouterEvent { /** * @param {?} id * @param {?} url */ constructor(id, url) { this.id = id; this.url = url; } } if (false) { /** * \@docsNotRequired * @type {?} */ RouterEvent.prototype.id; /** * \@docsNotRequired * @type {?} */ RouterEvent.prototype.url; } /** * \@description * * Represents an event triggered when a navigation starts. * * \@publicApi */ export class NavigationStart extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?=} navigationTrigger * @param {?=} restoredState */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, /** @docsNotRequired */ navigationTrigger = 'imperative', /** @docsNotRequired */ restoredState = null) { super(id, url); this.navigationTrigger = navigationTrigger; this.restoredState = restoredState; } /** * \@docsNotRequired * @return {?} */ toString() { return `NavigationStart(id: ${this.id}, url: '${this.url}')`; } } if (false) { /** * Identifies the trigger of the navigation. * * * 'imperative'--triggered by `router.navigateByUrl` or `router.navigate`. * * 'popstate'--triggered by a popstate event * * 'hashchange'--triggered by a hashchange event * @type {?} */ NavigationStart.prototype.navigationTrigger; /** * This contains the navigation id that pushed the history record that the router navigates * back to. This is not null only when the navigation is triggered by a popstate event. * * The router assigns a navigationId to every router transition/navigation. Even when the user * clicks on the back button in the browser, a new navigation id will be created. So from * the perspective of the router, the router never "goes back". By using the `restoredState` * and its navigationId, you can implement behavior that differentiates between creating new * states * and popstate events. In the latter case you can restore some remembered state (e.g., scroll * position). * @type {?} */ NavigationStart.prototype.restoredState; } /** * \@description * * Represents an event triggered when a navigation ends successfully. * * \@publicApi */ export class NavigationEnd extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} urlAfterRedirects */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, urlAfterRedirects) { super(id, url); this.urlAfterRedirects = urlAfterRedirects; } /** * \@docsNotRequired * @return {?} */ toString() { return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`; } } if (false) { /** * \@docsNotRequired * @type {?} */ NavigationEnd.prototype.urlAfterRedirects; } /** * \@description * * Represents an event triggered when a navigation is canceled. * * \@publicApi */ export class NavigationCancel extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} reason */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, reason) { super(id, url); this.reason = reason; } /** * \@docsNotRequired * @return {?} */ toString() { return `NavigationCancel(id: ${this.id}, url: '${this.url}')`; } } if (false) { /** * \@docsNotRequired * @type {?} */ NavigationCancel.prototype.reason; } /** * \@description * * Represents an event triggered when a navigation fails due to an unexpected error. * * \@publicApi */ export class NavigationError extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} error */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, error) { super(id, url); this.error = error; } /** * \@docsNotRequired * @return {?} */ toString() { return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ NavigationError.prototype.error; } /** * \@description * * Represents an event triggered when routes are recognized. * * \@publicApi */ export class RoutesRecognized extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} urlAfterRedirects * @param {?} state */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, urlAfterRedirects, state) { super(id, url); this.urlAfterRedirects = urlAfterRedirects; this.state = state; } /** * \@docsNotRequired * @return {?} */ toString() { return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ RoutesRecognized.prototype.urlAfterRedirects; /** * \@docsNotRequired * @type {?} */ RoutesRecognized.prototype.state; } /** * \@description * * Represents the start of the Guard phase of routing. * * \@publicApi */ export class GuardsCheckStart extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} urlAfterRedirects * @param {?} state */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, urlAfterRedirects, state) { super(id, url); this.urlAfterRedirects = urlAfterRedirects; this.state = state; } /** * @return {?} */ toString() { return `GuardsCheckStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ GuardsCheckStart.prototype.urlAfterRedirects; /** * \@docsNotRequired * @type {?} */ GuardsCheckStart.prototype.state; } /** * \@description * * Represents the end of the Guard phase of routing. * * \@publicApi */ export class GuardsCheckEnd extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} urlAfterRedirects * @param {?} state * @param {?} shouldActivate */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, urlAfterRedirects, state, shouldActivate) { super(id, url); this.urlAfterRedirects = urlAfterRedirects; this.state = state; this.shouldActivate = shouldActivate; } /** * @return {?} */ toString() { return `GuardsCheckEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state}, shouldActivate: ${this.shouldActivate})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ GuardsCheckEnd.prototype.urlAfterRedirects; /** * \@docsNotRequired * @type {?} */ GuardsCheckEnd.prototype.state; /** * \@docsNotRequired * @type {?} */ GuardsCheckEnd.prototype.shouldActivate; } /** * \@description * * Represents the start of the Resolve phase of routing. The timing of this * event may change, thus it's experimental. In the current iteration it will run * in the "resolve" phase whether there's things to resolve or not. In the future this * behavior may change to only run when there are things to be resolved. * * \@publicApi */ export class ResolveStart extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} urlAfterRedirects * @param {?} state */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, urlAfterRedirects, state) { super(id, url); this.urlAfterRedirects = urlAfterRedirects; this.state = state; } /** * @return {?} */ toString() { return `ResolveStart(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ ResolveStart.prototype.urlAfterRedirects; /** * \@docsNotRequired * @type {?} */ ResolveStart.prototype.state; } /** * \@description * * Represents the end of the Resolve phase of routing. See note on * `ResolveStart` for use of this experimental API. * * \@publicApi */ export class ResolveEnd extends RouterEvent { /** * @param {?} id * @param {?} url * @param {?} urlAfterRedirects * @param {?} state */ constructor(/** @docsNotRequired */ id, /** @docsNotRequired */ url, urlAfterRedirects, state) { super(id, url); this.urlAfterRedirects = urlAfterRedirects; this.state = state; } /** * @return {?} */ toString() { return `ResolveEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ ResolveEnd.prototype.urlAfterRedirects; /** * \@docsNotRequired * @type {?} */ ResolveEnd.prototype.state; } /** * \@description * * Represents an event triggered before lazy loading a route config. * * \@publicApi */ export class RouteConfigLoadStart { /** * @param {?} route */ constructor(route) { this.route = route; } /** * @return {?} */ toString() { return `RouteConfigLoadStart(path: ${this.route.path})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ RouteConfigLoadStart.prototype.route; } /** * \@description * * Represents an event triggered when a route has been lazy loaded. * * \@publicApi */ export class RouteConfigLoadEnd { /** * @param {?} route */ constructor(route) { this.route = route; } /** * @return {?} */ toString() { return `RouteConfigLoadEnd(path: ${this.route.path})`; } } if (false) { /** * \@docsNotRequired * @type {?} */ RouteConfigLoadEnd.prototype.route; } /** * \@description * * Represents the start of end of the Resolve phase of routing. See note on * `ChildActivationEnd` for use of this experimental API. * * \@publicApi */ export class ChildActivationStart { /** * @param {?} snapshot */ constructor(snapshot) { this.snapshot = snapshot; } /** * @return {?} */ toString() { /** @type {?} */ const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || ''; return `ChildActivationStart(path: '${path}')`; } } if (false) { /** * \@docsNotRequired * @type {?} */ ChildActivationStart.prototype.snapshot; } /** * \@description * * Represents the start of end of the Resolve phase of routing. See note on * `ChildActivationStart` for use of this experimental API. * * \@publicApi */ export class ChildActivationEnd { /** * @param {?} snapshot */ constructor(snapshot) { this.snapshot = snapshot; } /** * @return {?} */ toString() { /** @type {?} */ const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || ''; return `ChildActivationEnd(path: '${path}')`; } } if (false) { /** * \@docsNotRequired * @type {?} */ ChildActivationEnd.prototype.snapshot; } /** * \@description * * Represents the start of end of the Resolve phase of routing. See note on * `ActivationEnd` for use of this experimental API. * * \@publicApi */ export class ActivationStart { /** * @param {?} snapshot */ constructor(snapshot) { this.snapshot = snapshot; } /** * @return {?} */ toString() { /** @type {?} */ const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || ''; return `ActivationStart(path: '${path}')`; } } if (false) { /** * \@docsNotRequired * @type {?} */ ActivationStart.prototype.snapshot; } /** * \@description * * Represents the start of end of the Resolve phase of routing. See note on * `ActivationStart` for use of this experimental API. * * \@publicApi */ export class ActivationEnd { /** * @param {?} snapshot */ constructor(snapshot) { this.snapshot = snapshot; } /** * @return {?} */ toString() { /** @type {?} */ const path = this.snapshot.routeConfig && this.snapshot.routeConfig.path || ''; return `ActivationEnd(path: '${path}')`; } } if (false) { /** * \@docsNotRequired * @type {?} */ ActivationEnd.prototype.snapshot; } /** * \@description * * Represents a scrolling event. * * \@publicApi */ export class Scroll { /** * @param {?} routerEvent * @param {?} position * @param {?} anchor */ constructor(/** @docsNotRequired */ routerEvent, /** @docsNotRequired */ position, /** @docsNotRequired */ anchor) { this.routerEvent = routerEvent; this.position = position; this.anchor = anchor; } /** * @return {?} */ toString() { /** @type {?} */ const pos = this.position ? `${this.position[0]}, ${this.position[1]}` : null; return `Scroll(anchor: '${this.anchor}', position: '${pos}')`; } } if (false) { /** * \@docsNotRequired * @type {?} */ Scroll.prototype.routerEvent; /** * \@docsNotRequired * @type {?} */ Scroll.prototype.position; /** * \@docsNotRequired * @type {?} */ Scroll.prototype.anchor; } /** @typedef {?} */ var Event; export { Event }; //# 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 * @publicApi\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 * @publicApi\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 * @publicApi\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 * @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  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 * @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  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 * @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  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 * @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  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 * @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  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 * @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  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 * @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  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 * @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  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 * @publicApi\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 * @publicApi\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 * @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 * @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 * @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 * @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 * @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 * @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 * @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 * @description\n *\n * Represents a scrolling event.\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 * @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 * - `Scroll`\n *\n * @publicApi\n */\nexport type Event = RouterEvent | RouteConfigLoadStart | RouteConfigLoadEnd | ChildActivationStart |\n    ChildActivationEnd | ActivationStart | ActivationEnd | Scroll;\n"]}