@angular/router 12.2.0-next.3 → 12.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -14,5 +14,5 @@ import { Version } from '@angular/core';
14
14
  /**
15
15
  * @publicApi
16
16
  */
17
- export const VERSION = new Version('12.2.0-next.3');
17
+ export const VERSION = new Version('12.2.2');
18
18
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3JvdXRlci9zcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSDs7OztHQUlHO0FBRUgsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV0Qzs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQG1vZHVsZVxuICogQGRlc2NyaXB0aW9uXG4gKiBFbnRyeSBwb2ludCBmb3IgYWxsIHB1YmxpYyBBUElzIG9mIHRoZSByb3V0ZXIgcGFja2FnZS5cbiAqL1xuXG5pbXBvcnQge1ZlcnNpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBwdWJsaWNBcGlcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbiJdfQ==
@@ -8,7 +8,7 @@
8
8
  import { Location, LocationStrategy } from '@angular/common';
9
9
  import { MockLocationStrategy, SpyLocation } from '@angular/common/testing';
10
10
  import { Compiler, Injectable, Injector, NgModule, NgModuleFactoryLoader, Optional } from '@angular/core';
11
- import { ChildrenOutletContexts, NoPreloading, PreloadingStrategy, provideRoutes, Router, ROUTER_CONFIGURATION, RouterModule, ROUTES, UrlHandlingStrategy, UrlSerializer, ɵassignExtraOptionsToRouter as assignExtraOptionsToRouter, ɵflatten as flatten, ɵROUTER_PROVIDERS as ROUTER_PROVIDERS } from '@angular/router';
11
+ import { ChildrenOutletContexts, NoPreloading, PreloadingStrategy, provideRoutes, Router, ROUTER_CONFIGURATION, RouteReuseStrategy, RouterModule, ROUTES, UrlHandlingStrategy, UrlSerializer, ɵassignExtraOptionsToRouter as assignExtraOptionsToRouter, ɵflatten as flatten, ɵROUTER_PROVIDERS as ROUTER_PROVIDERS } from '@angular/router';
12
12
  /**
13
13
  * @description
14
14
  *
@@ -87,7 +87,7 @@ function isUrlHandlingStrategy(opts) {
87
87
  *
88
88
  * @publicApi
89
89
  */
90
- export function setupTestingRouter(urlSerializer, contexts, location, loader, compiler, injector, routes, opts, urlHandlingStrategy) {
90
+ export function setupTestingRouter(urlSerializer, contexts, location, loader, compiler, injector, routes, opts, urlHandlingStrategy, routeReuseStrategy) {
91
91
  const router = new Router(null, urlSerializer, contexts, location, injector, loader, compiler, flatten(routes));
92
92
  if (opts) {
93
93
  // Handle deprecated argument ordering.
@@ -102,6 +102,9 @@ export function setupTestingRouter(urlSerializer, contexts, location, loader, co
102
102
  if (urlHandlingStrategy) {
103
103
  router.urlHandlingStrategy = urlHandlingStrategy;
104
104
  }
105
+ if (routeReuseStrategy) {
106
+ router.routeReuseStrategy = routeReuseStrategy;
107
+ }
105
108
  return router;
106
109
  }
107
110
  /**
@@ -152,11 +155,12 @@ RouterTestingModule.decorators = [
152
155
  useFactory: setupTestingRouter,
153
156
  deps: [
154
157
  UrlSerializer, ChildrenOutletContexts, Location, NgModuleFactoryLoader, Compiler, Injector,
155
- ROUTES, ROUTER_CONFIGURATION, [UrlHandlingStrategy, new Optional()]
158
+ ROUTES, ROUTER_CONFIGURATION, [UrlHandlingStrategy, new Optional()],
159
+ [RouteReuseStrategy, new Optional()]
156
160
  ]
157
161
  },
158
162
  { provide: PreloadingStrategy, useExisting: NoPreloading }, provideRoutes([])
159
163
  ]
160
164
  },] }
161
165
  ];
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_testing_module.js","sourceRoot":"","sources":["../../../../../../../packages/router/testing/src/router_testing_module.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Location, LocationStrategy} from '@angular/common';\nimport {MockLocationStrategy, SpyLocation} from '@angular/common/testing';\nimport {Compiler, Injectable, Injector, ModuleWithProviders, NgModule, NgModuleFactory, NgModuleFactoryLoader, Optional} from '@angular/core';\nimport {ChildrenOutletContexts, ExtraOptions, NoPreloading, PreloadingStrategy, provideRoutes, Route, Router, ROUTER_CONFIGURATION, RouterModule, ROUTES, Routes, UrlHandlingStrategy, UrlSerializer, ɵassignExtraOptionsToRouter as assignExtraOptionsToRouter, ɵflatten as flatten, ɵROUTER_PROVIDERS as ROUTER_PROVIDERS} from '@angular/router';\n\n\n\n/**\n * @description\n *\n * Allows to simulate the loading of ng modules in tests.\n *\n * ```\n * const loader = TestBed.inject(NgModuleFactoryLoader);\n *\n * @Component({template: 'lazy-loaded'})\n * class LazyLoadedComponent {}\n * @NgModule({\n *   declarations: [LazyLoadedComponent],\n *   imports: [RouterModule.forChild([{path: 'loaded', component: LazyLoadedComponent}])]\n * })\n *\n * class LoadedModule {}\n *\n * // sets up stubbedModules\n * loader.stubbedModules = {lazyModule: LoadedModule};\n *\n * router.resetConfig([\n *   {path: 'lazy', loadChildren: 'lazyModule'},\n * ]);\n *\n * router.navigateByUrl('/lazy/loaded');\n * ```\n *\n * @publicApi\n */\n@Injectable()\nexport class SpyNgModuleFactoryLoader implements NgModuleFactoryLoader {\n  /**\n   * @docsNotRequired\n   */\n  private _stubbedModules: {[path: string]: Promise<NgModuleFactory<any>>} = {};\n\n  /**\n   * @docsNotRequired\n   */\n  set stubbedModules(modules: {[path: string]: any}) {\n    const res: {[path: string]: any} = {};\n    for (const t of Object.keys(modules)) {\n      res[t] = this.compiler.compileModuleAsync(modules[t]);\n    }\n    this._stubbedModules = res;\n  }\n\n  /**\n   * @docsNotRequired\n   */\n  get stubbedModules(): {[path: string]: any} {\n    return this._stubbedModules;\n  }\n\n  constructor(private compiler: Compiler) {}\n\n  load(path: string): Promise<NgModuleFactory<any>> {\n    if (this._stubbedModules[path]) {\n      return this._stubbedModules[path];\n    } else {\n      return <any>Promise.reject(new Error(`Cannot find module ${path}`));\n    }\n  }\n}\n\nfunction isUrlHandlingStrategy(opts: ExtraOptions|\n                               UrlHandlingStrategy): opts is UrlHandlingStrategy {\n  // This property check is needed because UrlHandlingStrategy is an interface and doesn't exist at\n  // runtime.\n  return 'shouldProcessUrl' in opts;\n}\n\n/**\n * Router setup factory function used for testing.\n *\n * @publicApi\n */\nexport function setupTestingRouter(\n    urlSerializer: UrlSerializer, contexts: ChildrenOutletContexts, location: Location,\n    loader: NgModuleFactoryLoader, compiler: Compiler, injector: Injector, routes: Route[][],\n    opts?: ExtraOptions, urlHandlingStrategy?: UrlHandlingStrategy): Router;\n\n/**\n * Router setup factory function used for testing.\n *\n * @deprecated As of v5.2. The 2nd-to-last argument should be `ExtraOptions`, not\n * `UrlHandlingStrategy`\n * @publicApi\n */\nexport function setupTestingRouter(\n    urlSerializer: UrlSerializer, contexts: ChildrenOutletContexts, location: Location,\n    loader: NgModuleFactoryLoader, compiler: Compiler, injector: Injector, routes: Route[][],\n    urlHandlingStrategy?: UrlHandlingStrategy): Router;\n\n/**\n * Router setup factory function used for testing.\n *\n * @publicApi\n */\nexport function setupTestingRouter(\n    urlSerializer: UrlSerializer, contexts: ChildrenOutletContexts, location: Location,\n    loader: NgModuleFactoryLoader, compiler: Compiler, injector: Injector, routes: Route[][],\n    opts?: ExtraOptions|UrlHandlingStrategy, urlHandlingStrategy?: UrlHandlingStrategy) {\n  const router = new Router(\n      null!, urlSerializer, contexts, location, injector, loader, compiler, flatten(routes));\n  if (opts) {\n    // Handle deprecated argument ordering.\n    if (isUrlHandlingStrategy(opts)) {\n      router.urlHandlingStrategy = opts;\n    } else {\n      // Handle ExtraOptions\n      assignExtraOptionsToRouter(opts, router);\n    }\n  }\n\n  if (urlHandlingStrategy) {\n    router.urlHandlingStrategy = urlHandlingStrategy;\n  }\n  return router;\n}\n\n/**\n * @description\n *\n * Sets up the router to be used for testing.\n *\n * The modules sets up the router to be used for testing.\n * It provides spy implementations of `Location`, `LocationStrategy`, and {@link\n * NgModuleFactoryLoader}.\n *\n * @usageNotes\n * ### Example\n *\n * ```\n * beforeEach(() => {\n *   TestBed.configureTestingModule({\n *     imports: [\n *       RouterTestingModule.withRoutes(\n *         [{path: '', component: BlankCmp}, {path: 'simple', component: SimpleCmp}]\n *       )\n *     ]\n *   });\n * });\n * ```\n *\n * @publicApi\n */\n@NgModule({\n  exports: [RouterModule],\n  providers: [\n    ROUTER_PROVIDERS, {provide: Location, useClass: SpyLocation},\n    {provide: LocationStrategy, useClass: MockLocationStrategy},\n    {provide: NgModuleFactoryLoader, useClass: SpyNgModuleFactoryLoader}, {\n      provide: Router,\n      useFactory: setupTestingRouter,\n      deps: [\n        UrlSerializer, ChildrenOutletContexts, Location, NgModuleFactoryLoader, Compiler, Injector,\n        ROUTES, ROUTER_CONFIGURATION, [UrlHandlingStrategy, new Optional()]\n      ]\n    },\n    {provide: PreloadingStrategy, useExisting: NoPreloading}, provideRoutes([])\n  ]\n})\nexport class RouterTestingModule {\n  static withRoutes(routes: Routes, config?: ExtraOptions):\n      ModuleWithProviders<RouterTestingModule> {\n    return {\n      ngModule: RouterTestingModule,\n      providers: [\n        provideRoutes(routes),\n        {provide: ROUTER_CONFIGURATION, useValue: config ? config : {}},\n      ]\n    };\n  }\n}\n"]}
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_testing_module.js","sourceRoot":"","sources":["../../../../../../../packages/router/testing/src/router_testing_module.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Location, LocationStrategy} from '@angular/common';\nimport {MockLocationStrategy, SpyLocation} from '@angular/common/testing';\nimport {Compiler, Injectable, Injector, ModuleWithProviders, NgModule, NgModuleFactory, NgModuleFactoryLoader, Optional} from '@angular/core';\nimport {ChildrenOutletContexts, ExtraOptions, NoPreloading, PreloadingStrategy, provideRoutes, Route, Router, ROUTER_CONFIGURATION, RouteReuseStrategy, RouterModule, ROUTES, Routes, UrlHandlingStrategy, UrlSerializer, ɵassignExtraOptionsToRouter as assignExtraOptionsToRouter, ɵflatten as flatten, ɵROUTER_PROVIDERS as ROUTER_PROVIDERS} from '@angular/router';\n\n\n\n/**\n * @description\n *\n * Allows to simulate the loading of ng modules in tests.\n *\n * ```\n * const loader = TestBed.inject(NgModuleFactoryLoader);\n *\n * @Component({template: 'lazy-loaded'})\n * class LazyLoadedComponent {}\n * @NgModule({\n *   declarations: [LazyLoadedComponent],\n *   imports: [RouterModule.forChild([{path: 'loaded', component: LazyLoadedComponent}])]\n * })\n *\n * class LoadedModule {}\n *\n * // sets up stubbedModules\n * loader.stubbedModules = {lazyModule: LoadedModule};\n *\n * router.resetConfig([\n *   {path: 'lazy', loadChildren: 'lazyModule'},\n * ]);\n *\n * router.navigateByUrl('/lazy/loaded');\n * ```\n *\n * @publicApi\n */\n@Injectable()\nexport class SpyNgModuleFactoryLoader implements NgModuleFactoryLoader {\n  /**\n   * @docsNotRequired\n   */\n  private _stubbedModules: {[path: string]: Promise<NgModuleFactory<any>>} = {};\n\n  /**\n   * @docsNotRequired\n   */\n  set stubbedModules(modules: {[path: string]: any}) {\n    const res: {[path: string]: any} = {};\n    for (const t of Object.keys(modules)) {\n      res[t] = this.compiler.compileModuleAsync(modules[t]);\n    }\n    this._stubbedModules = res;\n  }\n\n  /**\n   * @docsNotRequired\n   */\n  get stubbedModules(): {[path: string]: any} {\n    return this._stubbedModules;\n  }\n\n  constructor(private compiler: Compiler) {}\n\n  load(path: string): Promise<NgModuleFactory<any>> {\n    if (this._stubbedModules[path]) {\n      return this._stubbedModules[path];\n    } else {\n      return <any>Promise.reject(new Error(`Cannot find module ${path}`));\n    }\n  }\n}\n\nfunction isUrlHandlingStrategy(opts: ExtraOptions|\n                               UrlHandlingStrategy): opts is UrlHandlingStrategy {\n  // This property check is needed because UrlHandlingStrategy is an interface and doesn't exist at\n  // runtime.\n  return 'shouldProcessUrl' in opts;\n}\n\n/**\n * Router setup factory function used for testing.\n *\n * @publicApi\n */\nexport function setupTestingRouter(\n    urlSerializer: UrlSerializer, contexts: ChildrenOutletContexts, location: Location,\n    loader: NgModuleFactoryLoader, compiler: Compiler, injector: Injector, routes: Route[][],\n    opts?: ExtraOptions, urlHandlingStrategy?: UrlHandlingStrategy): Router;\n\n/**\n * Router setup factory function used for testing.\n *\n * @deprecated As of v5.2. The 2nd-to-last argument should be `ExtraOptions`, not\n * `UrlHandlingStrategy`\n * @publicApi\n */\nexport function setupTestingRouter(\n    urlSerializer: UrlSerializer, contexts: ChildrenOutletContexts, location: Location,\n    loader: NgModuleFactoryLoader, compiler: Compiler, injector: Injector, routes: Route[][],\n    urlHandlingStrategy?: UrlHandlingStrategy): Router;\n\n/**\n * Router setup factory function used for testing.\n *\n * @publicApi\n */\nexport function setupTestingRouter(\n    urlSerializer: UrlSerializer, contexts: ChildrenOutletContexts, location: Location,\n    loader: NgModuleFactoryLoader, compiler: Compiler, injector: Injector, routes: Route[][],\n    opts?: ExtraOptions|UrlHandlingStrategy, urlHandlingStrategy?: UrlHandlingStrategy,\n    routeReuseStrategy?: RouteReuseStrategy) {\n  const router = new Router(\n      null!, urlSerializer, contexts, location, injector, loader, compiler, flatten(routes));\n  if (opts) {\n    // Handle deprecated argument ordering.\n    if (isUrlHandlingStrategy(opts)) {\n      router.urlHandlingStrategy = opts;\n    } else {\n      // Handle ExtraOptions\n      assignExtraOptionsToRouter(opts, router);\n    }\n  }\n\n  if (urlHandlingStrategy) {\n    router.urlHandlingStrategy = urlHandlingStrategy;\n  }\n\n  if (routeReuseStrategy) {\n    router.routeReuseStrategy = routeReuseStrategy;\n  }\n\n  return router;\n}\n\n/**\n * @description\n *\n * Sets up the router to be used for testing.\n *\n * The modules sets up the router to be used for testing.\n * It provides spy implementations of `Location`, `LocationStrategy`, and {@link\n * NgModuleFactoryLoader}.\n *\n * @usageNotes\n * ### Example\n *\n * ```\n * beforeEach(() => {\n *   TestBed.configureTestingModule({\n *     imports: [\n *       RouterTestingModule.withRoutes(\n *         [{path: '', component: BlankCmp}, {path: 'simple', component: SimpleCmp}]\n *       )\n *     ]\n *   });\n * });\n * ```\n *\n * @publicApi\n */\n@NgModule({\n  exports: [RouterModule],\n  providers: [\n    ROUTER_PROVIDERS, {provide: Location, useClass: SpyLocation},\n    {provide: LocationStrategy, useClass: MockLocationStrategy},\n    {provide: NgModuleFactoryLoader, useClass: SpyNgModuleFactoryLoader}, {\n      provide: Router,\n      useFactory: setupTestingRouter,\n      deps: [\n        UrlSerializer, ChildrenOutletContexts, Location, NgModuleFactoryLoader, Compiler, Injector,\n        ROUTES, ROUTER_CONFIGURATION, [UrlHandlingStrategy, new Optional()],\n        [RouteReuseStrategy, new Optional()]\n      ]\n    },\n    {provide: PreloadingStrategy, useExisting: NoPreloading}, provideRoutes([])\n  ]\n})\nexport class RouterTestingModule {\n  static withRoutes(routes: Routes, config?: ExtraOptions):\n      ModuleWithProviders<RouterTestingModule> {\n    return {\n      ngModule: RouterTestingModule,\n      providers: [\n        provideRoutes(routes),\n        {provide: ROUTER_CONFIGURATION, useValue: config ? config : {}},\n      ]\n    };\n  }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v12.2.0-next.3
2
+ * @license Angular v12.2.2
3
3
  * (c) 2010-2021 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -23,12 +23,14 @@ import { map, switchMap, take, startWith, scan, filter, catchError, concatMap, l
23
23
  * The following code shows how a class subscribes to router events.
24
24
  *
25
25
  * ```ts
26
+ * import {Event, RouterEvent, Router} from '@angular/router';
27
+ *
26
28
  * class MyService {
27
- * constructor(public router: Router, logger: Logger) {
29
+ * constructor(public router: Router) {
28
30
  * router.events.pipe(
29
31
  * filter((e: Event): e is RouterEvent => e instanceof RouterEvent)
30
32
  * ).subscribe((e: RouterEvent) => {
31
- * logger.log(e.id, e.url);
33
+ * // Do something
32
34
  * });
33
35
  * }
34
36
  * }
@@ -4050,6 +4052,11 @@ class Router {
4050
4052
  t.extractedUrl.toString() !== this.browserUrlTree.toString();
4051
4053
  const processCurrentUrl = (this.onSameUrlNavigation === 'reload' ? true : urlTransition) &&
4052
4054
  this.urlHandlingStrategy.shouldProcessUrl(t.rawUrl);
4055
+ // If the source of the navigation is from a browser event, the URL is
4056
+ // already updated. We already need to sync the internal state.
4057
+ if (isBrowserTriggeredNavigation(t.source)) {
4058
+ this.browserUrlTree = t.rawUrl;
4059
+ }
4053
4060
  if (processCurrentUrl) {
4054
4061
  return of(t).pipe(
4055
4062
  // Fire NavigationStart event
@@ -4135,7 +4142,8 @@ class Router {
4135
4142
  this.triggerEvent(guardsEnd);
4136
4143
  }), filter(t => {
4137
4144
  if (!t.guardsResult) {
4138
- this.cancelNavigationTransitionRestoreHistory(t, '');
4145
+ this.restoreHistory(t);
4146
+ this.cancelNavigationTransition(t, '');
4139
4147
  return false;
4140
4148
  }
4141
4149
  return true;
@@ -4152,7 +4160,8 @@ class Router {
4152
4160
  next: () => dataResolved = true,
4153
4161
  complete: () => {
4154
4162
  if (!dataResolved) {
4155
- this.cancelNavigationTransitionRestoreHistory(t, `At least one route resolver didn't emit any value.`);
4163
+ this.restoreHistory(t);
4164
+ this.cancelNavigationTransition(t, `At least one route resolver didn't emit any value.`);
4156
4165
  }
4157
4166
  }
4158
4167
  }));
@@ -4218,7 +4227,8 @@ class Router {
4218
4227
  // AngularJS sync code which looks for a value here in order to determine
4219
4228
  // whether or not to handle a given popstate event or to leave it to the
4220
4229
  // Angular router.
4221
- this.cancelNavigationTransitionRestoreHistory(t, cancelationReason);
4230
+ this.restoreHistory(t);
4231
+ this.cancelNavigationTransition(t, cancelationReason);
4222
4232
  }
4223
4233
  else {
4224
4234
  // We cannot trigger a `location.historyGo` if the
@@ -4237,6 +4247,17 @@ class Router {
4237
4247
  // we can safely set currentNavigation to null here.
4238
4248
  this.currentNavigation = null;
4239
4249
  }), catchError((e) => {
4250
+ // TODO(atscott): The NavigationTransition `t` used here does not accurately
4251
+ // reflect the current state of the whole transition because some operations
4252
+ // return a new object rather than modifying the one in the outermost
4253
+ // `switchMap`.
4254
+ // The fix can likely be to:
4255
+ // 1. Rename the outer `t` variable so it's not shadowed all the time and
4256
+ // confusing
4257
+ // 2. Keep reassigning to the outer variable after each stage to ensure it
4258
+ // gets updated. Or change the implementations to not return a copy.
4259
+ // Not changed yet because it affects existing code and would need to be
4260
+ // tested more thoroughly.
4240
4261
  errored = true;
4241
4262
  /* This error type is issued during Redirect, and is handled as a
4242
4263
  * cancellation rather than an error. */
@@ -4249,7 +4270,7 @@ class Router {
4249
4270
  // This is only applicable with initial navigation, so setting
4250
4271
  // `navigated` only when not redirecting resolves this scenario.
4251
4272
  this.navigated = true;
4252
- this.resetStateAndUrl(t.currentRouterState, t.currentUrlTree, t.rawUrl);
4273
+ this.restoreHistory(t, true);
4253
4274
  }
4254
4275
  const navCancel = new NavigationCancel(t.id, this.serializeUrl(t.extractedUrl), e.message);
4255
4276
  eventsSubject.next(navCancel);
@@ -4267,7 +4288,12 @@ class Router {
4267
4288
  const mergedTree = this.urlHandlingStrategy.merge(e.url, this.rawUrlTree);
4268
4289
  const extras = {
4269
4290
  skipLocationChange: t.extras.skipLocationChange,
4270
- replaceUrl: this.urlUpdateStrategy === 'eager'
4291
+ // The URL is already updated at this point if we have 'eager' URL
4292
+ // updates or if the navigation was triggered by the browser (back
4293
+ // button, URL bar, etc). We want to replace that item in history if
4294
+ // the navigation is rejected.
4295
+ replaceUrl: this.urlUpdateStrategy === 'eager' ||
4296
+ isBrowserTriggeredNavigation(t.source)
4271
4297
  };
4272
4298
  this.scheduleNavigation(mergedTree, 'imperative', null, extras, { resolve: t.resolve, reject: t.reject, promise: t.promise });
4273
4299
  }, 0);
@@ -4276,7 +4302,7 @@ class Router {
4276
4302
  * the pre-error state. */
4277
4303
  }
4278
4304
  else {
4279
- this.resetStateAndUrl(t.currentRouterState, t.currentUrlTree, t.rawUrl);
4305
+ this.restoreHistory(t, true);
4280
4306
  const navError = new NavigationError(t.id, this.serializeUrl(t.extractedUrl), e);
4281
4307
  eventsSubject.next(navError);
4282
4308
  try {
@@ -4644,7 +4670,8 @@ class Router {
4644
4670
  const lastNavigation = this.getTransition();
4645
4671
  // We don't want to skip duplicate successful navs if they're imperative because
4646
4672
  // onSameUrlNavigation could be 'reload' (so the duplicate is intended).
4647
- const browserNavPrecededByRouterNav = source !== 'imperative' && (lastNavigation === null || lastNavigation === void 0 ? void 0 : lastNavigation.source) === 'imperative';
4673
+ const browserNavPrecededByRouterNav = isBrowserTriggeredNavigation(source) && lastNavigation &&
4674
+ !isBrowserTriggeredNavigation(lastNavigation.source);
4648
4675
  const lastNavigationSucceeded = this.lastSuccessfulId === lastNavigation.id;
4649
4676
  // If the last navigation succeeded or is in flight, we can use the rawUrl as the comparison.
4650
4677
  // However, if it failed, we should compare to the final result (urlAfterRedirects).
@@ -4728,42 +4755,57 @@ class Router {
4728
4755
  this.location.go(path, '', state);
4729
4756
  }
4730
4757
  }
4731
- resetStateAndUrl(storedState, storedUrl, rawUrl) {
4732
- this.routerState = storedState;
4733
- this.currentUrlTree = storedUrl;
4734
- this.rawUrlTree = this.urlHandlingStrategy.merge(this.currentUrlTree, rawUrl);
4735
- this.resetUrlToCurrentUrlTree();
4736
- }
4737
- resetUrlToCurrentUrlTree() {
4738
- this.location.replaceState(this.urlSerializer.serialize(this.rawUrlTree), '', this.generateNgRouterState(this.lastSuccessfulId, this.currentPageId));
4739
- }
4740
4758
  /**
4741
- * Responsible for handling the cancellation of a navigation:
4742
- * - performs the necessary rollback action to restore the browser URL to the
4743
- * state before the transition
4744
- * - triggers the `NavigationCancel` event
4745
- * - resolves the transition promise with `false`
4759
+ * Performs the necessary rollback action to restore the browser URL to the
4760
+ * state before the transition.
4746
4761
  */
4747
- cancelNavigationTransitionRestoreHistory(t, reason) {
4762
+ restoreHistory(t, restoringFromCaughtError = false) {
4763
+ var _a, _b;
4748
4764
  if (this.canceledNavigationResolution === 'computed') {
4765
+ const targetPagePosition = this.currentPageId - t.targetPageId;
4749
4766
  // The navigator change the location before triggered the browser event,
4750
4767
  // so we need to go back to the current url if the navigation is canceled.
4751
4768
  // Also, when navigation gets cancelled while using url update strategy eager, then we need to
4752
4769
  // go back. Because, when `urlUpdateSrategy` is `eager`; `setBrowserUrl` method is called
4753
4770
  // before any verification.
4754
- if (t.source === 'popstate' || this.urlUpdateStrategy === 'eager') {
4755
- const targetPagePosition = this.currentPageId - t.targetPageId;
4771
+ const browserUrlUpdateOccurred = (t.source === 'popstate' || this.urlUpdateStrategy === 'eager' ||
4772
+ this.currentUrlTree === ((_a = this.currentNavigation) === null || _a === void 0 ? void 0 : _a.finalUrl));
4773
+ if (browserUrlUpdateOccurred && targetPagePosition !== 0) {
4756
4774
  this.location.historyGo(targetPagePosition);
4757
4775
  }
4776
+ else if (this.currentUrlTree === ((_b = this.currentNavigation) === null || _b === void 0 ? void 0 : _b.finalUrl) && targetPagePosition === 0) {
4777
+ // We got to the activation stage (where currentUrlTree is set to the navigation's
4778
+ // finalUrl), but we weren't moving anywhere in history (skipLocationChange or replaceUrl).
4779
+ // We still need to reset the router state back to what it was when the navigation started.
4780
+ this.resetState(t);
4781
+ // TODO(atscott): resetting the `browserUrlTree` should really be done in `resetState`.
4782
+ // Investigate if this can be done by running TGP.
4783
+ this.browserUrlTree = t.currentUrlTree;
4784
+ this.resetUrlToCurrentUrlTree();
4785
+ }
4758
4786
  else {
4759
- // If update is not 'eager' and the transition navigation source isn't 'popstate', then the
4760
- // navigation was cancelled before any browser url change so nothing needs to be restored.
4787
+ // The browser URL and router state was not updated before the navigation cancelled so
4788
+ // there's no restoration needed.
4761
4789
  }
4762
4790
  }
4763
- else {
4791
+ else if (this.canceledNavigationResolution === 'replace') {
4792
+ // TODO(atscott): It seems like we should _always_ reset the state here. It would be a no-op
4793
+ // for `deferred` navigations that haven't change the internal state yet because guards
4794
+ // reject. For 'eager' navigations, it seems like we also really should reset the state
4795
+ // because the navigation was cancelled. Investigate if this can be done by running TGP.
4796
+ if (restoringFromCaughtError) {
4797
+ this.resetState(t);
4798
+ }
4764
4799
  this.resetUrlToCurrentUrlTree();
4765
4800
  }
4766
- this.cancelNavigationTransition(t, reason);
4801
+ }
4802
+ resetState(t) {
4803
+ this.routerState = t.currentRouterState;
4804
+ this.currentUrlTree = t.currentUrlTree;
4805
+ this.rawUrlTree = this.urlHandlingStrategy.merge(this.currentUrlTree, t.rawUrl);
4806
+ }
4807
+ resetUrlToCurrentUrlTree() {
4808
+ this.location.replaceState(this.urlSerializer.serialize(this.rawUrlTree), '', this.generateNgRouterState(this.lastSuccessfulId, this.currentPageId));
4767
4809
  }
4768
4810
  cancelNavigationTransition(t, reason) {
4769
4811
  const navCancel = new NavigationCancel(t.id, this.serializeUrl(t.extractedUrl), reason);
@@ -4798,6 +4840,9 @@ function validateCommands(commands) {
4798
4840
  }
4799
4841
  }
4800
4842
  }
4843
+ function isBrowserTriggeredNavigation(source) {
4844
+ return source !== 'imperative';
4845
+ }
4801
4846
 
4802
4847
  /**
4803
4848
  * @license
@@ -5230,7 +5275,7 @@ class RouterLinkActive {
5230
5275
  });
5231
5276
  }
5232
5277
  isLinkActive(router) {
5233
- const options = 'paths' in this.routerLinkActiveOptions ?
5278
+ const options = isActiveMatchOptions(this.routerLinkActiveOptions) ?
5234
5279
  this.routerLinkActiveOptions :
5235
5280
  // While the types should disallow `undefined` here, it's possible without strict inputs
5236
5281
  (this.routerLinkActiveOptions.exact || false);
@@ -5263,6 +5308,12 @@ RouterLinkActive.propDecorators = {
5263
5308
  routerLinkActiveOptions: [{ type: Input }],
5264
5309
  routerLinkActive: [{ type: Input }]
5265
5310
  };
5311
+ /**
5312
+ * Use instead of `'paths' in options` to be compatible with property renaming
5313
+ */
5314
+ function isActiveMatchOptions(options) {
5315
+ return !!options.paths;
5316
+ }
5266
5317
 
5267
5318
  /**
5268
5319
  * @license
@@ -6023,7 +6074,7 @@ function provideRouterInitializer() {
6023
6074
  /**
6024
6075
  * @publicApi
6025
6076
  */
6026
- const VERSION = new Version('12.2.0-next.3');
6077
+ const VERSION = new Version('12.2.2');
6027
6078
 
6028
6079
  /**
6029
6080
  * @license