@angular/router 12.2.0-next.2 → 12.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/router-testing.umd.js +7 -3
- package/bundles/router-testing.umd.js.map +1 -1
- package/bundles/router-upgrade.umd.js +1 -1
- package/bundles/router.umd.js +69 -31
- package/bundles/router.umd.js.map +1 -1
- package/esm2015/src/directives/router_link_active.js +8 -2
- package/esm2015/src/directives/router_outlet.js +2 -2
- package/esm2015/src/events.js +5 -3
- package/esm2015/src/router.js +56 -27
- package/esm2015/src/version.js +1 -1
- package/esm2015/testing/src/router_testing_module.js +8 -4
- package/fesm2015/router.js +68 -31
- package/fesm2015/router.js.map +1 -1
- package/fesm2015/testing.js +8 -4
- package/fesm2015/testing.js.map +1 -1
- package/fesm2015/upgrade.js +1 -1
- package/package.json +5 -5
- package/router.d.ts +18 -11
- package/router.metadata.json +1 -1
- package/testing/testing.d.ts +1 -1
- package/testing/testing.metadata.json +1 -1
- package/testing.d.ts +1 -1
- package/upgrade/upgrade.d.ts +1 -1
- package/upgrade.d.ts +1 -1
package/esm2015/src/version.js
CHANGED
|
@@ -14,5 +14,5 @@ import { Version } from '@angular/core';
|
|
|
14
14
|
/**
|
|
15
15
|
* @publicApi
|
|
16
16
|
*/
|
|
17
|
-
export const VERSION = new Version('12.2.
|
|
17
|
+
export const VERSION = new Version('12.2.1');
|
|
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"]}
|
package/fesm2015/router.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v12.2.
|
|
2
|
+
* @license Angular v12.2.1
|
|
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
|
|
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
|
-
*
|
|
33
|
+
* // Do something
|
|
32
34
|
* });
|
|
33
35
|
* }
|
|
34
36
|
* }
|
|
@@ -4135,7 +4137,8 @@ class Router {
|
|
|
4135
4137
|
this.triggerEvent(guardsEnd);
|
|
4136
4138
|
}), filter(t => {
|
|
4137
4139
|
if (!t.guardsResult) {
|
|
4138
|
-
this.
|
|
4140
|
+
this.restoreHistory(t);
|
|
4141
|
+
this.cancelNavigationTransition(t, '');
|
|
4139
4142
|
return false;
|
|
4140
4143
|
}
|
|
4141
4144
|
return true;
|
|
@@ -4152,7 +4155,8 @@ class Router {
|
|
|
4152
4155
|
next: () => dataResolved = true,
|
|
4153
4156
|
complete: () => {
|
|
4154
4157
|
if (!dataResolved) {
|
|
4155
|
-
this.
|
|
4158
|
+
this.restoreHistory(t);
|
|
4159
|
+
this.cancelNavigationTransition(t, `At least one route resolver didn't emit any value.`);
|
|
4156
4160
|
}
|
|
4157
4161
|
}
|
|
4158
4162
|
}));
|
|
@@ -4218,7 +4222,8 @@ class Router {
|
|
|
4218
4222
|
// AngularJS sync code which looks for a value here in order to determine
|
|
4219
4223
|
// whether or not to handle a given popstate event or to leave it to the
|
|
4220
4224
|
// Angular router.
|
|
4221
|
-
this.
|
|
4225
|
+
this.restoreHistory(t);
|
|
4226
|
+
this.cancelNavigationTransition(t, cancelationReason);
|
|
4222
4227
|
}
|
|
4223
4228
|
else {
|
|
4224
4229
|
// We cannot trigger a `location.historyGo` if the
|
|
@@ -4237,6 +4242,17 @@ class Router {
|
|
|
4237
4242
|
// we can safely set currentNavigation to null here.
|
|
4238
4243
|
this.currentNavigation = null;
|
|
4239
4244
|
}), catchError((e) => {
|
|
4245
|
+
// TODO(atscott): The NavigationTransition `t` used here does not accurately
|
|
4246
|
+
// reflect the current state of the whole transition because some operations
|
|
4247
|
+
// return a new object rather than modifying the one in the outermost
|
|
4248
|
+
// `switchMap`.
|
|
4249
|
+
// The fix can likely be to:
|
|
4250
|
+
// 1. Rename the outer `t` variable so it's not shadowed all the time and
|
|
4251
|
+
// confusing
|
|
4252
|
+
// 2. Keep reassigning to the outer variable after each stage to ensure it
|
|
4253
|
+
// gets updated. Or change the implementations to not return a copy.
|
|
4254
|
+
// Not changed yet because it affects existing code and would need to be
|
|
4255
|
+
// tested more thoroughly.
|
|
4240
4256
|
errored = true;
|
|
4241
4257
|
/* This error type is issued during Redirect, and is handled as a
|
|
4242
4258
|
* cancellation rather than an error. */
|
|
@@ -4249,7 +4265,7 @@ class Router {
|
|
|
4249
4265
|
// This is only applicable with initial navigation, so setting
|
|
4250
4266
|
// `navigated` only when not redirecting resolves this scenario.
|
|
4251
4267
|
this.navigated = true;
|
|
4252
|
-
this.
|
|
4268
|
+
this.restoreHistory(t, true);
|
|
4253
4269
|
}
|
|
4254
4270
|
const navCancel = new NavigationCancel(t.id, this.serializeUrl(t.extractedUrl), e.message);
|
|
4255
4271
|
eventsSubject.next(navCancel);
|
|
@@ -4276,7 +4292,7 @@ class Router {
|
|
|
4276
4292
|
* the pre-error state. */
|
|
4277
4293
|
}
|
|
4278
4294
|
else {
|
|
4279
|
-
this.
|
|
4295
|
+
this.restoreHistory(t, true);
|
|
4280
4296
|
const navError = new NavigationError(t.id, this.serializeUrl(t.extractedUrl), e);
|
|
4281
4297
|
eventsSubject.next(navError);
|
|
4282
4298
|
try {
|
|
@@ -4728,42 +4744,57 @@ class Router {
|
|
|
4728
4744
|
this.location.go(path, '', state);
|
|
4729
4745
|
}
|
|
4730
4746
|
}
|
|
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
4747
|
/**
|
|
4741
|
-
*
|
|
4742
|
-
*
|
|
4743
|
-
* state before the transition
|
|
4744
|
-
* - triggers the `NavigationCancel` event
|
|
4745
|
-
* - resolves the transition promise with `false`
|
|
4748
|
+
* Performs the necessary rollback action to restore the browser URL to the
|
|
4749
|
+
* state before the transition.
|
|
4746
4750
|
*/
|
|
4747
|
-
|
|
4751
|
+
restoreHistory(t, restoringFromCaughtError = false) {
|
|
4752
|
+
var _a, _b;
|
|
4748
4753
|
if (this.canceledNavigationResolution === 'computed') {
|
|
4754
|
+
const targetPagePosition = this.currentPageId - t.targetPageId;
|
|
4749
4755
|
// The navigator change the location before triggered the browser event,
|
|
4750
4756
|
// so we need to go back to the current url if the navigation is canceled.
|
|
4751
4757
|
// Also, when navigation gets cancelled while using url update strategy eager, then we need to
|
|
4752
4758
|
// go back. Because, when `urlUpdateSrategy` is `eager`; `setBrowserUrl` method is called
|
|
4753
4759
|
// before any verification.
|
|
4754
|
-
|
|
4755
|
-
|
|
4760
|
+
const browserUrlUpdateOccurred = (t.source === 'popstate' || this.urlUpdateStrategy === 'eager' ||
|
|
4761
|
+
this.currentUrlTree === ((_a = this.currentNavigation) === null || _a === void 0 ? void 0 : _a.finalUrl));
|
|
4762
|
+
if (browserUrlUpdateOccurred && targetPagePosition !== 0) {
|
|
4756
4763
|
this.location.historyGo(targetPagePosition);
|
|
4757
4764
|
}
|
|
4765
|
+
else if (this.currentUrlTree === ((_b = this.currentNavigation) === null || _b === void 0 ? void 0 : _b.finalUrl) && targetPagePosition === 0) {
|
|
4766
|
+
// We got to the activation stage (where currentUrlTree is set to the navigation's
|
|
4767
|
+
// finalUrl), but we weren't moving anywhere in history (skipLocationChange or replaceUrl).
|
|
4768
|
+
// We still need to reset the router state back to what it was when the navigation started.
|
|
4769
|
+
this.resetState(t);
|
|
4770
|
+
// TODO(atscott): resetting the `browserUrlTree` should really be done in `resetState`.
|
|
4771
|
+
// Investigate if this can be done by running TGP.
|
|
4772
|
+
this.browserUrlTree = t.currentUrlTree;
|
|
4773
|
+
this.resetUrlToCurrentUrlTree();
|
|
4774
|
+
}
|
|
4758
4775
|
else {
|
|
4759
|
-
//
|
|
4760
|
-
//
|
|
4776
|
+
// The browser URL and router state was not updated before the navigation cancelled so
|
|
4777
|
+
// there's no restoration needed.
|
|
4761
4778
|
}
|
|
4762
4779
|
}
|
|
4763
|
-
else {
|
|
4780
|
+
else if (this.canceledNavigationResolution === 'replace') {
|
|
4781
|
+
// TODO(atscott): It seems like we should _always_ reset the state here. It would be a no-op
|
|
4782
|
+
// for `deferred` navigations that haven't change the internal state yet because guards
|
|
4783
|
+
// reject. For 'eager' navigations, it seems like we also really should reset the state
|
|
4784
|
+
// because the navigation was cancelled. Investigate if this can be done by running TGP.
|
|
4785
|
+
if (restoringFromCaughtError) {
|
|
4786
|
+
this.resetState(t);
|
|
4787
|
+
}
|
|
4764
4788
|
this.resetUrlToCurrentUrlTree();
|
|
4765
4789
|
}
|
|
4766
|
-
|
|
4790
|
+
}
|
|
4791
|
+
resetState(t) {
|
|
4792
|
+
this.routerState = t.currentRouterState;
|
|
4793
|
+
this.currentUrlTree = t.currentUrlTree;
|
|
4794
|
+
this.rawUrlTree = this.urlHandlingStrategy.merge(this.currentUrlTree, t.rawUrl);
|
|
4795
|
+
}
|
|
4796
|
+
resetUrlToCurrentUrlTree() {
|
|
4797
|
+
this.location.replaceState(this.urlSerializer.serialize(this.rawUrlTree), '', this.generateNgRouterState(this.lastSuccessfulId, this.currentPageId));
|
|
4767
4798
|
}
|
|
4768
4799
|
cancelNavigationTransition(t, reason) {
|
|
4769
4800
|
const navCancel = new NavigationCancel(t.id, this.serializeUrl(t.extractedUrl), reason);
|
|
@@ -5230,7 +5261,7 @@ class RouterLinkActive {
|
|
|
5230
5261
|
});
|
|
5231
5262
|
}
|
|
5232
5263
|
isLinkActive(router) {
|
|
5233
|
-
const options =
|
|
5264
|
+
const options = isActiveMatchOptions(this.routerLinkActiveOptions) ?
|
|
5234
5265
|
this.routerLinkActiveOptions :
|
|
5235
5266
|
// While the types should disallow `undefined` here, it's possible without strict inputs
|
|
5236
5267
|
(this.routerLinkActiveOptions.exact || false);
|
|
@@ -5263,6 +5294,12 @@ RouterLinkActive.propDecorators = {
|
|
|
5263
5294
|
routerLinkActiveOptions: [{ type: Input }],
|
|
5264
5295
|
routerLinkActive: [{ type: Input }]
|
|
5265
5296
|
};
|
|
5297
|
+
/**
|
|
5298
|
+
* Use instead of `'paths' in options` to be compatible with property renaming
|
|
5299
|
+
*/
|
|
5300
|
+
function isActiveMatchOptions(options) {
|
|
5301
|
+
return !!options.paths;
|
|
5302
|
+
}
|
|
5266
5303
|
|
|
5267
5304
|
/**
|
|
5268
5305
|
* @license
|
|
@@ -6023,7 +6060,7 @@ function provideRouterInitializer() {
|
|
|
6023
6060
|
/**
|
|
6024
6061
|
* @publicApi
|
|
6025
6062
|
*/
|
|
6026
|
-
const VERSION = new Version('12.2.
|
|
6063
|
+
const VERSION = new Version('12.2.1');
|
|
6027
6064
|
|
|
6028
6065
|
/**
|
|
6029
6066
|
* @license
|