@angular/router 6.1.6 → 6.1.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/bundles/router-testing.umd.js +37 -26
  2. package/bundles/router-testing.umd.js.map +1 -1
  3. package/bundles/router-testing.umd.min.js +4 -4
  4. package/bundles/router-testing.umd.min.js.map +1 -1
  5. package/bundles/router-upgrade.umd.js +1 -1
  6. package/bundles/router-upgrade.umd.min.js +1 -1
  7. package/bundles/router-upgrade.umd.min.js.map +1 -1
  8. package/bundles/router.umd.js +214 -126
  9. package/bundles/router.umd.js.map +1 -1
  10. package/bundles/router.umd.min.js +19 -19
  11. package/bundles/router.umd.min.js.map +1 -1
  12. package/esm2015/src/config.js +1 -1
  13. package/esm2015/src/router.js +36 -12
  14. package/esm2015/src/router_module.js +2 -1
  15. package/esm2015/src/router_state.js +3 -1
  16. package/esm2015/src/url_tree.js +4 -2
  17. package/esm2015/src/version.js +1 -1
  18. package/esm2015/testing/src/router_testing_module.js +2 -1
  19. package/esm5/src/components/empty_outlet.js +5 -4
  20. package/esm5/src/config.js +1 -1
  21. package/esm5/src/directives/router_link.js +100 -45
  22. package/esm5/src/directives/router_link_active.js +27 -20
  23. package/esm5/src/directives/router_outlet.js +16 -16
  24. package/esm5/src/router.js +30 -11
  25. package/esm5/src/router_module.js +20 -22
  26. package/esm5/src/router_preloader.js +6 -12
  27. package/esm5/src/router_state.js +3 -1
  28. package/esm5/src/url_tree.js +4 -2
  29. package/esm5/src/version.js +1 -1
  30. package/esm5/testing/src/router_testing_module.js +26 -26
  31. package/fesm2015/router.js +39 -14
  32. package/fesm2015/router.js.map +1 -1
  33. package/fesm2015/testing.js +2 -1
  34. package/fesm2015/testing.js.map +1 -1
  35. package/fesm2015/upgrade.js +1 -1
  36. package/fesm5/router.js +201 -128
  37. package/fesm5/router.js.map +1 -1
  38. package/fesm5/testing.js +27 -27
  39. package/fesm5/testing.js.map +1 -1
  40. package/fesm5/upgrade.js +1 -1
  41. package/package.json +4 -4
  42. package/router.metadata.json +1 -1
  43. package/src/config.d.ts +1 -0
  44. package/src/router.d.ts +21 -8
  45. package/src/router_module.d.ts +1 -0
  46. package/src/router_state.d.ts +2 -0
  47. package/src/url_tree.d.ts +3 -1
  48. package/testing/src/router_testing_module.d.ts +1 -0
  49. package/testing/testing.metadata.json +1 -1
@@ -9,7 +9,7 @@
9
9
  * Use of this source code is governed by an MIT-style license that can be
10
10
  * found in the LICENSE file at https://angular.io/license
11
11
  */
12
- import { NgModuleRef, isDevMode } from '@angular/core';
12
+ import { NgModuleRef, NgZone, isDevMode, ɵConsole as Console } from '@angular/core';
13
13
  import { BehaviorSubject, Subject, of } from 'rxjs';
14
14
  import { concatMap, map, mergeMap } from 'rxjs/operators';
15
15
  import { applyRedirects } from './apply_redirects';
@@ -210,6 +210,7 @@ export class Router {
210
210
  this.config = config;
211
211
  this.navigations = new BehaviorSubject(/** @type {?} */ ((null)));
212
212
  this.navigationId = 0;
213
+ this.isNgZoneEnabled = false;
213
214
  this.events = new Subject();
214
215
  /**
215
216
  * Error handler that is invoked when a navigation errors.
@@ -278,6 +279,10 @@ export class Router {
278
279
  /** @type {?} */
279
280
  const onLoadEnd = (r) => this.triggerEvent(new RouteConfigLoadEnd(r));
280
281
  this.ngModule = injector.get(NgModuleRef);
282
+ this.console = injector.get(Console);
283
+ /** @type {?} */
284
+ const ngZone = injector.get(NgZone);
285
+ this.isNgZoneEnabled = ngZone instanceof NgZone;
281
286
  this.resetConfig(config);
282
287
  this.currentUrlTree = createEmptyUrlTree();
283
288
  this.rawUrlTree = this.currentUrlTree;
@@ -336,14 +341,16 @@ export class Router {
336
341
  get url() { return this.serializeUrl(this.currentUrlTree); }
337
342
  /**
338
343
  * \@internal
339
- * @param {?} e
344
+ * @param {?} event
340
345
  * @return {?}
341
346
  */
342
- triggerEvent(e) { (/** @type {?} */ (this.events)).next(e); }
347
+ triggerEvent(event) { (/** @type {?} */ (this.events)).next(event); }
343
348
  /**
344
349
  * Resets the configuration used for navigation and generating links.
345
350
  *
346
- * ### Usage
351
+ * \@usageNotes
352
+ *
353
+ * ### Example
347
354
  *
348
355
  * ```
349
356
  * router.resetConfig([
@@ -383,7 +390,9 @@ export class Router {
383
390
  * When given an activate route, applies the given commands starting from the route.
384
391
  * When not given a route, applies the given command starting from the root.
385
392
  *
386
- * ### Usage
393
+ * \@usageNotes
394
+ *
395
+ * ### Example
387
396
  *
388
397
  * ```
389
398
  * // create /team/33/user/11
@@ -460,7 +469,9 @@ export class Router {
460
469
  * - resolves to 'false' when navigation fails,
461
470
  * - is rejected when an error happens.
462
471
  *
463
- * ### Usage
472
+ * \@usageNotes
473
+ *
474
+ * ### Example
464
475
  *
465
476
  * ```
466
477
  * router.navigateByUrl("/team/33/user/11");
@@ -469,13 +480,18 @@ export class Router {
469
480
  * router.navigateByUrl("/team/33/user/11", { skipLocationChange: true });
470
481
  * ```
471
482
  *
472
- * In opposite to `navigate`, `navigateByUrl` takes a whole URL
473
- * and does not apply any delta to the current one.
483
+ * Since `navigateByUrl()` takes an absolute URL as the first parameter,
484
+ * it will not apply any delta to the current URL and ignores any properties
485
+ * in the second parameter (the `NavigationExtras`) that would change the
486
+ * provided URL.
474
487
  * @param {?} url
475
488
  * @param {?=} extras
476
489
  * @return {?}
477
490
  */
478
491
  navigateByUrl(url, extras = { skipLocationChange: false }) {
492
+ if (isDevMode() && this.isNgZoneEnabled && !NgZone.isInAngularZone()) {
493
+ this.console.warn(`Navigation triggered outside Angular zone, did you forget to call 'ngZone.run()'?`);
494
+ }
479
495
  /** @type {?} */
480
496
  const urlTree = url instanceof UrlTree ? url : this.parseUrl(url);
481
497
  /** @type {?} */
@@ -491,7 +507,9 @@ export class Router {
491
507
  * - resolves to 'false' when navigation fails,
492
508
  * - is rejected when an error happens.
493
509
  *
494
- * ### Usage
510
+ * \@usageNotes
511
+ *
512
+ * ### Example
495
513
  *
496
514
  * ```
497
515
  * router.navigate(['team', 33, 'user', 11], {relativeTo: route});
@@ -500,8 +518,9 @@ export class Router {
500
518
  * router.navigate(['team', 33, 'user', 11], {relativeTo: route, skipLocationChange: true});
501
519
  * ```
502
520
  *
503
- * In opposite to `navigateByUrl`, `navigate` always takes a delta that is applied to the current
504
- * URL.
521
+ * The first parameter of `navigate()` is a delta to be applied to the current URL
522
+ * or the one provided in the `relativeTo` property of the second parameter (the
523
+ * `NavigationExtras`).
505
524
  * @param {?} commands
506
525
  * @param {?=} extras
507
526
  * @return {?}
@@ -896,6 +915,10 @@ if (false) {
896
915
  /** @type {?} */
897
916
  Router.prototype.ngModule;
898
917
  /** @type {?} */
918
+ Router.prototype.console;
919
+ /** @type {?} */
920
+ Router.prototype.isNgZoneEnabled;
921
+ /** @type {?} */
899
922
  Router.prototype.events;
900
923
  /** @type {?} */
901
924
  Router.prototype.routerState;
@@ -1174,6 +1197,7 @@ class ActivateRoutes {
1174
1197
  const config = parentLoadedConfig(future.snapshot);
1175
1198
  /** @type {?} */
1176
1199
  const cmpFactoryResolver = config ? config.module.componentFactoryResolver : null;
1200
+ context.attachRef = null;
1177
1201
  context.route = future;
1178
1202
  context.resolver = cmpFactoryResolver;
1179
1203
  if (context.outlet) {
@@ -1238,4 +1262,4 @@ function validateCommands(commands) {
1238
1262
  }
1239
1263
  }
1240
1264
 
1241
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.js","sourceRoot":"","sources":["../../../../../../packages/router/src/router.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 {Location} from '@angular/common';\nimport {Compiler, Injector, NgModuleFactoryLoader, NgModuleRef, Type, isDevMode} from '@angular/core';\nimport {BehaviorSubject, Observable, Subject, Subscription, of } from 'rxjs';\nimport {concatMap, map, mergeMap} from 'rxjs/operators';\n\nimport {applyRedirects} from './apply_redirects';\nimport {LoadedRouterConfig, QueryParamsHandling, Route, Routes, standardizeConfig, validateConfig} from './config';\nimport {createRouterState} from './create_router_state';\nimport {createUrlTree} from './create_url_tree';\nimport {ActivationEnd, ChildActivationEnd, Event, GuardsCheckEnd, GuardsCheckStart, NavigationCancel, NavigationEnd, NavigationError, NavigationStart, NavigationTrigger, ResolveEnd, ResolveStart, RouteConfigLoadEnd, RouteConfigLoadStart, RoutesRecognized} from './events';\nimport {PreActivation} from './pre_activation';\nimport {recognize} from './recognize';\nimport {DefaultRouteReuseStrategy, DetachedRouteHandleInternal, RouteReuseStrategy} from './route_reuse_strategy';\nimport {RouterConfigLoader} from './router_config_loader';\nimport {ChildrenOutletContexts} from './router_outlet_context';\nimport {ActivatedRoute, ActivatedRouteSnapshot, RouterState, RouterStateSnapshot, advanceActivatedRoute, createEmptyState, inheritedParamsDataResolve} from './router_state';\nimport {Params, isNavigationCancelingError} from './shared';\nimport {DefaultUrlHandlingStrategy, UrlHandlingStrategy} from './url_handling_strategy';\nimport {UrlSerializer, UrlTree, containsTree, createEmptyUrlTree} from './url_tree';\nimport {forEach} from './utils/collection';\nimport {TreeNode, nodeChildrenAsMap} from './utils/tree';\n\n\n/**\n * @description\n *\n * Represents the extra options used during navigation.\n *\n *\n */\nexport interface NavigationExtras {\n  /**\n   * Enables relative navigation from the current ActivatedRoute.\n   *\n   * Configuration:\n   *\n   * ```\n   * [{\n  *   path: 'parent',\n  *   component: ParentComponent,\n  *   children: [{\n  *     path: 'list',\n  *     component: ListComponent\n  *   },{\n  *     path: 'child',\n  *     component: ChildComponent\n  *   }]\n  * }]\n   * ```\n   *\n   * Navigate to list route from child route:\n   *\n   * ```\n   *  @Component({...})\n   *  class ChildComponent {\n  *    constructor(private router: Router, private route: ActivatedRoute) {}\n  *\n  *    go() {\n  *      this.router.navigate(['../list'], { relativeTo: this.route });\n  *    }\n  *  }\n   * ```\n   */\n  relativeTo?: ActivatedRoute|null;\n\n  /**\n   * Sets query parameters to the URL.\n   *\n   * ```\n   * // Navigate to /results?page=1\n   * this.router.navigate(['/results'], { queryParams: { page: 1 } });\n   * ```\n   */\n  queryParams?: Params|null;\n\n  /**\n   * Sets the hash fragment for the URL.\n   *\n   * ```\n   * // Navigate to /results#top\n   * this.router.navigate(['/results'], { fragment: 'top' });\n   * ```\n   */\n  fragment?: string;\n\n  /**\n   * Preserves the query parameters for the next navigation.\n   *\n   * deprecated, use `queryParamsHandling` instead\n   *\n   * ```\n   * // Preserve query params from /results?page=1 to /view?page=1\n   * this.router.navigate(['/view'], { preserveQueryParams: true });\n   * ```\n   *\n   * @deprecated since v4\n   */\n  preserveQueryParams?: boolean;\n\n  /**\n   *  config strategy to handle the query parameters for the next navigation.\n   *\n   * ```\n   * // from /results?page=1 to /view?page=1&page=2\n   * this.router.navigate(['/view'], { queryParams: { page: 2 },  queryParamsHandling: \"merge\" });\n   * ```\n   */\n  queryParamsHandling?: QueryParamsHandling|null;\n  /**\n   * Preserves the fragment for the next navigation\n   *\n   * ```\n   * // Preserve fragment from /results#top to /view#top\n   * this.router.navigate(['/view'], { preserveFragment: true });\n   * ```\n   */\n  preserveFragment?: boolean;\n  /**\n   * Navigates without pushing a new state into history.\n   *\n   * ```\n   * // Navigate silently to /view\n   * this.router.navigate(['/view'], { skipLocationChange: true });\n   * ```\n   */\n  skipLocationChange?: boolean;\n  /**\n   * Navigates while replacing the current state in history.\n   *\n   * ```\n   * // Navigate to /view\n   * this.router.navigate(['/view'], { replaceUrl: true });\n   * ```\n   */\n  replaceUrl?: boolean;\n}\n\n/**\n * @description\n *\n * Error handler that is invoked when a navigation errors.\n *\n * If the handler returns a value, the navigation promise will be resolved with this value.\n * If the handler throws an exception, the navigation promise will be rejected with\n * the exception.\n *\n *\n */\nexport type ErrorHandler = (error: any) => any;\n\nfunction defaultErrorHandler(error: any): any {\n  throw error;\n}\n\nfunction defaultMalformedUriErrorHandler(\n    error: URIError, urlSerializer: UrlSerializer, url: string): UrlTree {\n  return urlSerializer.parse('/');\n}\n\ntype NavStreamValue =\n    boolean | {appliedUrl: UrlTree, snapshot: RouterStateSnapshot, shouldActivate?: boolean};\n\ntype NavigationParams = {\n  id: number,\n  rawUrl: UrlTree,\n  extras: NavigationExtras,\n  resolve: any,\n  reject: any,\n  promise: Promise<boolean>,\n  source: NavigationTrigger,\n  state: {navigationId: number} | null\n};\n\n/**\n * @internal\n */\nexport type RouterHook = (snapshot: RouterStateSnapshot, runExtras: {\n  appliedUrlTree: UrlTree,\n  rawUrlTree: UrlTree,\n  skipLocationChange: boolean,\n  replaceUrl: boolean,\n  navigationId: number\n}) => Observable<void>;\n\n/**\n * @internal\n */\nfunction defaultRouterHook(snapshot: RouterStateSnapshot, runExtras: {\n  appliedUrlTree: UrlTree,\n  rawUrlTree: UrlTree,\n  skipLocationChange: boolean,\n  replaceUrl: boolean,\n  navigationId: number\n}): Observable<void> {\n  return of (null) as any;\n}\n\n/**\n * @description\n *\n * Provides the navigation and url manipulation capabilities.\n *\n * See `Routes` for more details and examples.\n *\n * @ngModule RouterModule\n *\n *\n */\nexport class Router {\n  private currentUrlTree: UrlTree;\n  private rawUrlTree: UrlTree;\n  private navigations = new BehaviorSubject<NavigationParams>(null !);\n\n  // TODO(issue/24571): remove '!'.\n  private locationSubscription !: Subscription;\n  private navigationId: number = 0;\n  private configLoader: RouterConfigLoader;\n  private ngModule: NgModuleRef<any>;\n\n  public readonly events: Observable<Event> = new Subject<Event>();\n  public readonly routerState: RouterState;\n\n  /**\n   * Error handler that is invoked when a navigation errors.\n   *\n   * See `ErrorHandler` for more information.\n   */\n  errorHandler: ErrorHandler = defaultErrorHandler;\n\n  /**\n   * Malformed uri error handler is invoked when `Router.parseUrl(url)` throws an\n   * error due to containing an invalid character. The most common case would be a `%` sign\n   * that's not encoded and is not part of a percent encoded sequence.\n   */\n  malformedUriErrorHandler:\n      (error: URIError, urlSerializer: UrlSerializer,\n       url: string) => UrlTree = defaultMalformedUriErrorHandler;\n\n  /**\n   * Indicates if at least one navigation happened.\n   */\n  navigated: boolean = false;\n  private lastSuccessfulId: number = -1;\n\n  /**\n   * Used by RouterModule. This allows us to\n   * pause the navigation either before preactivation or after it.\n   * @internal\n   */\n  hooks: {beforePreactivation: RouterHook, afterPreactivation: RouterHook} = {\n    beforePreactivation: defaultRouterHook,\n    afterPreactivation: defaultRouterHook\n  };\n\n  /**\n   * Extracts and merges URLs. Used for AngularJS to Angular migrations.\n   */\n  urlHandlingStrategy: UrlHandlingStrategy = new DefaultUrlHandlingStrategy();\n\n  routeReuseStrategy: RouteReuseStrategy = new DefaultRouteReuseStrategy();\n\n  /**\n   * Define what the router should do if it receives a navigation request to the current URL.\n   * By default, the router will ignore this navigation. However, this prevents features such\n   * as a \"refresh\" button. Use this option to configure the behavior when navigating to the\n   * current URL. Default is 'ignore'.\n   */\n  onSameUrlNavigation: 'reload'|'ignore' = 'ignore';\n\n  /**\n   * Defines how the router merges params, data and resolved data from parent to child\n   * routes. Available options are:\n   *\n   * - `'emptyOnly'`, the default, only inherits parent params for path-less or component-less\n   *   routes.\n   * - `'always'`, enables unconditional inheritance of parent params.\n   */\n  paramsInheritanceStrategy: 'emptyOnly'|'always' = 'emptyOnly';\n\n  /**\n   * Defines when the router updates the browser URL. The default behavior is to update after\n   * successful navigation. However, some applications may prefer a mode where the URL gets\n   * updated at the beginning of navigation. The most common use case would be updating the\n   * URL early so if navigation fails, you can show an error message with the URL that failed.\n   * Available options are:\n   *\n   * - `'deferred'`, the default, updates the browser URL after navigation has finished.\n   * - `'eager'`, updates browser URL at the beginning of navigation.\n   */\n  urlUpdateStrategy: 'deferred'|'eager' = 'deferred';\n\n  /**\n   * See {@link RouterModule} for more information.\n   */\n  relativeLinkResolution: 'legacy'|'corrected' = 'legacy';\n\n  /**\n   * Creates the router service.\n   */\n  // TODO: vsavkin make internal after the final is out.\n  constructor(\n      private rootComponentType: Type<any>|null, private urlSerializer: UrlSerializer,\n      private rootContexts: ChildrenOutletContexts, private location: Location, injector: Injector,\n      loader: NgModuleFactoryLoader, compiler: Compiler, public config: Routes) {\n    const onLoadStart = (r: Route) => this.triggerEvent(new RouteConfigLoadStart(r));\n    const onLoadEnd = (r: Route) => this.triggerEvent(new RouteConfigLoadEnd(r));\n\n    this.ngModule = injector.get(NgModuleRef);\n\n    this.resetConfig(config);\n    this.currentUrlTree = createEmptyUrlTree();\n    this.rawUrlTree = this.currentUrlTree;\n\n    this.configLoader = new RouterConfigLoader(loader, compiler, onLoadStart, onLoadEnd);\n    this.routerState = createEmptyState(this.currentUrlTree, this.rootComponentType);\n    this.processNavigations();\n  }\n\n  /**\n   * @internal\n   * TODO: this should be removed once the constructor of the router made internal\n   */\n  resetRootComponentType(rootComponentType: Type<any>): void {\n    this.rootComponentType = rootComponentType;\n    // TODO: vsavkin router 4.0 should make the root component set to null\n    // this will simplify the lifecycle of the router.\n    this.routerState.root.component = this.rootComponentType;\n  }\n\n  /**\n   * Sets up the location change listener and performs the initial navigation.\n   */\n  initialNavigation(): void {\n    this.setUpLocationChangeListener();\n    if (this.navigationId === 0) {\n      this.navigateByUrl(this.location.path(true), {replaceUrl: true});\n    }\n  }\n\n  /**\n   * Sets up the location change listener.\n   */\n  setUpLocationChangeListener(): void {\n    // Don't need to use Zone.wrap any more, because zone.js\n    // already patch onPopState, so location change callback will\n    // run into ngZone\n    if (!this.locationSubscription) {\n      this.locationSubscription = <any>this.location.subscribe((change: any) => {\n        let rawUrlTree = this.parseUrl(change['url']);\n        const source: NavigationTrigger = change['type'] === 'popstate' ? 'popstate' : 'hashchange';\n        const state = change.state && change.state.navigationId ?\n            {navigationId: change.state.navigationId} :\n            null;\n        setTimeout(\n            () => { this.scheduleNavigation(rawUrlTree, source, state, {replaceUrl: true}); }, 0);\n      });\n    }\n  }\n\n  /** The current url */\n  get url(): string { return this.serializeUrl(this.currentUrlTree); }\n\n  /** @internal */\n  triggerEvent(e: Event): void { (this.events as Subject<Event>).next(e); }\n\n  /**\n   * Resets the configuration used for navigation and generating links.\n   *\n   * ### Usage\n   *\n   * ```\n   * router.resetConfig([\n   *  { path: 'team/:id', component: TeamCmp, children: [\n   *    { path: 'simple', component: SimpleCmp },\n   *    { path: 'user/:name', component: UserCmp }\n   *  ]}\n   * ]);\n   * ```\n   */\n  resetConfig(config: Routes): void {\n    validateConfig(config);\n    this.config = config.map(standardizeConfig);\n    this.navigated = false;\n    this.lastSuccessfulId = -1;\n  }\n\n  /** @docsNotRequired */\n  ngOnDestroy(): void { this.dispose(); }\n\n  /** Disposes of the router */\n  dispose(): void {\n    if (this.locationSubscription) {\n      this.locationSubscription.unsubscribe();\n      this.locationSubscription = null !;\n    }\n  }\n\n  /**\n   * Applies an array of commands to the current url tree and creates a new url tree.\n   *\n   * When given an activate route, applies the given commands starting from the route.\n   * When not given a route, applies the given command starting from the root.\n   *\n   * ### Usage\n   *\n   * ```\n   * // create /team/33/user/11\n   * router.createUrlTree(['/team', 33, 'user', 11]);\n   *\n   * // create /team/33;expand=true/user/11\n   * router.createUrlTree(['/team', 33, {expand: true}, 'user', 11]);\n   *\n   * // you can collapse static segments like this (this works only with the first passed-in value):\n   * router.createUrlTree(['/team/33/user', userId]);\n   *\n   * // If the first segment can contain slashes, and you do not want the router to split it, you\n   * // can do the following:\n   *\n   * router.createUrlTree([{segmentPath: '/one/two'}]);\n   *\n   * // create /team/33/(user/11//right:chat)\n   * router.createUrlTree(['/team', 33, {outlets: {primary: 'user/11', right: 'chat'}}]);\n   *\n   * // remove the right secondary node\n   * router.createUrlTree(['/team', 33, {outlets: {primary: 'user/11', right: null}}]);\n   *\n   * // assuming the current url is `/team/33/user/11` and the route points to `user/11`\n   *\n   * // navigate to /team/33/user/11/details\n   * router.createUrlTree(['details'], {relativeTo: route});\n   *\n   * // navigate to /team/33/user/22\n   * router.createUrlTree(['../22'], {relativeTo: route});\n   *\n   * // navigate to /team/44/user/22\n   * router.createUrlTree(['../../team/44/user/22'], {relativeTo: route});\n   * ```\n   */\n  createUrlTree(commands: any[], navigationExtras: NavigationExtras = {}): UrlTree {\n    const {relativeTo,          queryParams,         fragment,\n           preserveQueryParams, queryParamsHandling, preserveFragment} = navigationExtras;\n    if (isDevMode() && preserveQueryParams && <any>console && <any>console.warn) {\n      console.warn('preserveQueryParams is deprecated, use queryParamsHandling instead.');\n    }\n    const a = relativeTo || this.routerState.root;\n    const f = preserveFragment ? this.currentUrlTree.fragment : fragment;\n    let q: Params|null = null;\n    if (queryParamsHandling) {\n      switch (queryParamsHandling) {\n        case 'merge':\n          q = {...this.currentUrlTree.queryParams, ...queryParams};\n          break;\n        case 'preserve':\n          q = this.currentUrlTree.queryParams;\n          break;\n        default:\n          q = queryParams || null;\n      }\n    } else {\n      q = preserveQueryParams ? this.currentUrlTree.queryParams : queryParams || null;\n    }\n    if (q !== null) {\n      q = this.removeEmptyProps(q);\n    }\n    return createUrlTree(a, this.currentUrlTree, commands, q !, f !);\n  }\n\n  /**\n   * Navigate based on the provided url. This navigation is always absolute.\n   *\n   * Returns a promise that:\n   * - resolves to 'true' when navigation succeeds,\n   * - resolves to 'false' when navigation fails,\n   * - is rejected when an error happens.\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigateByUrl(\"/team/33/user/11\");\n   *\n   * // Navigate without updating the URL\n   * router.navigateByUrl(\"/team/33/user/11\", { skipLocationChange: true });\n   * ```\n   *\n   * In opposite to `navigate`, `navigateByUrl` takes a whole URL\n   * and does not apply any delta to the current one.\n   */\n  navigateByUrl(url: string|UrlTree, extras: NavigationExtras = {skipLocationChange: false}):\n      Promise<boolean> {\n    const urlTree = url instanceof UrlTree ? url : this.parseUrl(url);\n    const mergedTree = this.urlHandlingStrategy.merge(urlTree, this.rawUrlTree);\n\n    return this.scheduleNavigation(mergedTree, 'imperative', null, extras);\n  }\n\n  /**\n   * Navigate based on the provided array of commands and a starting point.\n   * If no starting route is provided, the navigation is absolute.\n   *\n   * Returns a promise that:\n   * - resolves to 'true' when navigation succeeds,\n   * - resolves to 'false' when navigation fails,\n   * - is rejected when an error happens.\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigate(['team', 33, 'user', 11], {relativeTo: route});\n   *\n   * // Navigate without updating the URL\n   * router.navigate(['team', 33, 'user', 11], {relativeTo: route, skipLocationChange: true});\n   * ```\n   *\n   * In opposite to `navigateByUrl`, `navigate` always takes a delta that is applied to the current\n   * URL.\n   */\n  navigate(commands: any[], extras: NavigationExtras = {skipLocationChange: false}):\n      Promise<boolean> {\n    validateCommands(commands);\n    return this.navigateByUrl(this.createUrlTree(commands, extras), extras);\n  }\n\n  /** Serializes a `UrlTree` into a string */\n  serializeUrl(url: UrlTree): string { return this.urlSerializer.serialize(url); }\n\n  /** Parses a string into a `UrlTree` */\n  parseUrl(url: string): UrlTree {\n    let urlTree: UrlTree;\n    try {\n      urlTree = this.urlSerializer.parse(url);\n    } catch (e) {\n      urlTree = this.malformedUriErrorHandler(e, this.urlSerializer, url);\n    }\n    return urlTree;\n  }\n\n  /** Returns whether the url is activated */\n  isActive(url: string|UrlTree, exact: boolean): boolean {\n    if (url instanceof UrlTree) {\n      return containsTree(this.currentUrlTree, url, exact);\n    }\n\n    const urlTree = this.parseUrl(url);\n    return containsTree(this.currentUrlTree, urlTree, exact);\n  }\n\n  private removeEmptyProps(params: Params): Params {\n    return Object.keys(params).reduce((result: Params, key: string) => {\n      const value: any = params[key];\n      if (value !== null && value !== undefined) {\n        result[key] = value;\n      }\n      return result;\n    }, {});\n  }\n\n  private processNavigations(): void {\n    this.navigations\n        .pipe(concatMap((nav: NavigationParams) => {\n          if (nav) {\n            this.executeScheduledNavigation(nav);\n            // a failed navigation should not stop the router from processing\n            // further navigations => the catch\n            return nav.promise.catch(() => {});\n          } else {\n            return <any>of (null);\n          }\n        }))\n        .subscribe(() => {});\n  }\n\n  private scheduleNavigation(\n      rawUrl: UrlTree, source: NavigationTrigger, state: {navigationId: number}|null,\n      extras: NavigationExtras): Promise<boolean> {\n    const lastNavigation = this.navigations.value;\n    // If the user triggers a navigation imperatively (e.g., by using navigateByUrl),\n    // and that navigation results in 'replaceState' that leads to the same URL,\n    // we should skip those.\n    if (lastNavigation && source !== 'imperative' && lastNavigation.source === 'imperative' &&\n        lastNavigation.rawUrl.toString() === rawUrl.toString()) {\n      return Promise.resolve(true);  // return value is not used\n    }\n\n    // Because of a bug in IE and Edge, the location class fires two events (popstate and\n    // hashchange) every single time. The second one should be ignored. Otherwise, the URL will\n    // flicker. Handles the case when a popstate was emitted first.\n    if (lastNavigation && source == 'hashchange' && lastNavigation.source === 'popstate' &&\n        lastNavigation.rawUrl.toString() === rawUrl.toString()) {\n      return Promise.resolve(true);  // return value is not used\n    }\n    // Because of a bug in IE and Edge, the location class fires two events (popstate and\n    // hashchange) every single time. The second one should be ignored. Otherwise, the URL will\n    // flicker. Handles the case when a hashchange was emitted first.\n    if (lastNavigation && source == 'popstate' && lastNavigation.source === 'hashchange' &&\n        lastNavigation.rawUrl.toString() === rawUrl.toString()) {\n      return Promise.resolve(true);  // return value is not used\n    }\n\n    let resolve: any = null;\n    let reject: any = null;\n\n    const promise = new Promise<boolean>((res, rej) => {\n      resolve = res;\n      reject = rej;\n    });\n\n    const id = ++this.navigationId;\n    this.navigations.next({id, source, state, rawUrl, extras, resolve, reject, promise});\n\n    // Make sure that the error is propagated even though `processNavigations` catch\n    // handler does not rethrow\n    return promise.catch((e: any) => Promise.reject(e));\n  }\n\n  private executeScheduledNavigation({id, rawUrl, extras, resolve, reject, source,\n                                      state}: NavigationParams): void {\n    const url = this.urlHandlingStrategy.extract(rawUrl);\n    const urlTransition = !this.navigated || url.toString() !== this.currentUrlTree.toString();\n\n    if ((this.onSameUrlNavigation === 'reload' ? true : urlTransition) &&\n        this.urlHandlingStrategy.shouldProcessUrl(rawUrl)) {\n      if (this.urlUpdateStrategy === 'eager' && !extras.skipLocationChange) {\n        this.setBrowserUrl(rawUrl, !!extras.replaceUrl, id);\n      }\n      (this.events as Subject<Event>)\n          .next(new NavigationStart(id, this.serializeUrl(url), source, state));\n      Promise.resolve()\n          .then(\n              (_) => this.runNavigate(\n                  url, rawUrl, !!extras.skipLocationChange, !!extras.replaceUrl, id, null))\n          .then(resolve, reject);\n\n      // we cannot process the current URL, but we could process the previous one =>\n      // we need to do some cleanup\n    } else if (\n        urlTransition && this.rawUrlTree &&\n        this.urlHandlingStrategy.shouldProcessUrl(this.rawUrlTree)) {\n      (this.events as Subject<Event>)\n          .next(new NavigationStart(id, this.serializeUrl(url), source, state));\n      Promise.resolve()\n          .then(\n              (_) => this.runNavigate(\n                  url, rawUrl, false, false, id,\n                  createEmptyState(url, this.rootComponentType).snapshot))\n          .then(resolve, reject);\n\n    } else {\n      this.rawUrlTree = rawUrl;\n      resolve(null);\n    }\n  }\n\n  private runNavigate(\n      url: UrlTree, rawUrl: UrlTree, skipLocationChange: boolean, replaceUrl: boolean, id: number,\n      precreatedState: RouterStateSnapshot|null): Promise<boolean> {\n    if (id !== this.navigationId) {\n      (this.events as Subject<Event>)\n          .next(new NavigationCancel(\n              id, this.serializeUrl(url),\n              `Navigation ID ${id} is not equal to the current navigation id ${this.navigationId}`));\n      return Promise.resolve(false);\n    }\n\n    return new Promise((resolvePromise, rejectPromise) => {\n      // create an observable of the url and route state snapshot\n      // this operation do not result in any side effects\n      let urlAndSnapshot$: Observable<NavStreamValue>;\n      if (!precreatedState) {\n        const moduleInjector = this.ngModule.injector;\n        const redirectsApplied$ =\n            applyRedirects(moduleInjector, this.configLoader, this.urlSerializer, url, this.config);\n\n        urlAndSnapshot$ = redirectsApplied$.pipe(mergeMap((appliedUrl: UrlTree) => {\n          return recognize(\n                     this.rootComponentType, this.config, appliedUrl, this.serializeUrl(appliedUrl),\n                     this.paramsInheritanceStrategy, this.relativeLinkResolution)\n              .pipe(map((snapshot: any) => {\n                (this.events as Subject<Event>)\n                    .next(new RoutesRecognized(\n                        id, this.serializeUrl(url), this.serializeUrl(appliedUrl), snapshot));\n\n                return {appliedUrl, snapshot};\n              }));\n        }));\n      } else {\n        urlAndSnapshot$ = of ({appliedUrl: url, snapshot: precreatedState});\n      }\n\n      const beforePreactivationDone$ =\n          urlAndSnapshot$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean') return of (p);\n            return this.hooks\n                .beforePreactivation(p.snapshot, {\n                  navigationId: id,\n                  appliedUrlTree: url,\n                  rawUrlTree: rawUrl, skipLocationChange, replaceUrl,\n                })\n                .pipe(map(() => p));\n          }));\n\n      // run preactivation: guards and data resolvers\n      let preActivation: PreActivation;\n\n      const preactivationSetup$ = beforePreactivationDone$.pipe(map((p): NavStreamValue => {\n        if (typeof p === 'boolean') return p;\n        const {appliedUrl, snapshot} = p;\n        const moduleInjector = this.ngModule.injector;\n        preActivation = new PreActivation(\n            snapshot, this.routerState.snapshot, moduleInjector,\n            (evt: Event) => this.triggerEvent(evt));\n        preActivation.initialize(this.rootContexts);\n        return {appliedUrl, snapshot};\n      }));\n\n      const preactivationCheckGuards$ =\n          preactivationSetup$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean' || this.navigationId !== id) return of (false);\n            const {appliedUrl, snapshot} = p;\n\n            this.triggerEvent(new GuardsCheckStart(\n                id, this.serializeUrl(url), this.serializeUrl(appliedUrl), snapshot));\n\n            return preActivation.checkGuards().pipe(map((shouldActivate: boolean) => {\n              this.triggerEvent(new GuardsCheckEnd(\n                  id, this.serializeUrl(url), this.serializeUrl(appliedUrl), snapshot,\n                  shouldActivate));\n              return {appliedUrl: appliedUrl, snapshot: snapshot, shouldActivate: shouldActivate};\n            }));\n          }));\n\n      const preactivationResolveData$ =\n          preactivationCheckGuards$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean' || this.navigationId !== id) return of (false);\n\n            if (p.shouldActivate && preActivation.isActivating()) {\n              this.triggerEvent(new ResolveStart(\n                  id, this.serializeUrl(url), this.serializeUrl(p.appliedUrl), p.snapshot));\n              return preActivation.resolveData(this.paramsInheritanceStrategy).pipe(map(() => {\n                this.triggerEvent(new ResolveEnd(\n                    id, this.serializeUrl(url), this.serializeUrl(p.appliedUrl), p.snapshot));\n                return p;\n              }));\n            } else {\n              return of (p);\n            }\n          }));\n\n      const preactivationDone$ =\n          preactivationResolveData$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean' || this.navigationId !== id) return of (false);\n            return this.hooks\n                .afterPreactivation(p.snapshot, {\n                  navigationId: id,\n                  appliedUrlTree: url,\n                  rawUrlTree: rawUrl, skipLocationChange, replaceUrl,\n                })\n                .pipe(map(() => p));\n          }));\n\n\n      // create router state\n      // this operation has side effects => route state is being affected\n      const routerState$ = preactivationDone$.pipe(map((p) => {\n        if (typeof p === 'boolean' || this.navigationId !== id) return false;\n        const {appliedUrl, snapshot, shouldActivate} = p;\n        if (shouldActivate) {\n          const state = createRouterState(this.routeReuseStrategy, snapshot, this.routerState);\n          return {appliedUrl, state, shouldActivate};\n        } else {\n          return {appliedUrl, state: null, shouldActivate};\n        }\n      }));\n\n\n      this.activateRoutes(\n          routerState$, this.routerState, this.currentUrlTree, id, url, rawUrl, skipLocationChange,\n          replaceUrl, resolvePromise, rejectPromise);\n    });\n  }\n\n  /**\n   * Performs the logic of activating routes. This is a synchronous process by default. While this\n   * is a private method, it could be overridden to make activation asynchronous.\n   */\n  private activateRoutes(\n      state: Observable<false|\n                        {appliedUrl: UrlTree, state: RouterState|null, shouldActivate?: boolean}>,\n      storedState: RouterState, storedUrl: UrlTree, id: number, url: UrlTree, rawUrl: UrlTree,\n      skipLocationChange: boolean, replaceUrl: boolean, resolvePromise: any, rejectPromise: any) {\n    // applied the new router state\n    // this operation has side effects\n    let navigationIsSuccessful: boolean;\n\n    state\n        .forEach((p) => {\n          if (typeof p === 'boolean' || !p.shouldActivate || id !== this.navigationId || !p.state) {\n            navigationIsSuccessful = false;\n            return;\n          }\n          const {appliedUrl, state} = p;\n          this.currentUrlTree = appliedUrl;\n          this.rawUrlTree = this.urlHandlingStrategy.merge(this.currentUrlTree, rawUrl);\n\n          (this as{routerState: RouterState}).routerState = state;\n\n          if (this.urlUpdateStrategy === 'deferred' && !skipLocationChange) {\n            this.setBrowserUrl(this.rawUrlTree, replaceUrl, id);\n          }\n\n          new ActivateRoutes(\n              this.routeReuseStrategy, state, storedState, (evt: Event) => this.triggerEvent(evt))\n              .activate(this.rootContexts);\n\n          navigationIsSuccessful = true;\n        })\n        .then(\n            () => {\n              if (navigationIsSuccessful) {\n                this.navigated = true;\n                this.lastSuccessfulId = id;\n                (this.events as Subject<Event>)\n                    .next(new NavigationEnd(\n                        id, this.serializeUrl(url), this.serializeUrl(this.currentUrlTree)));\n                resolvePromise(true);\n              } else {\n                this.resetUrlToCurrentUrlTree();\n                (this.events as Subject<Event>)\n                    .next(new NavigationCancel(id, this.serializeUrl(url), ''));\n                resolvePromise(false);\n              }\n            },\n            (e: any) => {\n              if (isNavigationCancelingError(e)) {\n                this.navigated = true;\n                this.resetStateAndUrl(storedState, storedUrl, rawUrl);\n                (this.events as Subject<Event>)\n                    .next(new NavigationCancel(id, this.serializeUrl(url), e.message));\n\n                resolvePromise(false);\n              } else {\n                this.resetStateAndUrl(storedState, storedUrl, rawUrl);\n                (this.events as Subject<Event>)\n                    .next(new NavigationError(id, this.serializeUrl(url), e));\n                try {\n                  resolvePromise(this.errorHandler(e));\n                } catch (ee) {\n                  rejectPromise(ee);\n                }\n              }\n            });\n  }\n\n  private setBrowserUrl(url: UrlTree, replaceUrl: boolean, id: number) {\n    const path = this.urlSerializer.serialize(url);\n    if (this.location.isCurrentPathEqualTo(path) || replaceUrl) {\n      this.location.replaceState(path, '', {navigationId: id});\n    } else {\n      this.location.go(path, '', {navigationId: id});\n    }\n  }\n\n  private resetStateAndUrl(storedState: RouterState, storedUrl: UrlTree, rawUrl: UrlTree): void {\n    (this as{routerState: RouterState}).routerState = storedState;\n    this.currentUrlTree = storedUrl;\n    this.rawUrlTree = this.urlHandlingStrategy.merge(this.currentUrlTree, rawUrl);\n    this.resetUrlToCurrentUrlTree();\n  }\n\n  private resetUrlToCurrentUrlTree(): void {\n    this.location.replaceState(\n        this.urlSerializer.serialize(this.rawUrlTree), '', {navigationId: this.lastSuccessfulId});\n  }\n}\n\nclass ActivateRoutes {\n  constructor(\n      private routeReuseStrategy: RouteReuseStrategy, private futureState: RouterState,\n      private currState: RouterState, private forwardEvent: (evt: Event) => void) {}\n\n  activate(parentContexts: ChildrenOutletContexts): void {\n    const futureRoot = this.futureState._root;\n    const currRoot = this.currState ? this.currState._root : null;\n\n    this.deactivateChildRoutes(futureRoot, currRoot, parentContexts);\n    advanceActivatedRoute(this.futureState.root);\n    this.activateChildRoutes(futureRoot, currRoot, parentContexts);\n  }\n\n  // De-activate the child route that are not re-used for the future state\n  private deactivateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      contexts: ChildrenOutletContexts): void {\n    const children: {[outletName: string]: TreeNode<ActivatedRoute>} = nodeChildrenAsMap(currNode);\n\n    // Recurse on the routes active in the future state to de-activate deeper children\n    futureNode.children.forEach(futureChild => {\n      const childOutletName = futureChild.value.outlet;\n      this.deactivateRoutes(futureChild, children[childOutletName], contexts);\n      delete children[childOutletName];\n    });\n\n    // De-activate the routes that will not be re-used\n    forEach(children, (v: TreeNode<ActivatedRoute>, childName: string) => {\n      this.deactivateRouteAndItsChildren(v, contexts);\n    });\n  }\n\n  private deactivateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      parentContext: ChildrenOutletContexts): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n\n    if (future === curr) {\n      // Reusing the node, check to see if the children need to be de-activated\n      if (future.component) {\n        // If we have a normal route, we need to go through an outlet.\n        const context = parentContext.getContext(future.outlet);\n        if (context) {\n          this.deactivateChildRoutes(futureNode, currNode, context.children);\n        }\n      } else {\n        // if we have a componentless route, we recurse but keep the same outlet map.\n        this.deactivateChildRoutes(futureNode, currNode, parentContext);\n      }\n    } else {\n      if (curr) {\n        // Deactivate the current route which will not be re-used\n        this.deactivateRouteAndItsChildren(currNode, parentContext);\n      }\n    }\n  }\n\n  private deactivateRouteAndItsChildren(\n      route: TreeNode<ActivatedRoute>, parentContexts: ChildrenOutletContexts): void {\n    if (this.routeReuseStrategy.shouldDetach(route.value.snapshot)) {\n      this.detachAndStoreRouteSubtree(route, parentContexts);\n    } else {\n      this.deactivateRouteAndOutlet(route, parentContexts);\n    }\n  }\n\n  private detachAndStoreRouteSubtree(\n      route: TreeNode<ActivatedRoute>, parentContexts: ChildrenOutletContexts): void {\n    const context = parentContexts.getContext(route.value.outlet);\n    if (context && context.outlet) {\n      const componentRef = context.outlet.detach();\n      const contexts = context.children.onOutletDeactivated();\n      this.routeReuseStrategy.store(route.value.snapshot, {componentRef, route, contexts});\n    }\n  }\n\n  private deactivateRouteAndOutlet(\n      route: TreeNode<ActivatedRoute>, parentContexts: ChildrenOutletContexts): void {\n    const context = parentContexts.getContext(route.value.outlet);\n\n    if (context) {\n      const children: {[outletName: string]: any} = nodeChildrenAsMap(route);\n      const contexts = route.value.component ? context.children : parentContexts;\n\n      forEach(children, (v: any, k: string) => this.deactivateRouteAndItsChildren(v, contexts));\n\n      if (context.outlet) {\n        // Destroy the component\n        context.outlet.deactivate();\n        // Destroy the contexts for all the outlets that were in the component\n        context.children.onOutletDeactivated();\n      }\n    }\n  }\n\n  private activateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      contexts: ChildrenOutletContexts): void {\n    const children: {[outlet: string]: any} = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.activateRoutes(c, children[c.value.outlet], contexts);\n      this.forwardEvent(new ActivationEnd(c.value.snapshot));\n    });\n    if (futureNode.children.length) {\n      this.forwardEvent(new ChildActivationEnd(futureNode.value.snapshot));\n    }\n  }\n\n  private activateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      parentContexts: ChildrenOutletContexts): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n\n    advanceActivatedRoute(future);\n\n    // reusing the node\n    if (future === curr) {\n      if (future.component) {\n        // If we have a normal route, we need to go through an outlet.\n        const context = parentContexts.getOrCreateContext(future.outlet);\n        this.activateChildRoutes(futureNode, currNode, context.children);\n      } else {\n        // if we have a componentless route, we recurse but keep the same outlet map.\n        this.activateChildRoutes(futureNode, currNode, parentContexts);\n      }\n    } else {\n      if (future.component) {\n        // if we have a normal route, we need to place the component into the outlet and recurse.\n        const context = parentContexts.getOrCreateContext(future.outlet);\n\n        if (this.routeReuseStrategy.shouldAttach(future.snapshot)) {\n          const stored =\n              (<DetachedRouteHandleInternal>this.routeReuseStrategy.retrieve(future.snapshot));\n          this.routeReuseStrategy.store(future.snapshot, null);\n          context.children.onOutletReAttached(stored.contexts);\n          context.attachRef = stored.componentRef;\n          context.route = stored.route.value;\n          if (context.outlet) {\n            // Attach right away when the outlet has already been instantiated\n            // Otherwise attach from `RouterOutlet.ngOnInit` when it is instantiated\n            context.outlet.attach(stored.componentRef, stored.route.value);\n          }\n          advanceActivatedRouteNodeAndItsChildren(stored.route);\n        } else {\n          const config = parentLoadedConfig(future.snapshot);\n          const cmpFactoryResolver = config ? config.module.componentFactoryResolver : null;\n\n          context.route = future;\n          context.resolver = cmpFactoryResolver;\n          if (context.outlet) {\n            // Activate the outlet when it has already been instantiated\n            // Otherwise it will get activated from its `ngOnInit` when instantiated\n            context.outlet.activateWith(future, cmpFactoryResolver);\n          }\n\n          this.activateChildRoutes(futureNode, null, context.children);\n        }\n      } else {\n        // if we have a componentless route, we recurse but keep the same outlet map.\n        this.activateChildRoutes(futureNode, null, parentContexts);\n      }\n    }\n  }\n}\n\nfunction advanceActivatedRouteNodeAndItsChildren(node: TreeNode<ActivatedRoute>): void {\n  advanceActivatedRoute(node.value);\n  node.children.forEach(advanceActivatedRouteNodeAndItsChildren);\n}\n\nfunction parentLoadedConfig(snapshot: ActivatedRouteSnapshot): LoadedRouterConfig|null {\n  for (let s = snapshot.parent; s; s = s.parent) {\n    const route = s.routeConfig;\n    if (route && route._loadedConfig) return route._loadedConfig;\n    if (route && route.component) return null;\n  }\n\n  return null;\n}\n\nfunction validateCommands(commands: string[]): void {\n  for (let i = 0; i < commands.length; i++) {\n    const cmd = commands[i];\n    if (cmd == null) {\n      throw new Error(`The requested path contains ${cmd} segment at index ${i}`);\n    }\n  }\n}\n"]}
1265
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.js","sourceRoot":"","sources":["../../../../../../packages/router/src/router.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 {Location} from '@angular/common';\nimport {Compiler, Injector, NgModuleFactoryLoader, NgModuleRef, NgZone, Optional, Type, isDevMode, ɵConsole as Console} from '@angular/core';\nimport {BehaviorSubject, Observable, Subject, Subscription, of } from 'rxjs';\nimport {concatMap, map, mergeMap} from 'rxjs/operators';\n\nimport {applyRedirects} from './apply_redirects';\nimport {LoadedRouterConfig, QueryParamsHandling, Route, Routes, standardizeConfig, validateConfig} from './config';\nimport {createRouterState} from './create_router_state';\nimport {createUrlTree} from './create_url_tree';\nimport {ActivationEnd, ChildActivationEnd, Event, GuardsCheckEnd, GuardsCheckStart, NavigationCancel, NavigationEnd, NavigationError, NavigationStart, NavigationTrigger, ResolveEnd, ResolveStart, RouteConfigLoadEnd, RouteConfigLoadStart, RoutesRecognized} from './events';\nimport {PreActivation} from './pre_activation';\nimport {recognize} from './recognize';\nimport {DefaultRouteReuseStrategy, DetachedRouteHandleInternal, RouteReuseStrategy} from './route_reuse_strategy';\nimport {RouterConfigLoader} from './router_config_loader';\nimport {ChildrenOutletContexts} from './router_outlet_context';\nimport {ActivatedRoute, ActivatedRouteSnapshot, RouterState, RouterStateSnapshot, advanceActivatedRoute, createEmptyState, inheritedParamsDataResolve} from './router_state';\nimport {Params, isNavigationCancelingError} from './shared';\nimport {DefaultUrlHandlingStrategy, UrlHandlingStrategy} from './url_handling_strategy';\nimport {UrlSerializer, UrlTree, containsTree, createEmptyUrlTree} from './url_tree';\nimport {forEach} from './utils/collection';\nimport {TreeNode, nodeChildrenAsMap} from './utils/tree';\n\n\n/**\n * @description\n *\n * Represents the extra options used during navigation.\n *\n *\n */\nexport interface NavigationExtras {\n  /**\n   * Enables relative navigation from the current ActivatedRoute.\n   *\n   * Configuration:\n   *\n   * ```\n   * [{\n  *   path: 'parent',\n  *   component: ParentComponent,\n  *   children: [{\n  *     path: 'list',\n  *     component: ListComponent\n  *   },{\n  *     path: 'child',\n  *     component: ChildComponent\n  *   }]\n  * }]\n   * ```\n   *\n   * Navigate to list route from child route:\n   *\n   * ```\n   *  @Component({...})\n   *  class ChildComponent {\n  *    constructor(private router: Router, private route: ActivatedRoute) {}\n  *\n  *    go() {\n  *      this.router.navigate(['../list'], { relativeTo: this.route });\n  *    }\n  *  }\n   * ```\n   */\n  relativeTo?: ActivatedRoute|null;\n\n  /**\n   * Sets query parameters to the URL.\n   *\n   * ```\n   * // Navigate to /results?page=1\n   * this.router.navigate(['/results'], { queryParams: { page: 1 } });\n   * ```\n   */\n  queryParams?: Params|null;\n\n  /**\n   * Sets the hash fragment for the URL.\n   *\n   * ```\n   * // Navigate to /results#top\n   * this.router.navigate(['/results'], { fragment: 'top' });\n   * ```\n   */\n  fragment?: string;\n\n  /**\n   * Preserves the query parameters for the next navigation.\n   *\n   * deprecated, use `queryParamsHandling` instead\n   *\n   * ```\n   * // Preserve query params from /results?page=1 to /view?page=1\n   * this.router.navigate(['/view'], { preserveQueryParams: true });\n   * ```\n   *\n   * @deprecated since v4\n   */\n  preserveQueryParams?: boolean;\n\n  /**\n   *  config strategy to handle the query parameters for the next navigation.\n   *\n   * ```\n   * // from /results?page=1 to /view?page=1&page=2\n   * this.router.navigate(['/view'], { queryParams: { page: 2 },  queryParamsHandling: \"merge\" });\n   * ```\n   */\n  queryParamsHandling?: QueryParamsHandling|null;\n  /**\n   * Preserves the fragment for the next navigation\n   *\n   * ```\n   * // Preserve fragment from /results#top to /view#top\n   * this.router.navigate(['/view'], { preserveFragment: true });\n   * ```\n   */\n  preserveFragment?: boolean;\n  /**\n   * Navigates without pushing a new state into history.\n   *\n   * ```\n   * // Navigate silently to /view\n   * this.router.navigate(['/view'], { skipLocationChange: true });\n   * ```\n   */\n  skipLocationChange?: boolean;\n  /**\n   * Navigates while replacing the current state in history.\n   *\n   * ```\n   * // Navigate to /view\n   * this.router.navigate(['/view'], { replaceUrl: true });\n   * ```\n   */\n  replaceUrl?: boolean;\n}\n\n/**\n * @description\n *\n * Error handler that is invoked when a navigation errors.\n *\n * If the handler returns a value, the navigation promise will be resolved with this value.\n * If the handler throws an exception, the navigation promise will be rejected with\n * the exception.\n *\n *\n */\nexport type ErrorHandler = (error: any) => any;\n\nfunction defaultErrorHandler(error: any): any {\n  throw error;\n}\n\nfunction defaultMalformedUriErrorHandler(\n    error: URIError, urlSerializer: UrlSerializer, url: string): UrlTree {\n  return urlSerializer.parse('/');\n}\n\ntype NavStreamValue =\n    boolean | {appliedUrl: UrlTree, snapshot: RouterStateSnapshot, shouldActivate?: boolean};\n\ntype NavigationParams = {\n  id: number,\n  rawUrl: UrlTree,\n  extras: NavigationExtras,\n  resolve: any,\n  reject: any,\n  promise: Promise<boolean>,\n  source: NavigationTrigger,\n  state: {navigationId: number} | null\n};\n\n/**\n * @internal\n */\nexport type RouterHook = (snapshot: RouterStateSnapshot, runExtras: {\n  appliedUrlTree: UrlTree,\n  rawUrlTree: UrlTree,\n  skipLocationChange: boolean,\n  replaceUrl: boolean,\n  navigationId: number\n}) => Observable<void>;\n\n/**\n * @internal\n */\nfunction defaultRouterHook(snapshot: RouterStateSnapshot, runExtras: {\n  appliedUrlTree: UrlTree,\n  rawUrlTree: UrlTree,\n  skipLocationChange: boolean,\n  replaceUrl: boolean,\n  navigationId: number\n}): Observable<void> {\n  return of (null) as any;\n}\n\n/**\n * @description\n *\n * Provides the navigation and url manipulation capabilities.\n *\n * See `Routes` for more details and examples.\n *\n * @ngModule RouterModule\n *\n *\n */\nexport class Router {\n  private currentUrlTree: UrlTree;\n  private rawUrlTree: UrlTree;\n  private navigations = new BehaviorSubject<NavigationParams>(null !);\n\n  // TODO(issue/24571): remove '!'.\n  private locationSubscription !: Subscription;\n  private navigationId: number = 0;\n  private configLoader: RouterConfigLoader;\n  private ngModule: NgModuleRef<any>;\n  private console: Console;\n  private isNgZoneEnabled: boolean = false;\n\n  public readonly events: Observable<Event> = new Subject<Event>();\n  public readonly routerState: RouterState;\n\n  /**\n   * Error handler that is invoked when a navigation errors.\n   *\n   * See `ErrorHandler` for more information.\n   */\n  errorHandler: ErrorHandler = defaultErrorHandler;\n\n  /**\n   * Malformed uri error handler is invoked when `Router.parseUrl(url)` throws an\n   * error due to containing an invalid character. The most common case would be a `%` sign\n   * that's not encoded and is not part of a percent encoded sequence.\n   */\n  malformedUriErrorHandler:\n      (error: URIError, urlSerializer: UrlSerializer,\n       url: string) => UrlTree = defaultMalformedUriErrorHandler;\n\n  /**\n   * Indicates if at least one navigation happened.\n   */\n  navigated: boolean = false;\n  private lastSuccessfulId: number = -1;\n\n  /**\n   * Used by RouterModule. This allows us to\n   * pause the navigation either before preactivation or after it.\n   * @internal\n   */\n  hooks: {beforePreactivation: RouterHook, afterPreactivation: RouterHook} = {\n    beforePreactivation: defaultRouterHook,\n    afterPreactivation: defaultRouterHook\n  };\n\n  /**\n   * Extracts and merges URLs. Used for AngularJS to Angular migrations.\n   */\n  urlHandlingStrategy: UrlHandlingStrategy = new DefaultUrlHandlingStrategy();\n\n  routeReuseStrategy: RouteReuseStrategy = new DefaultRouteReuseStrategy();\n\n  /**\n   * Define what the router should do if it receives a navigation request to the current URL.\n   * By default, the router will ignore this navigation. However, this prevents features such\n   * as a \"refresh\" button. Use this option to configure the behavior when navigating to the\n   * current URL. Default is 'ignore'.\n   */\n  onSameUrlNavigation: 'reload'|'ignore' = 'ignore';\n\n  /**\n   * Defines how the router merges params, data and resolved data from parent to child\n   * routes. Available options are:\n   *\n   * - `'emptyOnly'`, the default, only inherits parent params for path-less or component-less\n   *   routes.\n   * - `'always'`, enables unconditional inheritance of parent params.\n   */\n  paramsInheritanceStrategy: 'emptyOnly'|'always' = 'emptyOnly';\n\n  /**\n   * Defines when the router updates the browser URL. The default behavior is to update after\n   * successful navigation. However, some applications may prefer a mode where the URL gets\n   * updated at the beginning of navigation. The most common use case would be updating the\n   * URL early so if navigation fails, you can show an error message with the URL that failed.\n   * Available options are:\n   *\n   * - `'deferred'`, the default, updates the browser URL after navigation has finished.\n   * - `'eager'`, updates browser URL at the beginning of navigation.\n   */\n  urlUpdateStrategy: 'deferred'|'eager' = 'deferred';\n\n  /**\n   * See {@link RouterModule} for more information.\n   */\n  relativeLinkResolution: 'legacy'|'corrected' = 'legacy';\n\n  /**\n   * Creates the router service.\n   */\n  // TODO: vsavkin make internal after the final is out.\n  constructor(\n      private rootComponentType: Type<any>|null, private urlSerializer: UrlSerializer,\n      private rootContexts: ChildrenOutletContexts, private location: Location, injector: Injector,\n      loader: NgModuleFactoryLoader, compiler: Compiler, public config: Routes) {\n    const onLoadStart = (r: Route) => this.triggerEvent(new RouteConfigLoadStart(r));\n    const onLoadEnd = (r: Route) => this.triggerEvent(new RouteConfigLoadEnd(r));\n\n    this.ngModule = injector.get(NgModuleRef);\n    this.console = injector.get(Console);\n    const ngZone = injector.get(NgZone);\n    this.isNgZoneEnabled = ngZone instanceof NgZone;\n\n    this.resetConfig(config);\n    this.currentUrlTree = createEmptyUrlTree();\n    this.rawUrlTree = this.currentUrlTree;\n\n    this.configLoader = new RouterConfigLoader(loader, compiler, onLoadStart, onLoadEnd);\n    this.routerState = createEmptyState(this.currentUrlTree, this.rootComponentType);\n    this.processNavigations();\n  }\n\n  /**\n   * @internal\n   * TODO: this should be removed once the constructor of the router made internal\n   */\n  resetRootComponentType(rootComponentType: Type<any>): void {\n    this.rootComponentType = rootComponentType;\n    // TODO: vsavkin router 4.0 should make the root component set to null\n    // this will simplify the lifecycle of the router.\n    this.routerState.root.component = this.rootComponentType;\n  }\n\n  /**\n   * Sets up the location change listener and performs the initial navigation.\n   */\n  initialNavigation(): void {\n    this.setUpLocationChangeListener();\n    if (this.navigationId === 0) {\n      this.navigateByUrl(this.location.path(true), {replaceUrl: true});\n    }\n  }\n\n  /**\n   * Sets up the location change listener.\n   */\n  setUpLocationChangeListener(): void {\n    // Don't need to use Zone.wrap any more, because zone.js\n    // already patch onPopState, so location change callback will\n    // run into ngZone\n    if (!this.locationSubscription) {\n      this.locationSubscription = <any>this.location.subscribe((change: any) => {\n        let rawUrlTree = this.parseUrl(change['url']);\n        const source: NavigationTrigger = change['type'] === 'popstate' ? 'popstate' : 'hashchange';\n        const state = change.state && change.state.navigationId ?\n            {navigationId: change.state.navigationId} :\n            null;\n        setTimeout(\n            () => { this.scheduleNavigation(rawUrlTree, source, state, {replaceUrl: true}); }, 0);\n      });\n    }\n  }\n\n  /** The current url */\n  get url(): string { return this.serializeUrl(this.currentUrlTree); }\n\n  /** @internal */\n  triggerEvent(event: Event): void { (this.events as Subject<Event>).next(event); }\n\n  /**\n   * Resets the configuration used for navigation and generating links.\n   *\n   * @usageNotes\n   *\n   * ### Example\n   *\n   * ```\n   * router.resetConfig([\n   *  { path: 'team/:id', component: TeamCmp, children: [\n   *    { path: 'simple', component: SimpleCmp },\n   *    { path: 'user/:name', component: UserCmp }\n   *  ]}\n   * ]);\n   * ```\n   */\n  resetConfig(config: Routes): void {\n    validateConfig(config);\n    this.config = config.map(standardizeConfig);\n    this.navigated = false;\n    this.lastSuccessfulId = -1;\n  }\n\n  /** @docsNotRequired */\n  ngOnDestroy(): void { this.dispose(); }\n\n  /** Disposes of the router */\n  dispose(): void {\n    if (this.locationSubscription) {\n      this.locationSubscription.unsubscribe();\n      this.locationSubscription = null !;\n    }\n  }\n\n  /**\n   * Applies an array of commands to the current url tree and creates a new url tree.\n   *\n   * When given an activate route, applies the given commands starting from the route.\n   * When not given a route, applies the given command starting from the root.\n   *\n   * @usageNotes\n   *\n   * ### Example\n   *\n   * ```\n   * // create /team/33/user/11\n   * router.createUrlTree(['/team', 33, 'user', 11]);\n   *\n   * // create /team/33;expand=true/user/11\n   * router.createUrlTree(['/team', 33, {expand: true}, 'user', 11]);\n   *\n   * // you can collapse static segments like this (this works only with the first passed-in value):\n   * router.createUrlTree(['/team/33/user', userId]);\n   *\n   * // If the first segment can contain slashes, and you do not want the router to split it, you\n   * // can do the following:\n   *\n   * router.createUrlTree([{segmentPath: '/one/two'}]);\n   *\n   * // create /team/33/(user/11//right:chat)\n   * router.createUrlTree(['/team', 33, {outlets: {primary: 'user/11', right: 'chat'}}]);\n   *\n   * // remove the right secondary node\n   * router.createUrlTree(['/team', 33, {outlets: {primary: 'user/11', right: null}}]);\n   *\n   * // assuming the current url is `/team/33/user/11` and the route points to `user/11`\n   *\n   * // navigate to /team/33/user/11/details\n   * router.createUrlTree(['details'], {relativeTo: route});\n   *\n   * // navigate to /team/33/user/22\n   * router.createUrlTree(['../22'], {relativeTo: route});\n   *\n   * // navigate to /team/44/user/22\n   * router.createUrlTree(['../../team/44/user/22'], {relativeTo: route});\n   * ```\n   */\n  createUrlTree(commands: any[], navigationExtras: NavigationExtras = {}): UrlTree {\n    const {relativeTo,          queryParams,         fragment,\n           preserveQueryParams, queryParamsHandling, preserveFragment} = navigationExtras;\n    if (isDevMode() && preserveQueryParams && <any>console && <any>console.warn) {\n      console.warn('preserveQueryParams is deprecated, use queryParamsHandling instead.');\n    }\n    const a = relativeTo || this.routerState.root;\n    const f = preserveFragment ? this.currentUrlTree.fragment : fragment;\n    let q: Params|null = null;\n    if (queryParamsHandling) {\n      switch (queryParamsHandling) {\n        case 'merge':\n          q = {...this.currentUrlTree.queryParams, ...queryParams};\n          break;\n        case 'preserve':\n          q = this.currentUrlTree.queryParams;\n          break;\n        default:\n          q = queryParams || null;\n      }\n    } else {\n      q = preserveQueryParams ? this.currentUrlTree.queryParams : queryParams || null;\n    }\n    if (q !== null) {\n      q = this.removeEmptyProps(q);\n    }\n    return createUrlTree(a, this.currentUrlTree, commands, q !, f !);\n  }\n\n  /**\n   * Navigate based on the provided url. This navigation is always absolute.\n   *\n   * Returns a promise that:\n   * - resolves to 'true' when navigation succeeds,\n   * - resolves to 'false' when navigation fails,\n   * - is rejected when an error happens.\n   *\n   * @usageNotes\n   *\n   * ### Example\n   *\n   * ```\n   * router.navigateByUrl(\"/team/33/user/11\");\n   *\n   * // Navigate without updating the URL\n   * router.navigateByUrl(\"/team/33/user/11\", { skipLocationChange: true });\n   * ```\n   *\n   * Since `navigateByUrl()` takes an absolute URL as the first parameter,\n   * it will not apply any delta to the current URL and ignores any properties\n   * in the second parameter (the `NavigationExtras`) that would change the\n   * provided URL.\n   */\n  navigateByUrl(url: string|UrlTree, extras: NavigationExtras = {skipLocationChange: false}):\n      Promise<boolean> {\n    if (isDevMode() && this.isNgZoneEnabled && !NgZone.isInAngularZone()) {\n      this.console.warn(\n          `Navigation triggered outside Angular zone, did you forget to call 'ngZone.run()'?`);\n    }\n\n    const urlTree = url instanceof UrlTree ? url : this.parseUrl(url);\n    const mergedTree = this.urlHandlingStrategy.merge(urlTree, this.rawUrlTree);\n\n    return this.scheduleNavigation(mergedTree, 'imperative', null, extras);\n  }\n\n  /**\n   * Navigate based on the provided array of commands and a starting point.\n   * If no starting route is provided, the navigation is absolute.\n   *\n   * Returns a promise that:\n   * - resolves to 'true' when navigation succeeds,\n   * - resolves to 'false' when navigation fails,\n   * - is rejected when an error happens.\n   *\n   * @usageNotes\n   *\n   * ### Example\n   *\n   * ```\n   * router.navigate(['team', 33, 'user', 11], {relativeTo: route});\n   *\n   * // Navigate without updating the URL\n   * router.navigate(['team', 33, 'user', 11], {relativeTo: route, skipLocationChange: true});\n   * ```\n   *\n   * The first parameter of `navigate()` is a delta to be applied to the current URL\n   * or the one provided in the `relativeTo` property of the second parameter (the\n   * `NavigationExtras`).\n   */\n  navigate(commands: any[], extras: NavigationExtras = {skipLocationChange: false}):\n      Promise<boolean> {\n    validateCommands(commands);\n    return this.navigateByUrl(this.createUrlTree(commands, extras), extras);\n  }\n\n  /** Serializes a `UrlTree` into a string */\n  serializeUrl(url: UrlTree): string { return this.urlSerializer.serialize(url); }\n\n  /** Parses a string into a `UrlTree` */\n  parseUrl(url: string): UrlTree {\n    let urlTree: UrlTree;\n    try {\n      urlTree = this.urlSerializer.parse(url);\n    } catch (e) {\n      urlTree = this.malformedUriErrorHandler(e, this.urlSerializer, url);\n    }\n    return urlTree;\n  }\n\n  /** Returns whether the url is activated */\n  isActive(url: string|UrlTree, exact: boolean): boolean {\n    if (url instanceof UrlTree) {\n      return containsTree(this.currentUrlTree, url, exact);\n    }\n\n    const urlTree = this.parseUrl(url);\n    return containsTree(this.currentUrlTree, urlTree, exact);\n  }\n\n  private removeEmptyProps(params: Params): Params {\n    return Object.keys(params).reduce((result: Params, key: string) => {\n      const value: any = params[key];\n      if (value !== null && value !== undefined) {\n        result[key] = value;\n      }\n      return result;\n    }, {});\n  }\n\n  private processNavigations(): void {\n    this.navigations\n        .pipe(concatMap((nav: NavigationParams) => {\n          if (nav) {\n            this.executeScheduledNavigation(nav);\n            // a failed navigation should not stop the router from processing\n            // further navigations => the catch\n            return nav.promise.catch(() => {});\n          } else {\n            return <any>of (null);\n          }\n        }))\n        .subscribe(() => {});\n  }\n\n  private scheduleNavigation(\n      rawUrl: UrlTree, source: NavigationTrigger, state: {navigationId: number}|null,\n      extras: NavigationExtras): Promise<boolean> {\n    const lastNavigation = this.navigations.value;\n    // If the user triggers a navigation imperatively (e.g., by using navigateByUrl),\n    // and that navigation results in 'replaceState' that leads to the same URL,\n    // we should skip those.\n    if (lastNavigation && source !== 'imperative' && lastNavigation.source === 'imperative' &&\n        lastNavigation.rawUrl.toString() === rawUrl.toString()) {\n      return Promise.resolve(true);  // return value is not used\n    }\n\n    // Because of a bug in IE and Edge, the location class fires two events (popstate and\n    // hashchange) every single time. The second one should be ignored. Otherwise, the URL will\n    // flicker. Handles the case when a popstate was emitted first.\n    if (lastNavigation && source == 'hashchange' && lastNavigation.source === 'popstate' &&\n        lastNavigation.rawUrl.toString() === rawUrl.toString()) {\n      return Promise.resolve(true);  // return value is not used\n    }\n    // Because of a bug in IE and Edge, the location class fires two events (popstate and\n    // hashchange) every single time. The second one should be ignored. Otherwise, the URL will\n    // flicker. Handles the case when a hashchange was emitted first.\n    if (lastNavigation && source == 'popstate' && lastNavigation.source === 'hashchange' &&\n        lastNavigation.rawUrl.toString() === rawUrl.toString()) {\n      return Promise.resolve(true);  // return value is not used\n    }\n\n    let resolve: any = null;\n    let reject: any = null;\n\n    const promise = new Promise<boolean>((res, rej) => {\n      resolve = res;\n      reject = rej;\n    });\n\n    const id = ++this.navigationId;\n    this.navigations.next({id, source, state, rawUrl, extras, resolve, reject, promise});\n\n    // Make sure that the error is propagated even though `processNavigations` catch\n    // handler does not rethrow\n    return promise.catch((e: any) => Promise.reject(e));\n  }\n\n  private executeScheduledNavigation({id, rawUrl, extras, resolve, reject, source,\n                                      state}: NavigationParams): void {\n    const url = this.urlHandlingStrategy.extract(rawUrl);\n    const urlTransition = !this.navigated || url.toString() !== this.currentUrlTree.toString();\n\n    if ((this.onSameUrlNavigation === 'reload' ? true : urlTransition) &&\n        this.urlHandlingStrategy.shouldProcessUrl(rawUrl)) {\n      if (this.urlUpdateStrategy === 'eager' && !extras.skipLocationChange) {\n        this.setBrowserUrl(rawUrl, !!extras.replaceUrl, id);\n      }\n      (this.events as Subject<Event>)\n          .next(new NavigationStart(id, this.serializeUrl(url), source, state));\n      Promise.resolve()\n          .then(\n              (_) => this.runNavigate(\n                  url, rawUrl, !!extras.skipLocationChange, !!extras.replaceUrl, id, null))\n          .then(resolve, reject);\n\n      // we cannot process the current URL, but we could process the previous one =>\n      // we need to do some cleanup\n    } else if (\n        urlTransition && this.rawUrlTree &&\n        this.urlHandlingStrategy.shouldProcessUrl(this.rawUrlTree)) {\n      (this.events as Subject<Event>)\n          .next(new NavigationStart(id, this.serializeUrl(url), source, state));\n      Promise.resolve()\n          .then(\n              (_) => this.runNavigate(\n                  url, rawUrl, false, false, id,\n                  createEmptyState(url, this.rootComponentType).snapshot))\n          .then(resolve, reject);\n\n    } else {\n      this.rawUrlTree = rawUrl;\n      resolve(null);\n    }\n  }\n\n  private runNavigate(\n      url: UrlTree, rawUrl: UrlTree, skipLocationChange: boolean, replaceUrl: boolean, id: number,\n      precreatedState: RouterStateSnapshot|null): Promise<boolean> {\n    if (id !== this.navigationId) {\n      (this.events as Subject<Event>)\n          .next(new NavigationCancel(\n              id, this.serializeUrl(url),\n              `Navigation ID ${id} is not equal to the current navigation id ${this.navigationId}`));\n      return Promise.resolve(false);\n    }\n\n    return new Promise((resolvePromise, rejectPromise) => {\n      // create an observable of the url and route state snapshot\n      // this operation do not result in any side effects\n      let urlAndSnapshot$: Observable<NavStreamValue>;\n      if (!precreatedState) {\n        const moduleInjector = this.ngModule.injector;\n        const redirectsApplied$ =\n            applyRedirects(moduleInjector, this.configLoader, this.urlSerializer, url, this.config);\n\n        urlAndSnapshot$ = redirectsApplied$.pipe(mergeMap((appliedUrl: UrlTree) => {\n          return recognize(\n                     this.rootComponentType, this.config, appliedUrl, this.serializeUrl(appliedUrl),\n                     this.paramsInheritanceStrategy, this.relativeLinkResolution)\n              .pipe(map((snapshot: any) => {\n                (this.events as Subject<Event>)\n                    .next(new RoutesRecognized(\n                        id, this.serializeUrl(url), this.serializeUrl(appliedUrl), snapshot));\n\n                return {appliedUrl, snapshot};\n              }));\n        }));\n      } else {\n        urlAndSnapshot$ = of ({appliedUrl: url, snapshot: precreatedState});\n      }\n\n      const beforePreactivationDone$ =\n          urlAndSnapshot$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean') return of (p);\n            return this.hooks\n                .beforePreactivation(p.snapshot, {\n                  navigationId: id,\n                  appliedUrlTree: url,\n                  rawUrlTree: rawUrl, skipLocationChange, replaceUrl,\n                })\n                .pipe(map(() => p));\n          }));\n\n      // run preactivation: guards and data resolvers\n      let preActivation: PreActivation;\n\n      const preactivationSetup$ = beforePreactivationDone$.pipe(map((p): NavStreamValue => {\n        if (typeof p === 'boolean') return p;\n        const {appliedUrl, snapshot} = p;\n        const moduleInjector = this.ngModule.injector;\n        preActivation = new PreActivation(\n            snapshot, this.routerState.snapshot, moduleInjector,\n            (evt: Event) => this.triggerEvent(evt));\n        preActivation.initialize(this.rootContexts);\n        return {appliedUrl, snapshot};\n      }));\n\n      const preactivationCheckGuards$ =\n          preactivationSetup$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean' || this.navigationId !== id) return of (false);\n            const {appliedUrl, snapshot} = p;\n\n            this.triggerEvent(new GuardsCheckStart(\n                id, this.serializeUrl(url), this.serializeUrl(appliedUrl), snapshot));\n\n            return preActivation.checkGuards().pipe(map((shouldActivate: boolean) => {\n              this.triggerEvent(new GuardsCheckEnd(\n                  id, this.serializeUrl(url), this.serializeUrl(appliedUrl), snapshot,\n                  shouldActivate));\n              return {appliedUrl: appliedUrl, snapshot: snapshot, shouldActivate: shouldActivate};\n            }));\n          }));\n\n      const preactivationResolveData$ =\n          preactivationCheckGuards$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean' || this.navigationId !== id) return of (false);\n\n            if (p.shouldActivate && preActivation.isActivating()) {\n              this.triggerEvent(new ResolveStart(\n                  id, this.serializeUrl(url), this.serializeUrl(p.appliedUrl), p.snapshot));\n              return preActivation.resolveData(this.paramsInheritanceStrategy).pipe(map(() => {\n                this.triggerEvent(new ResolveEnd(\n                    id, this.serializeUrl(url), this.serializeUrl(p.appliedUrl), p.snapshot));\n                return p;\n              }));\n            } else {\n              return of (p);\n            }\n          }));\n\n      const preactivationDone$ =\n          preactivationResolveData$.pipe(mergeMap((p): Observable<NavStreamValue> => {\n            if (typeof p === 'boolean' || this.navigationId !== id) return of (false);\n            return this.hooks\n                .afterPreactivation(p.snapshot, {\n                  navigationId: id,\n                  appliedUrlTree: url,\n                  rawUrlTree: rawUrl, skipLocationChange, replaceUrl,\n                })\n                .pipe(map(() => p));\n          }));\n\n\n      // create router state\n      // this operation has side effects => route state is being affected\n      const routerState$ = preactivationDone$.pipe(map((p) => {\n        if (typeof p === 'boolean' || this.navigationId !== id) return false;\n        const {appliedUrl, snapshot, shouldActivate} = p;\n        if (shouldActivate) {\n          const state = createRouterState(this.routeReuseStrategy, snapshot, this.routerState);\n          return {appliedUrl, state, shouldActivate};\n        } else {\n          return {appliedUrl, state: null, shouldActivate};\n        }\n      }));\n\n\n      this.activateRoutes(\n          routerState$, this.routerState, this.currentUrlTree, id, url, rawUrl, skipLocationChange,\n          replaceUrl, resolvePromise, rejectPromise);\n    });\n  }\n\n  /**\n   * Performs the logic of activating routes. This is a synchronous process by default. While this\n   * is a private method, it could be overridden to make activation asynchronous.\n   */\n  private activateRoutes(\n      state: Observable<false|\n                        {appliedUrl: UrlTree, state: RouterState|null, shouldActivate?: boolean}>,\n      storedState: RouterState, storedUrl: UrlTree, id: number, url: UrlTree, rawUrl: UrlTree,\n      skipLocationChange: boolean, replaceUrl: boolean, resolvePromise: any, rejectPromise: any) {\n    // applied the new router state\n    // this operation has side effects\n    let navigationIsSuccessful: boolean;\n\n    state\n        .forEach((p) => {\n          if (typeof p === 'boolean' || !p.shouldActivate || id !== this.navigationId || !p.state) {\n            navigationIsSuccessful = false;\n            return;\n          }\n          const {appliedUrl, state} = p;\n          this.currentUrlTree = appliedUrl;\n          this.rawUrlTree = this.urlHandlingStrategy.merge(this.currentUrlTree, rawUrl);\n\n          (this as{routerState: RouterState}).routerState = state;\n\n          if (this.urlUpdateStrategy === 'deferred' && !skipLocationChange) {\n            this.setBrowserUrl(this.rawUrlTree, replaceUrl, id);\n          }\n\n          new ActivateRoutes(\n              this.routeReuseStrategy, state, storedState, (evt: Event) => this.triggerEvent(evt))\n              .activate(this.rootContexts);\n\n          navigationIsSuccessful = true;\n        })\n        .then(\n            () => {\n              if (navigationIsSuccessful) {\n                this.navigated = true;\n                this.lastSuccessfulId = id;\n                (this.events as Subject<Event>)\n                    .next(new NavigationEnd(\n                        id, this.serializeUrl(url), this.serializeUrl(this.currentUrlTree)));\n                resolvePromise(true);\n              } else {\n                this.resetUrlToCurrentUrlTree();\n                (this.events as Subject<Event>)\n                    .next(new NavigationCancel(id, this.serializeUrl(url), ''));\n                resolvePromise(false);\n              }\n            },\n            (e: any) => {\n              if (isNavigationCancelingError(e)) {\n                this.navigated = true;\n                this.resetStateAndUrl(storedState, storedUrl, rawUrl);\n                (this.events as Subject<Event>)\n                    .next(new NavigationCancel(id, this.serializeUrl(url), e.message));\n\n                resolvePromise(false);\n              } else {\n                this.resetStateAndUrl(storedState, storedUrl, rawUrl);\n                (this.events as Subject<Event>)\n                    .next(new NavigationError(id, this.serializeUrl(url), e));\n                try {\n                  resolvePromise(this.errorHandler(e));\n                } catch (ee) {\n                  rejectPromise(ee);\n                }\n              }\n            });\n  }\n\n  private setBrowserUrl(url: UrlTree, replaceUrl: boolean, id: number) {\n    const path = this.urlSerializer.serialize(url);\n    if (this.location.isCurrentPathEqualTo(path) || replaceUrl) {\n      this.location.replaceState(path, '', {navigationId: id});\n    } else {\n      this.location.go(path, '', {navigationId: id});\n    }\n  }\n\n  private resetStateAndUrl(storedState: RouterState, storedUrl: UrlTree, rawUrl: UrlTree): void {\n    (this as{routerState: RouterState}).routerState = storedState;\n    this.currentUrlTree = storedUrl;\n    this.rawUrlTree = this.urlHandlingStrategy.merge(this.currentUrlTree, rawUrl);\n    this.resetUrlToCurrentUrlTree();\n  }\n\n  private resetUrlToCurrentUrlTree(): void {\n    this.location.replaceState(\n        this.urlSerializer.serialize(this.rawUrlTree), '', {navigationId: this.lastSuccessfulId});\n  }\n}\n\nclass ActivateRoutes {\n  constructor(\n      private routeReuseStrategy: RouteReuseStrategy, private futureState: RouterState,\n      private currState: RouterState, private forwardEvent: (evt: Event) => void) {}\n\n  activate(parentContexts: ChildrenOutletContexts): void {\n    const futureRoot = this.futureState._root;\n    const currRoot = this.currState ? this.currState._root : null;\n\n    this.deactivateChildRoutes(futureRoot, currRoot, parentContexts);\n    advanceActivatedRoute(this.futureState.root);\n    this.activateChildRoutes(futureRoot, currRoot, parentContexts);\n  }\n\n  // De-activate the child route that are not re-used for the future state\n  private deactivateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      contexts: ChildrenOutletContexts): void {\n    const children: {[outletName: string]: TreeNode<ActivatedRoute>} = nodeChildrenAsMap(currNode);\n\n    // Recurse on the routes active in the future state to de-activate deeper children\n    futureNode.children.forEach(futureChild => {\n      const childOutletName = futureChild.value.outlet;\n      this.deactivateRoutes(futureChild, children[childOutletName], contexts);\n      delete children[childOutletName];\n    });\n\n    // De-activate the routes that will not be re-used\n    forEach(children, (v: TreeNode<ActivatedRoute>, childName: string) => {\n      this.deactivateRouteAndItsChildren(v, contexts);\n    });\n  }\n\n  private deactivateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      parentContext: ChildrenOutletContexts): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n\n    if (future === curr) {\n      // Reusing the node, check to see if the children need to be de-activated\n      if (future.component) {\n        // If we have a normal route, we need to go through an outlet.\n        const context = parentContext.getContext(future.outlet);\n        if (context) {\n          this.deactivateChildRoutes(futureNode, currNode, context.children);\n        }\n      } else {\n        // if we have a componentless route, we recurse but keep the same outlet map.\n        this.deactivateChildRoutes(futureNode, currNode, parentContext);\n      }\n    } else {\n      if (curr) {\n        // Deactivate the current route which will not be re-used\n        this.deactivateRouteAndItsChildren(currNode, parentContext);\n      }\n    }\n  }\n\n  private deactivateRouteAndItsChildren(\n      route: TreeNode<ActivatedRoute>, parentContexts: ChildrenOutletContexts): void {\n    if (this.routeReuseStrategy.shouldDetach(route.value.snapshot)) {\n      this.detachAndStoreRouteSubtree(route, parentContexts);\n    } else {\n      this.deactivateRouteAndOutlet(route, parentContexts);\n    }\n  }\n\n  private detachAndStoreRouteSubtree(\n      route: TreeNode<ActivatedRoute>, parentContexts: ChildrenOutletContexts): void {\n    const context = parentContexts.getContext(route.value.outlet);\n    if (context && context.outlet) {\n      const componentRef = context.outlet.detach();\n      const contexts = context.children.onOutletDeactivated();\n      this.routeReuseStrategy.store(route.value.snapshot, {componentRef, route, contexts});\n    }\n  }\n\n  private deactivateRouteAndOutlet(\n      route: TreeNode<ActivatedRoute>, parentContexts: ChildrenOutletContexts): void {\n    const context = parentContexts.getContext(route.value.outlet);\n\n    if (context) {\n      const children: {[outletName: string]: any} = nodeChildrenAsMap(route);\n      const contexts = route.value.component ? context.children : parentContexts;\n\n      forEach(children, (v: any, k: string) => this.deactivateRouteAndItsChildren(v, contexts));\n\n      if (context.outlet) {\n        // Destroy the component\n        context.outlet.deactivate();\n        // Destroy the contexts for all the outlets that were in the component\n        context.children.onOutletDeactivated();\n      }\n    }\n  }\n\n  private activateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      contexts: ChildrenOutletContexts): void {\n    const children: {[outlet: string]: any} = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.activateRoutes(c, children[c.value.outlet], contexts);\n      this.forwardEvent(new ActivationEnd(c.value.snapshot));\n    });\n    if (futureNode.children.length) {\n      this.forwardEvent(new ChildActivationEnd(futureNode.value.snapshot));\n    }\n  }\n\n  private activateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      parentContexts: ChildrenOutletContexts): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n\n    advanceActivatedRoute(future);\n\n    // reusing the node\n    if (future === curr) {\n      if (future.component) {\n        // If we have a normal route, we need to go through an outlet.\n        const context = parentContexts.getOrCreateContext(future.outlet);\n        this.activateChildRoutes(futureNode, currNode, context.children);\n      } else {\n        // if we have a componentless route, we recurse but keep the same outlet map.\n        this.activateChildRoutes(futureNode, currNode, parentContexts);\n      }\n    } else {\n      if (future.component) {\n        // if we have a normal route, we need to place the component into the outlet and recurse.\n        const context = parentContexts.getOrCreateContext(future.outlet);\n\n        if (this.routeReuseStrategy.shouldAttach(future.snapshot)) {\n          const stored =\n              (<DetachedRouteHandleInternal>this.routeReuseStrategy.retrieve(future.snapshot));\n          this.routeReuseStrategy.store(future.snapshot, null);\n          context.children.onOutletReAttached(stored.contexts);\n          context.attachRef = stored.componentRef;\n          context.route = stored.route.value;\n          if (context.outlet) {\n            // Attach right away when the outlet has already been instantiated\n            // Otherwise attach from `RouterOutlet.ngOnInit` when it is instantiated\n            context.outlet.attach(stored.componentRef, stored.route.value);\n          }\n          advanceActivatedRouteNodeAndItsChildren(stored.route);\n        } else {\n          const config = parentLoadedConfig(future.snapshot);\n          const cmpFactoryResolver = config ? config.module.componentFactoryResolver : null;\n\n          context.attachRef = null;\n          context.route = future;\n          context.resolver = cmpFactoryResolver;\n          if (context.outlet) {\n            // Activate the outlet when it has already been instantiated\n            // Otherwise it will get activated from its `ngOnInit` when instantiated\n            context.outlet.activateWith(future, cmpFactoryResolver);\n          }\n\n          this.activateChildRoutes(futureNode, null, context.children);\n        }\n      } else {\n        // if we have a componentless route, we recurse but keep the same outlet map.\n        this.activateChildRoutes(futureNode, null, parentContexts);\n      }\n    }\n  }\n}\n\nfunction advanceActivatedRouteNodeAndItsChildren(node: TreeNode<ActivatedRoute>): void {\n  advanceActivatedRoute(node.value);\n  node.children.forEach(advanceActivatedRouteNodeAndItsChildren);\n}\n\nfunction parentLoadedConfig(snapshot: ActivatedRouteSnapshot): LoadedRouterConfig|null {\n  for (let s = snapshot.parent; s; s = s.parent) {\n    const route = s.routeConfig;\n    if (route && route._loadedConfig) return route._loadedConfig;\n    if (route && route.component) return null;\n  }\n\n  return null;\n}\n\nfunction validateCommands(commands: string[]): void {\n  for (let i = 0; i < commands.length; i++) {\n    const cmd = commands[i];\n    if (cmd == null) {\n      throw new Error(`The requested path contains ${cmd} segment at index ${i}`);\n    }\n  }\n}\n"]}