@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.
- 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 +85 -33
- 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 +72 -29
- package/esm2015/src/version.js +1 -1
- package/esm2015/testing/src/router_testing_module.js +8 -4
- package/fesm2015/router.js +84 -33
- 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.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"]}
|
package/fesm2015/router.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v12.2.
|
|
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
|
|
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
|
* }
|
|
@@ -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.
|
|
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.
|
|
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.
|
|
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.
|
|
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
|
-
|
|
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.
|
|
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
|
|
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
|
-
*
|
|
4742
|
-
*
|
|
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
|
-
|
|
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
|
-
|
|
4755
|
-
|
|
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
|
-
//
|
|
4760
|
-
//
|
|
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
|
-
|
|
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 =
|
|
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.
|
|
6077
|
+
const VERSION = new Version('12.2.2');
|
|
6027
6078
|
|
|
6028
6079
|
/**
|
|
6029
6080
|
* @license
|