@angular/router 14.0.0-next.1 → 14.0.0-next.12

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 (50) hide show
  1. package/esm2020/src/apply_redirects.mjs +12 -13
  2. package/esm2020/src/components/empty_outlet.mjs +3 -3
  3. package/esm2020/src/create_url_tree.mjs +8 -7
  4. package/esm2020/src/directives/router_link.mjs +15 -18
  5. package/esm2020/src/directives/router_link_active.mjs +3 -3
  6. package/esm2020/src/directives/router_outlet.mjs +4 -4
  7. package/esm2020/src/events.mjs +1 -1
  8. package/esm2020/src/index.mjs +1 -1
  9. package/esm2020/src/models.mjs +14 -0
  10. package/esm2020/src/operators/activate_routes.mjs +1 -1
  11. package/esm2020/src/operators/apply_redirects.mjs +1 -1
  12. package/esm2020/src/operators/check_guards.mjs +1 -1
  13. package/esm2020/src/operators/recognize.mjs +1 -1
  14. package/esm2020/src/operators/resolve_data.mjs +12 -15
  15. package/esm2020/src/page_title_strategy.mjs +3 -3
  16. package/esm2020/src/private_export.mjs +1 -1
  17. package/esm2020/src/recognize.mjs +4 -4
  18. package/esm2020/src/router.mjs +7 -19
  19. package/esm2020/src/router_config_loader.mjs +2 -2
  20. package/esm2020/src/router_module.mjs +8 -8
  21. package/esm2020/src/router_preloader.mjs +4 -4
  22. package/esm2020/src/router_scroller.mjs +3 -3
  23. package/esm2020/src/router_state.mjs +2 -2
  24. package/esm2020/src/shared.mjs +1 -1
  25. package/esm2020/src/url_tree.mjs +2 -2
  26. package/esm2020/src/utils/config.mjs +1 -4
  27. package/esm2020/src/utils/config_matching.mjs +4 -4
  28. package/esm2020/src/utils/preactivation.mjs +1 -1
  29. package/esm2020/src/utils/type_guards.mjs +1 -1
  30. package/esm2020/src/version.mjs +1 -1
  31. package/esm2020/testing/src/router_testing_module.mjs +4 -4
  32. package/esm2020/upgrade/src/upgrade.mjs +15 -5
  33. package/fesm2015/router.mjs +86 -103
  34. package/fesm2015/router.mjs.map +1 -1
  35. package/fesm2015/testing.mjs +5 -5
  36. package/fesm2015/testing.mjs.map +1 -1
  37. package/fesm2015/upgrade.mjs +16 -5
  38. package/fesm2015/upgrade.mjs.map +1 -1
  39. package/fesm2020/router.mjs +82 -103
  40. package/fesm2020/router.mjs.map +1 -1
  41. package/fesm2020/testing.mjs +5 -5
  42. package/fesm2020/testing.mjs.map +1 -1
  43. package/fesm2020/upgrade.mjs +15 -5
  44. package/fesm2020/upgrade.mjs.map +1 -1
  45. package/package.json +5 -5
  46. package/router.d.ts +39 -9
  47. package/testing/testing.d.ts +1 -1
  48. package/upgrade/upgrade.d.ts +1 -1
  49. package/esm2020/src/config.mjs +0 -14
  50. package/esm2020/src/interfaces.mjs +0 -9
@@ -85,9 +85,9 @@ export class RouterTestingModule {
85
85
  };
86
86
  }
87
87
  }
88
- RouterTestingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterTestingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
89
- RouterTestingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterTestingModule, exports: [RouterModule] });
90
- RouterTestingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterTestingModule, providers: [
88
+ RouterTestingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterTestingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
89
+ RouterTestingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterTestingModule, exports: [RouterModule] });
90
+ RouterTestingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterTestingModule, providers: [
91
91
  ROUTER_PROVIDERS,
92
92
  EXTRA_ROUTER_TESTING_PROVIDERS,
93
93
  { provide: Location, useClass: SpyLocation },
@@ -112,7 +112,7 @@ RouterTestingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ver
112
112
  { provide: PreloadingStrategy, useExisting: NoPreloading },
113
113
  provideRoutes([]),
114
114
  ], imports: [RouterModule] });
115
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterTestingModule, decorators: [{
115
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterTestingModule, decorators: [{
116
116
  type: NgModule,
117
117
  args: [{
118
118
  exports: [RouterModule],
@@ -68,15 +68,25 @@ export function setUpLocationSync(ngUpgrade, urlType = 'path') {
68
68
  const router = ngUpgrade.injector.get(Router);
69
69
  const location = ngUpgrade.injector.get(Location);
70
70
  ngUpgrade.$injector.get('$rootScope')
71
- .$on('$locationChangeStart', (_, next, __) => {
71
+ .$on('$locationChangeStart', (event, newUrl, oldUrl, newState, oldState) => {
72
+ // Navigations coming from Angular router have a navigationId state
73
+ // property. Don't trigger Angular router navigation again if it is
74
+ // caused by a URL change from the current Angular router
75
+ // navigation.
76
+ const currentNavigationId = router.getCurrentNavigation()?.id;
77
+ const newStateNavigationId = newState?.navigationId;
78
+ if (newStateNavigationId !== undefined &&
79
+ newStateNavigationId === currentNavigationId) {
80
+ return;
81
+ }
72
82
  let url;
73
83
  if (urlType === 'path') {
74
- url = resolveUrl(next);
84
+ url = resolveUrl(newUrl);
75
85
  }
76
86
  else if (urlType === 'hash') {
77
87
  // Remove the first hash from the URL
78
- const hashIdx = next.indexOf('#');
79
- url = resolveUrl(next.substring(0, hashIdx) + next.substring(hashIdx + 1));
88
+ const hashIdx = newUrl.indexOf('#');
89
+ url = resolveUrl(newUrl.substring(0, hashIdx) + newUrl.substring(hashIdx + 1));
80
90
  }
81
91
  else {
82
92
  throw 'Invalid URLType passed to setUpLocationSync: ' + urlType;
@@ -117,4 +127,4 @@ function resolveUrl(url) {
117
127
  hash: anchor.hash
118
128
  };
119
129
  }
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upgrade.js","sourceRoot":"","sources":["../../../../../../../packages/router/upgrade/src/upgrade.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAC,sBAAsB,EAA+B,MAAM,eAAe,CAAC;AACnF,OAAO,EAAC,MAAM,EAAC,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAC,aAAa,EAAC,MAAM,yBAAyB,CAAC;AAEtD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG;IACtC,OAAO,EAAE,sBAAsB;IAC/B,KAAK,EAAE,IAAI;IACX,UAAU,EAAE,6BAAyE;IACrF,IAAI,EAAE,CAAC,aAAa,CAAC;CACtB,CAAC;AAEF;;GAEG;AACH,MAAM,UAAU,6BAA6B,CAAC,SAAwB;IACpE,OAAO,GAAG,EAAE;QACV,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAC/B,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,iBAAiB,CAAC,SAAwB,EAAE,UAAyB,MAAM;IACzF,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE;QACxB,MAAM,IAAI,KAAK,CAAC;;;OAGb,CAAC,CAAC;KACN;IAED,MAAM,MAAM,GAAW,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACtD,MAAM,QAAQ,GAAa,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAE5D,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC;SAChC,GAAG,CAAC,sBAAsB,EAAE,CAAC,CAAM,EAAE,IAAY,EAAE,EAAU,EAAE,EAAE;QAChE,IAAI,GAAG,CAAC;QACR,IAAI,OAAO,KAAK,MAAM,EAAE;YACtB,GAAG,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;SACxB;aAAM,IAAI,OAAO,KAAK,MAAM,EAAE;YAC7B,qCAAqC;YACrC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAClC,GAAG,GAAG,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;SAC5E;aAAM;YACL,MAAM,+CAA+C,GAAG,OAAO,CAAC;SACjE;QACD,MAAM,IAAI,GAAG,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC9C,MAAM,CAAC,aAAa,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACT,CAAC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,IAAI,MAAmC,CAAC;AACxC,SAAS,UAAU,CAAC,GAAW;IAC7B,IAAI,CAAC,MAAM,EAAE;QACX,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;KACtC;IAED,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACjC,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IAEzC,OAAO;QACL,6DAA6D;QAC7D,QAAQ,EAAE,IAAI,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE;QAClD,MAAM,EAAE,MAAM,CAAC,MAAM;QACrB,IAAI,EAAE,MAAM,CAAC,IAAI;KAClB,CAAC;AACJ,CAAC","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} from '@angular/common';\nimport {APP_BOOTSTRAP_LISTENER, ComponentRef, InjectionToken} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {UpgradeModule} from '@angular/upgrade/static';\n\n/**\n * Creates an initializer that sets up `ngRoute` integration\n * along with setting up the Angular router.\n *\n * @usageNotes\n *\n * <code-example language=\"typescript\">\n * @NgModule({\n *  imports: [\n *   RouterModule.forRoot(SOME_ROUTES),\n *   UpgradeModule\n * ],\n * providers: [\n *   RouterUpgradeInitializer\n * ]\n * })\n * export class AppModule {\n *   ngDoBootstrap() {}\n * }\n * </code-example>\n *\n * @publicApi\n */\nexport const RouterUpgradeInitializer = {\n  provide: APP_BOOTSTRAP_LISTENER,\n  multi: true,\n  useFactory: locationSyncBootstrapListener as (ngUpgrade: UpgradeModule) => () => void,\n  deps: [UpgradeModule]\n};\n\n/**\n * @internal\n */\nexport function locationSyncBootstrapListener(ngUpgrade: UpgradeModule) {\n  return () => {\n    setUpLocationSync(ngUpgrade);\n  };\n}\n\n/**\n * Sets up a location change listener to trigger `history.pushState`.\n * Works around the problem that `onPopState` does not trigger `history.pushState`.\n * Must be called *after* calling `UpgradeModule.bootstrap`.\n *\n * @param ngUpgrade The upgrade NgModule.\n * @param urlType The location strategy.\n * @see `HashLocationStrategy`\n * @see `PathLocationStrategy`\n *\n * @publicApi\n */\nexport function setUpLocationSync(ngUpgrade: UpgradeModule, urlType: 'path'|'hash' = 'path') {\n  if (!ngUpgrade.$injector) {\n    throw new Error(`\n        RouterUpgradeInitializer can be used only after UpgradeModule.bootstrap has been called.\n        Remove RouterUpgradeInitializer and call setUpLocationSync after UpgradeModule.bootstrap.\n      `);\n  }\n\n  const router: Router = ngUpgrade.injector.get(Router);\n  const location: Location = ngUpgrade.injector.get(Location);\n\n  ngUpgrade.$injector.get('$rootScope')\n      .$on('$locationChangeStart', (_: any, next: string, __: string) => {\n        let url;\n        if (urlType === 'path') {\n          url = resolveUrl(next);\n        } else if (urlType === 'hash') {\n          // Remove the first hash from the URL\n          const hashIdx = next.indexOf('#');\n          url = resolveUrl(next.substring(0, hashIdx) + next.substring(hashIdx + 1));\n        } else {\n          throw 'Invalid URLType passed to setUpLocationSync: ' + urlType;\n        }\n        const path = location.normalize(url.pathname);\n        router.navigateByUrl(path + url.search + url.hash);\n      });\n}\n\n/**\n * Normalizes and parses a URL.\n *\n * - Normalizing means that a relative URL will be resolved into an absolute URL in the context of\n *   the application document.\n * - Parsing means that the anchor's `protocol`, `hostname`, `port`, `pathname` and related\n *   properties are all populated to reflect the normalized URL.\n *\n * While this approach has wide compatibility, it doesn't work as expected on IE. On IE, normalizing\n * happens similar to other browsers, but the parsed components will not be set. (E.g. if you assign\n * `a.href = 'foo'`, then `a.protocol`, `a.host`, etc. will not be correctly updated.)\n * We work around that by performing the parsing in a 2nd step by taking a previously normalized URL\n * and assigning it again. This correctly populates all properties.\n *\n * See\n * https://github.com/angular/angular.js/blob/2c7400e7d07b0f6cec1817dab40b9250ce8ebce6/src/ng/urlUtils.js#L26-L33\n * for more info.\n */\nlet anchor: HTMLAnchorElement|undefined;\nfunction resolveUrl(url: string): {pathname: string, search: string, hash: string} {\n  if (!anchor) {\n    anchor = document.createElement('a');\n  }\n\n  anchor.setAttribute('href', url);\n  anchor.setAttribute('href', anchor.href);\n\n  return {\n    // IE does not start `pathname` with `/` like other browsers.\n    pathname: `/${anchor.pathname.replace(/^\\//, '')}`,\n    search: anchor.search,\n    hash: anchor.hash\n  };\n}\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upgrade.js","sourceRoot":"","sources":["../../../../../../../packages/router/upgrade/src/upgrade.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAC,sBAAsB,EAA+B,MAAM,eAAe,CAAC;AACnF,OAAO,EAAC,MAAM,EAAkC,MAAM,iBAAiB,CAAC;AACxE,OAAO,EAAC,aAAa,EAAC,MAAM,yBAAyB,CAAC;AAEtD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG;IACtC,OAAO,EAAE,sBAAsB;IAC/B,KAAK,EAAE,IAAI;IACX,UAAU,EAAE,6BAAyE;IACrF,IAAI,EAAE,CAAC,aAAa,CAAC;CACtB,CAAC;AAEF;;GAEG;AACH,MAAM,UAAU,6BAA6B,CAAC,SAAwB;IACpE,OAAO,GAAG,EAAE;QACV,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAC/B,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,iBAAiB,CAAC,SAAwB,EAAE,UAAyB,MAAM;IACzF,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE;QACxB,MAAM,IAAI,KAAK,CAAC;;;OAGb,CAAC,CAAC;KACN;IAED,MAAM,MAAM,GAAW,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACtD,MAAM,QAAQ,GAAa,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAE5D,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC;SAChC,GAAG,CACA,sBAAsB,EACtB,CAAC,KAAU,EAAE,MAAc,EAAE,MAAc,EAC1C,QAA+C,EAC/C,QAA+C,EAAE,EAAE;QAClD,mEAAmE;QACnE,mEAAmE;QACnE,yDAAyD;QACzD,cAAc;QACd,MAAM,mBAAmB,GAAG,MAAM,CAAC,oBAAoB,EAAE,EAAE,EAAE,CAAC;QAC9D,MAAM,oBAAoB,GAAG,QAAQ,EAAE,YAAY,CAAC;QACpD,IAAI,oBAAoB,KAAK,SAAS;YAClC,oBAAoB,KAAK,mBAAmB,EAAE;YAChD,OAAO;SACR;QAED,IAAI,GAAG,CAAC;QACR,IAAI,OAAO,KAAK,MAAM,EAAE;YACtB,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;SAC1B;aAAM,IAAI,OAAO,KAAK,MAAM,EAAE;YAC7B,qCAAqC;YACrC,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YACpC,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;SAChF;aAAM;YACL,MAAM,+CAA+C,GAAG,OAAO,CAAC;SACjE;QACD,MAAM,IAAI,GAAG,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC9C,MAAM,CAAC,aAAa,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACb,CAAC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,IAAI,MAAmC,CAAC;AACxC,SAAS,UAAU,CAAC,GAAW;IAC7B,IAAI,CAAC,MAAM,EAAE;QACX,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;KACtC;IAED,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACjC,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IAEzC,OAAO;QACL,6DAA6D;QAC7D,QAAQ,EAAE,IAAI,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE;QAClD,MAAM,EAAE,MAAM,CAAC,MAAM;QACrB,IAAI,EAAE,MAAM,CAAC,IAAI;KAClB,CAAC;AACJ,CAAC","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} from '@angular/common';\nimport {APP_BOOTSTRAP_LISTENER, ComponentRef, InjectionToken} from '@angular/core';\nimport {Router, ɵRestoredState as RestoredState} from '@angular/router';\nimport {UpgradeModule} from '@angular/upgrade/static';\n\n/**\n * Creates an initializer that sets up `ngRoute` integration\n * along with setting up the Angular router.\n *\n * @usageNotes\n *\n * <code-example language=\"typescript\">\n * @NgModule({\n *  imports: [\n *   RouterModule.forRoot(SOME_ROUTES),\n *   UpgradeModule\n * ],\n * providers: [\n *   RouterUpgradeInitializer\n * ]\n * })\n * export class AppModule {\n *   ngDoBootstrap() {}\n * }\n * </code-example>\n *\n * @publicApi\n */\nexport const RouterUpgradeInitializer = {\n  provide: APP_BOOTSTRAP_LISTENER,\n  multi: true,\n  useFactory: locationSyncBootstrapListener as (ngUpgrade: UpgradeModule) => () => void,\n  deps: [UpgradeModule]\n};\n\n/**\n * @internal\n */\nexport function locationSyncBootstrapListener(ngUpgrade: UpgradeModule) {\n  return () => {\n    setUpLocationSync(ngUpgrade);\n  };\n}\n\n/**\n * Sets up a location change listener to trigger `history.pushState`.\n * Works around the problem that `onPopState` does not trigger `history.pushState`.\n * Must be called *after* calling `UpgradeModule.bootstrap`.\n *\n * @param ngUpgrade The upgrade NgModule.\n * @param urlType The location strategy.\n * @see `HashLocationStrategy`\n * @see `PathLocationStrategy`\n *\n * @publicApi\n */\nexport function setUpLocationSync(ngUpgrade: UpgradeModule, urlType: 'path'|'hash' = 'path') {\n  if (!ngUpgrade.$injector) {\n    throw new Error(`\n        RouterUpgradeInitializer can be used only after UpgradeModule.bootstrap has been called.\n        Remove RouterUpgradeInitializer and call setUpLocationSync after UpgradeModule.bootstrap.\n      `);\n  }\n\n  const router: Router = ngUpgrade.injector.get(Router);\n  const location: Location = ngUpgrade.injector.get(Location);\n\n  ngUpgrade.$injector.get('$rootScope')\n      .$on(\n          '$locationChangeStart',\n          (event: any, newUrl: string, oldUrl: string,\n           newState?: {[k: string]: unknown}|RestoredState,\n           oldState?: {[k: string]: unknown}|RestoredState) => {\n            // Navigations coming from Angular router have a navigationId state\n            // property. Don't trigger Angular router navigation again if it is\n            // caused by a URL change from the current Angular router\n            // navigation.\n            const currentNavigationId = router.getCurrentNavigation()?.id;\n            const newStateNavigationId = newState?.navigationId;\n            if (newStateNavigationId !== undefined &&\n                newStateNavigationId === currentNavigationId) {\n              return;\n            }\n\n            let url;\n            if (urlType === 'path') {\n              url = resolveUrl(newUrl);\n            } else if (urlType === 'hash') {\n              // Remove the first hash from the URL\n              const hashIdx = newUrl.indexOf('#');\n              url = resolveUrl(newUrl.substring(0, hashIdx) + newUrl.substring(hashIdx + 1));\n            } else {\n              throw 'Invalid URLType passed to setUpLocationSync: ' + urlType;\n            }\n            const path = location.normalize(url.pathname);\n            router.navigateByUrl(path + url.search + url.hash);\n          });\n}\n\n/**\n * Normalizes and parses a URL.\n *\n * - Normalizing means that a relative URL will be resolved into an absolute URL in the context of\n *   the application document.\n * - Parsing means that the anchor's `protocol`, `hostname`, `port`, `pathname` and related\n *   properties are all populated to reflect the normalized URL.\n *\n * While this approach has wide compatibility, it doesn't work as expected on IE. On IE, normalizing\n * happens similar to other browsers, but the parsed components will not be set. (E.g. if you assign\n * `a.href = 'foo'`, then `a.protocol`, `a.host`, etc. will not be correctly updated.)\n * We work around that by performing the parsing in a 2nd step by taking a previously normalized URL\n * and assigning it again. This correctly populates all properties.\n *\n * See\n * https://github.com/angular/angular.js/blob/2c7400e7d07b0f6cec1817dab40b9250ce8ebce6/src/ng/urlUtils.js#L26-L33\n * for more info.\n */\nlet anchor: HTMLAnchorElement|undefined;\nfunction resolveUrl(url: string): {pathname: string, search: string, hash: string} {\n  if (!anchor) {\n    anchor = document.createElement('a');\n  }\n\n  anchor.setAttribute('href', url);\n  anchor.setAttribute('href', anchor.href);\n\n  return {\n    // IE does not start `pathname` with `/` like other browsers.\n    pathname: `/${anchor.pathname.replace(/^\\//, '')}`,\n    search: anchor.search,\n    hash: anchor.hash\n  };\n}\n"]}
@@ -1,12 +1,12 @@
1
1
  /**
2
- * @license Angular v14.0.0-next.1
2
+ * @license Angular v14.0.0-next.12
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
6
6
 
7
7
  import * as i0 from '@angular/core';
8
- import { ɵisObservable, ɵisPromise, EventEmitter, Directive, Attribute, Output, Component, NgModuleRef, InjectionToken, InjectFlags, NgModuleFactory, ɵConsole, NgZone, Injectable, Input, HostListener, HostBinding, Optional, ContentChildren, Injector, Compiler, NgProbeToken, ANALYZE_FOR_ENTRY_COMPONENTS, SkipSelf, Inject, APP_INITIALIZER, APP_BOOTSTRAP_LISTENER, NgModule, ApplicationRef, Version } from '@angular/core';
9
- import { from, of, BehaviorSubject, combineLatest, Observable, EmptyError, concat, defer, EMPTY, ConnectableObservable, Subject } from 'rxjs';
8
+ import { ɵisObservable, ɵisPromise, EventEmitter, Directive, Attribute, Output, Component, NgModuleRef, InjectionToken, InjectFlags, NgModuleFactory, ɵConsole, NgZone, Injectable, ɵcoerceToBoolean, Input, HostListener, HostBinding, Optional, ContentChildren, Injector, Compiler, NgProbeToken, ANALYZE_FOR_ENTRY_COMPONENTS, SkipSelf, Inject, APP_INITIALIZER, APP_BOOTSTRAP_LISTENER, NgModule, ApplicationRef, Version } from '@angular/core';
9
+ import { from, of, BehaviorSubject, combineLatest, throwError, EmptyError, concat, defer, Observable, EMPTY, ConnectableObservable, Subject } from 'rxjs';
10
10
  import { map, switchMap, take, startWith, scan, filter, catchError, concatMap, last as last$1, first, mergeMap, tap, takeLast, refCount, finalize, mergeAll } from 'rxjs/operators';
11
11
  import * as i3 from '@angular/common';
12
12
  import { Location, LocationStrategy, PlatformLocation, APP_BASE_HREF, ViewportScroller, HashLocationStrategy, PathLocationStrategy, LOCATION_INITIALIZED } from '@angular/common';
@@ -1131,7 +1131,7 @@ class UrlParser {
1131
1131
  }
1132
1132
  let outletName = undefined;
1133
1133
  if (path.indexOf(':') > -1) {
1134
- outletName = path.substr(0, path.indexOf(':'));
1134
+ outletName = path.slice(0, path.indexOf(':'));
1135
1135
  this.capture(outletName);
1136
1136
  this.capture(':');
1137
1137
  }
@@ -1454,9 +1454,10 @@ function inheritedParamsDataResolve(route, paramsInheritanceStrategy = 'emptyOnl
1454
1454
  /** @internal */
1455
1455
  function flattenInherited(pathFromRoot) {
1456
1456
  return pathFromRoot.reduce((res, curr) => {
1457
+ var _a;
1457
1458
  const params = Object.assign(Object.assign({}, res.params), curr.params);
1458
1459
  const data = Object.assign(Object.assign({}, res.data), curr.data);
1459
- const resolve = Object.assign(Object.assign({}, res.resolve), curr._resolvedData);
1460
+ const resolve = Object.assign(Object.assign(Object.assign(Object.assign({}, curr.data), res.resolve), (_a = curr.routeConfig) === null || _a === void 0 ? void 0 : _a.data), curr._resolvedData);
1460
1461
  return { params, data, resolve };
1461
1462
  }, { params: {}, data: {}, resolve: {} });
1462
1463
  }
@@ -1713,17 +1714,17 @@ function createActivatedRoute(c) {
1713
1714
  */
1714
1715
  function createUrlTree(route, urlTree, commands, queryParams, fragment) {
1715
1716
  if (commands.length === 0) {
1716
- return tree(urlTree.root, urlTree.root, urlTree, queryParams, fragment);
1717
+ return tree(urlTree.root, urlTree.root, urlTree.root, queryParams, fragment);
1717
1718
  }
1718
1719
  const nav = computeNavigation(commands);
1719
1720
  if (nav.toRoot()) {
1720
- return tree(urlTree.root, new UrlSegmentGroup([], {}), urlTree, queryParams, fragment);
1721
+ return tree(urlTree.root, urlTree.root, new UrlSegmentGroup([], {}), queryParams, fragment);
1721
1722
  }
1722
1723
  const startingPosition = findStartingPosition(nav, urlTree, route);
1723
1724
  const segmentGroup = startingPosition.processChildren ?
1724
1725
  updateSegmentGroupChildren(startingPosition.segmentGroup, startingPosition.index, nav.commands) :
1725
1726
  updateSegmentGroup(startingPosition.segmentGroup, startingPosition.index, nav.commands);
1726
- return tree(startingPosition.segmentGroup, segmentGroup, urlTree, queryParams, fragment);
1727
+ return tree(urlTree.root, startingPosition.segmentGroup, segmentGroup, queryParams, fragment);
1727
1728
  }
1728
1729
  function isMatrixParams(command) {
1729
1730
  return typeof command === 'object' && command != null && !command.outlets && !command.segmentPath;
@@ -1735,17 +1736,18 @@ function isMatrixParams(command) {
1735
1736
  function isCommandWithOutlets(command) {
1736
1737
  return typeof command === 'object' && command != null && command.outlets;
1737
1738
  }
1738
- function tree(oldSegmentGroup, newSegmentGroup, urlTree, queryParams, fragment) {
1739
+ function tree(oldRoot, oldSegmentGroup, newSegmentGroup, queryParams, fragment) {
1739
1740
  let qp = {};
1740
1741
  if (queryParams) {
1741
1742
  forEach(queryParams, (value, name) => {
1742
1743
  qp[name] = Array.isArray(value) ? value.map((v) => `${v}`) : `${value}`;
1743
1744
  });
1744
1745
  }
1745
- if (urlTree.root === oldSegmentGroup) {
1746
+ if (oldRoot === oldSegmentGroup) {
1746
1747
  return new UrlTree(newSegmentGroup, qp, fragment);
1747
1748
  }
1748
- return new UrlTree(replaceSegment(urlTree.root, oldSegmentGroup, newSegmentGroup), qp, fragment);
1749
+ const newRoot = replaceSegment(oldRoot, oldSegmentGroup, newSegmentGroup);
1750
+ return new UrlTree(newRoot, qp, fragment);
1749
1751
  }
1750
1752
  function replaceSegment(current, oldSegment, newSegment) {
1751
1753
  const children = {};
@@ -2525,9 +2527,9 @@ class RouterOutlet {
2525
2527
  this.activateEvents.emit(this.activated.instance);
2526
2528
  }
2527
2529
  }
2528
- RouterOutlet.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterOutlet, deps: [{ token: ChildrenOutletContexts }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }, { token: 'name', attribute: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
2529
- RouterOutlet.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.1", type: RouterOutlet, selector: "router-outlet", outputs: { activateEvents: "activate", deactivateEvents: "deactivate", attachEvents: "attach", detachEvents: "detach" }, exportAs: ["outlet"], ngImport: i0 });
2530
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterOutlet, decorators: [{
2530
+ RouterOutlet.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterOutlet, deps: [{ token: ChildrenOutletContexts }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }, { token: 'name', attribute: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
2531
+ RouterOutlet.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.12", type: RouterOutlet, selector: "router-outlet", outputs: { activateEvents: "activate", deactivateEvents: "deactivate", attachEvents: "attach", detachEvents: "detach" }, exportAs: ["outlet"], ngImport: i0 });
2532
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterOutlet, decorators: [{
2531
2533
  type: Directive,
2532
2534
  args: [{ selector: 'router-outlet', exportAs: 'outlet' }]
2533
2535
  }], ctorParameters: function () {
@@ -2583,9 +2585,9 @@ class OutletInjector {
2583
2585
  */
2584
2586
  class ɵEmptyOutletComponent {
2585
2587
  }
2586
- ɵEmptyOutletComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: ɵEmptyOutletComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2587
- ɵEmptyOutletComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "14.0.0-next.1", type: ɵEmptyOutletComponent, selector: "ng-component", ngImport: i0, template: `<router-outlet></router-outlet>`, isInline: true, directives: [{ type: RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] });
2588
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: ɵEmptyOutletComponent, decorators: [{
2588
+ ɵEmptyOutletComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: ɵEmptyOutletComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2589
+ ɵEmptyOutletComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "14.0.0-next.12", type: ɵEmptyOutletComponent, selector: "ng-component", ngImport: i0, template: `<router-outlet></router-outlet>`, isInline: true, directives: [{ type: RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] });
2590
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: ɵEmptyOutletComponent, decorators: [{
2589
2591
  type: Component,
2590
2592
  args: [{ template: `<router-outlet></router-outlet>` }]
2591
2593
  }] });
@@ -2659,9 +2661,6 @@ function validateNode(route, fullPath) {
2659
2661
  const exp = `The default value of 'pathMatch' is 'prefix', but often the intent is to use 'full'.`;
2660
2662
  throw new Error(`Invalid configuration of route '{path: "${fullPath}", redirectTo: "${route.redirectTo}"}': please provide 'pathMatch'. ${exp}`);
2661
2663
  }
2662
- if (route.pathMatch !== void 0 && route.pathMatch !== 'full' && route.pathMatch !== 'prefix') {
2663
- throw new Error(`Invalid configuration of route '${fullPath}': pathMatch can only be set to 'prefix' or 'full'`);
2664
- }
2665
2664
  }
2666
2665
  if (route.children) {
2667
2666
  validateConfig(route.children, fullPath);
@@ -2719,7 +2718,7 @@ function sortByMatchingOutlets(routes, outletName) {
2719
2718
  const noMatch$1 = {
2720
2719
  matched: false,
2721
2720
  consumedSegments: [],
2722
- lastChild: 0,
2721
+ remainingSegments: [],
2723
2722
  parameters: {},
2724
2723
  positionalParamSegments: {}
2725
2724
  };
@@ -2732,7 +2731,7 @@ function match(segmentGroup, route, segments) {
2732
2731
  return {
2733
2732
  matched: true,
2734
2733
  consumedSegments: [],
2735
- lastChild: 0,
2734
+ remainingSegments: segments,
2736
2735
  parameters: {},
2737
2736
  positionalParamSegments: {}
2738
2737
  };
@@ -2750,7 +2749,7 @@ function match(segmentGroup, route, segments) {
2750
2749
  return {
2751
2750
  matched: true,
2752
2751
  consumedSegments: res.consumed,
2753
- lastChild: res.consumed.length,
2752
+ remainingSegments: segments.slice(res.consumed.length),
2754
2753
  // TODO(atscott): investigate combining parameters and positionalParamSegments
2755
2754
  parameters,
2756
2755
  positionalParamSegments: (_a = res.posParams) !== null && _a !== void 0 ? _a : {}
@@ -2868,16 +2867,16 @@ class AbsoluteRedirect {
2868
2867
  }
2869
2868
  }
2870
2869
  function noMatch(segmentGroup) {
2871
- return new Observable((obs) => obs.error(new NoMatch$1(segmentGroup)));
2870
+ return throwError(new NoMatch$1(segmentGroup));
2872
2871
  }
2873
2872
  function absoluteRedirect(newTree) {
2874
- return new Observable((obs) => obs.error(new AbsoluteRedirect(newTree)));
2873
+ return throwError(new AbsoluteRedirect(newTree));
2875
2874
  }
2876
2875
  function namedOutletsRedirect(redirectTo) {
2877
- return new Observable((obs) => obs.error(new Error(`Only absolute redirects can have named outlets. redirectTo: '${redirectTo}'`)));
2876
+ return throwError(new Error(`Only absolute redirects can have named outlets. redirectTo: '${redirectTo}'`));
2878
2877
  }
2879
2878
  function canLoadFails(route) {
2880
- return new Observable((obs) => obs.error(navigationCancelingError(`Cannot load children because the guard of the route "path: '${route.path}'" returned false`)));
2879
+ return throwError(navigationCancelingError(`Cannot load children because the guard of the route "path: '${route.path}'" returned false`));
2881
2880
  }
2882
2881
  /**
2883
2882
  * Returns the `UrlTree` with the redirection applied.
@@ -2992,7 +2991,7 @@ class ApplyRedirects {
2992
2991
  if (noLeftoversInUrl(segmentGroup, segments, outlet)) {
2993
2992
  return of(new UrlSegmentGroup([], {}));
2994
2993
  }
2995
- throw new NoMatch$1(segmentGroup);
2994
+ return noMatch(segmentGroup);
2996
2995
  }
2997
2996
  throw e;
2998
2997
  }));
@@ -3026,7 +3025,7 @@ class ApplyRedirects {
3026
3025
  }));
3027
3026
  }
3028
3027
  expandRegularSegmentAgainstRouteUsingRedirect(ngModule, segmentGroup, routes, route, segments, outlet) {
3029
- const { matched, consumedSegments, lastChild, positionalParamSegments } = match(segmentGroup, route, segments);
3028
+ const { matched, consumedSegments, remainingSegments, positionalParamSegments } = match(segmentGroup, route, segments);
3030
3029
  if (!matched)
3031
3030
  return noMatch(segmentGroup);
3032
3031
  const newTree = this.applyRedirectCommands(consumedSegments, route.redirectTo, positionalParamSegments);
@@ -3034,7 +3033,7 @@ class ApplyRedirects {
3034
3033
  return absoluteRedirect(newTree);
3035
3034
  }
3036
3035
  return this.lineralizeSegments(route, newTree).pipe(mergeMap((newSegments) => {
3037
- return this.expandSegment(ngModule, segmentGroup, routes, newSegments.concat(segments.slice(lastChild)), outlet, false);
3036
+ return this.expandSegment(ngModule, segmentGroup, routes, newSegments.concat(remainingSegments), outlet, false);
3038
3037
  }));
3039
3038
  }
3040
3039
  matchSegmentAgainstRoute(ngModule, rawSegmentGroup, route, segments, outlet) {
@@ -3049,15 +3048,14 @@ class ApplyRedirects {
3049
3048
  }
3050
3049
  return of(new UrlSegmentGroup(segments, {}));
3051
3050
  }
3052
- const { matched, consumedSegments, lastChild } = match(rawSegmentGroup, route, segments);
3051
+ const { matched, consumedSegments, remainingSegments } = match(rawSegmentGroup, route, segments);
3053
3052
  if (!matched)
3054
3053
  return noMatch(rawSegmentGroup);
3055
- const rawSlicedSegments = segments.slice(lastChild);
3056
3054
  const childConfig$ = this.getChildConfig(ngModule, route, segments);
3057
3055
  return childConfig$.pipe(mergeMap((routerConfig) => {
3058
3056
  const childModule = routerConfig.module;
3059
3057
  const childConfig = routerConfig.routes;
3060
- const { segmentGroup: splitSegmentGroup, slicedSegments } = split(rawSegmentGroup, consumedSegments, rawSlicedSegments, childConfig);
3058
+ const { segmentGroup: splitSegmentGroup, slicedSegments } = split(rawSegmentGroup, consumedSegments, remainingSegments, childConfig);
3061
3059
  // See comment on the other call to `split` about why this is necessary.
3062
3060
  const segmentGroup = new UrlSegmentGroup(splitSegmentGroup.segments, splitSegmentGroup.children);
3063
3061
  if (slicedSegments.length === 0 && segmentGroup.hasChildren()) {
@@ -3634,7 +3632,7 @@ class Recognizer {
3634
3632
  return null;
3635
3633
  let snapshot;
3636
3634
  let consumedSegments = [];
3637
- let rawSlicedSegments = [];
3635
+ let remainingSegments = [];
3638
3636
  if (route.path === '**') {
3639
3637
  const params = segments.length > 0 ? last(segments).parameters : {};
3640
3638
  snapshot = new ActivatedRouteSnapshot(segments, params, Object.freeze(Object.assign({}, this.urlTree.queryParams)), this.urlTree.fragment, getData(route), getOutlet(route), route.component, route, getSourceSegmentGroup(rawSegment), getPathIndexShift(rawSegment) + segments.length, getResolve(route));
@@ -3645,11 +3643,11 @@ class Recognizer {
3645
3643
  return null;
3646
3644
  }
3647
3645
  consumedSegments = result.consumedSegments;
3648
- rawSlicedSegments = segments.slice(result.lastChild);
3646
+ remainingSegments = result.remainingSegments;
3649
3647
  snapshot = new ActivatedRouteSnapshot(consumedSegments, result.parameters, Object.freeze(Object.assign({}, this.urlTree.queryParams)), this.urlTree.fragment, getData(route), getOutlet(route), route.component, route, getSourceSegmentGroup(rawSegment), getPathIndexShift(rawSegment) + consumedSegments.length, getResolve(route));
3650
3648
  }
3651
3649
  const childConfig = getChildConfig(route);
3652
- const { segmentGroup, slicedSegments } = split(rawSegment, consumedSegments, rawSlicedSegments,
3650
+ const { segmentGroup, slicedSegments } = split(rawSegment, consumedSegments, remainingSegments,
3653
3651
  // Filter out routes with redirectTo because we are trying to create activated route
3654
3652
  // snapshots and don't handle redirects here. That should have been done in
3655
3653
  // `applyRedirects`.
@@ -3809,19 +3807,16 @@ function resolveData(paramsInheritanceStrategy, moduleInjector) {
3809
3807
  function runResolve(futureARS, futureRSS, paramsInheritanceStrategy, moduleInjector) {
3810
3808
  const config = futureARS.routeConfig;
3811
3809
  const resolve = futureARS._resolve;
3812
- const data = Object.assign({}, futureARS.data);
3813
- if ((config === null || config === void 0 ? void 0 : config.title) !== undefined) {
3814
- if (typeof config.title === 'string' || config.title === null) {
3815
- data[RouteTitle] = config.title;
3816
- }
3817
- else {
3818
- resolve[RouteTitle] = config.title;
3819
- }
3810
+ if ((config === null || config === void 0 ? void 0 : config.title) !== undefined && !hasStaticTitle(config)) {
3811
+ resolve[RouteTitle] = config.title;
3820
3812
  }
3821
3813
  return resolveNode(resolve, futureARS, futureRSS, moduleInjector)
3822
3814
  .pipe(map((resolvedData) => {
3823
3815
  futureARS._resolvedData = resolvedData;
3824
- futureARS.data = Object.assign(Object.assign({}, data), inheritedParamsDataResolve(futureARS, paramsInheritanceStrategy).resolve);
3816
+ futureARS.data = inheritedParamsDataResolve(futureARS, paramsInheritanceStrategy).resolve;
3817
+ if (config && hasStaticTitle(config)) {
3818
+ futureARS.data[RouteTitle] = config.title;
3819
+ }
3825
3820
  return null;
3826
3821
  }));
3827
3822
  }
@@ -3832,7 +3827,7 @@ function resolveNode(resolve, futureARS, futureRSS, moduleInjector) {
3832
3827
  }
3833
3828
  const data = {};
3834
3829
  return from(keys).pipe(mergeMap(key => getResolver(resolve[key], futureARS, futureRSS, moduleInjector)
3835
- .pipe(tap((value) => {
3830
+ .pipe(take(1), tap((value) => {
3836
3831
  data[key] = value;
3837
3832
  }))), takeLast(1), mergeMap(() => {
3838
3833
  // Ensure all resolvers returned values, otherwise don't emit any "next" and just complete
@@ -3851,6 +3846,9 @@ function getResolver(injectionToken, futureARS, futureRSS, moduleInjector) {
3851
3846
  return resolver.resolve ? wrapIntoObservable(resolver.resolve(futureARS, futureRSS)) :
3852
3847
  wrapIntoObservable(resolver(futureARS, futureRSS));
3853
3848
  }
3849
+ function hasStaticTitle(config) {
3850
+ return typeof config.title === 'string' || config.title === null;
3851
+ }
3854
3852
 
3855
3853
  /**
3856
3854
  * @license
@@ -4178,6 +4176,8 @@ class Router {
4178
4176
  /**
4179
4177
  * Enables a bug fix that corrects relative link resolution in components with empty paths.
4180
4178
  * @see `RouterModule`
4179
+ *
4180
+ * @deprecated
4181
4181
  */
4182
4182
  this.relativeLinkResolution = 'corrected';
4183
4183
  /**
@@ -4262,7 +4262,7 @@ class Router {
4262
4262
  tap(t => {
4263
4263
  this.currentNavigation = {
4264
4264
  id: t.id,
4265
- initialUrl: t.currentRawUrl,
4265
+ initialUrl: t.rawUrl,
4266
4266
  extractedUrl: t.extractedUrl,
4267
4267
  trigger: t.source,
4268
4268
  extras: t.extras,
@@ -4829,24 +4829,10 @@ class Router {
4829
4829
  });
4830
4830
  }
4831
4831
  scheduleNavigation(rawUrl, source, restoredState, extras, priorPromise) {
4832
- var _a, _b, _c;
4832
+ var _a, _b;
4833
4833
  if (this.disposed) {
4834
4834
  return Promise.resolve(false);
4835
4835
  }
4836
- // Duplicate navigations may be triggered by attempts to sync AngularJS and
4837
- // Angular router states. We have the setTimeout in the location listener to
4838
- // ensure the imperative nav is scheduled before the browser nav.
4839
- const lastNavigation = this.transitions.value;
4840
- const browserNavPrecededByRouterNav = isBrowserTriggeredNavigation(source) && lastNavigation &&
4841
- !isBrowserTriggeredNavigation(lastNavigation.source);
4842
- const navToSameUrl = lastNavigation.rawUrl.toString() === rawUrl.toString();
4843
- const lastNavigationInProgress = lastNavigation.id === ((_a = this.currentNavigation) === null || _a === void 0 ? void 0 : _a.id);
4844
- // We consider duplicates as ones that goes to the same URL while the first
4845
- // is still processing.
4846
- const isDuplicateNav = navToSameUrl && lastNavigationInProgress;
4847
- if (browserNavPrecededByRouterNav && isDuplicateNav) {
4848
- return Promise.resolve(true); // return value is not used
4849
- }
4850
4836
  let resolve;
4851
4837
  let reject;
4852
4838
  let promise;
@@ -4878,10 +4864,10 @@ class Router {
4878
4864
  // If we're replacing the URL or doing a silent navigation, we do not want to increment the
4879
4865
  // page id because we aren't pushing a new entry to history.
4880
4866
  if (extras.replaceUrl || extras.skipLocationChange) {
4881
- targetPageId = (_b = this.browserPageId) !== null && _b !== void 0 ? _b : 0;
4867
+ targetPageId = (_a = this.browserPageId) !== null && _a !== void 0 ? _a : 0;
4882
4868
  }
4883
4869
  else {
4884
- targetPageId = ((_c = this.browserPageId) !== null && _c !== void 0 ? _c : 0) + 1;
4870
+ targetPageId = ((_b = this.browserPageId) !== null && _b !== void 0 ? _b : 0) + 1;
4885
4871
  }
4886
4872
  }
4887
4873
  }
@@ -4989,9 +4975,9 @@ class Router {
4989
4975
  return { navigationId };
4990
4976
  }
4991
4977
  }
4992
- Router.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: Router, deps: "invalid", target: i0.ɵɵFactoryTarget.Injectable });
4993
- Router.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: Router });
4994
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: Router, decorators: [{
4978
+ Router.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: Router, deps: "invalid", target: i0.ɵɵFactoryTarget.Injectable });
4979
+ Router.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: Router });
4980
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: Router, decorators: [{
4995
4981
  type: Injectable
4996
4982
  }], ctorParameters: function () { return [{ type: i0.Type }, { type: UrlSerializer }, { type: ChildrenOutletContexts }, { type: i3.Location }, { type: i0.Injector }, { type: i0.Compiler }, { type: undefined }]; } });
4997
4983
  function validateCommands(commands) {
@@ -5023,7 +5009,7 @@ function isBrowserTriggeredNavigation(source) {
5023
5009
  * For example, `['/team', teamId, 'user', userName, {details: true}]`
5024
5010
  * generates a link to `/team/11/user/bob;details=true`.
5025
5011
  *
5026
- * Multiple static segments can be merged into one term and combined with dynamic segements.
5012
+ * Multiple static segments can be merged into one term and combined with dynamic segments.
5027
5013
  * For example, `['/team/11/user', userName, {details: true}]`
5028
5014
  *
5029
5015
  * The input that you provide to the link is treated as a delta to the current URL.
@@ -5161,8 +5147,8 @@ class RouterLink {
5161
5147
  return true;
5162
5148
  }
5163
5149
  const extras = {
5164
- skipLocationChange: attrBoolValue(this.skipLocationChange),
5165
- replaceUrl: attrBoolValue(this.replaceUrl),
5150
+ skipLocationChange: ɵcoerceToBoolean(this.skipLocationChange),
5151
+ replaceUrl: ɵcoerceToBoolean(this.replaceUrl),
5166
5152
  state: this.state,
5167
5153
  };
5168
5154
  this.router.navigateByUrl(this.urlTree, extras);
@@ -5179,13 +5165,13 @@ class RouterLink {
5179
5165
  queryParams: this.queryParams,
5180
5166
  fragment: this.fragment,
5181
5167
  queryParamsHandling: this.queryParamsHandling,
5182
- preserveFragment: attrBoolValue(this.preserveFragment),
5168
+ preserveFragment: ɵcoerceToBoolean(this.preserveFragment),
5183
5169
  });
5184
5170
  }
5185
5171
  }
5186
- RouterLink.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterLink, deps: [{ token: Router }, { token: ActivatedRoute }, { token: 'tabindex', attribute: true }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
5187
- RouterLink.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.1", type: RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: { queryParams: "queryParams", fragment: "fragment", queryParamsHandling: "queryParamsHandling", preserveFragment: "preserveFragment", skipLocationChange: "skipLocationChange", replaceUrl: "replaceUrl", state: "state", relativeTo: "relativeTo", routerLink: "routerLink" }, host: { listeners: { "click": "onClick()" } }, usesOnChanges: true, ngImport: i0 });
5188
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterLink, decorators: [{
5172
+ RouterLink.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterLink, deps: [{ token: Router }, { token: ActivatedRoute }, { token: 'tabindex', attribute: true }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
5173
+ RouterLink.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.12", type: RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: { queryParams: "queryParams", fragment: "fragment", queryParamsHandling: "queryParamsHandling", preserveFragment: "preserveFragment", skipLocationChange: "skipLocationChange", replaceUrl: "replaceUrl", state: "state", relativeTo: "relativeTo", routerLink: "routerLink" }, host: { listeners: { "click": "onClick()" } }, usesOnChanges: true, ngImport: i0 });
5174
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterLink, decorators: [{
5189
5175
  type: Directive,
5190
5176
  args: [{ selector: ':not(a):not(area)[routerLink]' }]
5191
5177
  }], ctorParameters: function () {
@@ -5277,8 +5263,8 @@ class RouterLinkWithHref {
5277
5263
  return true;
5278
5264
  }
5279
5265
  const extras = {
5280
- skipLocationChange: attrBoolValue(this.skipLocationChange),
5281
- replaceUrl: attrBoolValue(this.replaceUrl),
5266
+ skipLocationChange: ɵcoerceToBoolean(this.skipLocationChange),
5267
+ replaceUrl: ɵcoerceToBoolean(this.replaceUrl),
5282
5268
  state: this.state
5283
5269
  };
5284
5270
  this.router.navigateByUrl(this.urlTree, extras);
@@ -5300,13 +5286,13 @@ class RouterLinkWithHref {
5300
5286
  queryParams: this.queryParams,
5301
5287
  fragment: this.fragment,
5302
5288
  queryParamsHandling: this.queryParamsHandling,
5303
- preserveFragment: attrBoolValue(this.preserveFragment),
5289
+ preserveFragment: ɵcoerceToBoolean(this.preserveFragment),
5304
5290
  });
5305
5291
  }
5306
5292
  }
5307
- RouterLinkWithHref.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterLinkWithHref, deps: [{ token: Router }, { token: ActivatedRoute }, { token: i3.LocationStrategy }], target: i0.ɵɵFactoryTarget.Directive });
5308
- RouterLinkWithHref.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.1", type: RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: { target: "target", queryParams: "queryParams", fragment: "fragment", queryParamsHandling: "queryParamsHandling", preserveFragment: "preserveFragment", skipLocationChange: "skipLocationChange", replaceUrl: "replaceUrl", state: "state", relativeTo: "relativeTo", routerLink: "routerLink" }, host: { listeners: { "click": "onClick($event.button,$event.ctrlKey,$event.shiftKey,$event.altKey,$event.metaKey)" }, properties: { "attr.target": "this.target", "attr.href": "this.href" } }, usesOnChanges: true, ngImport: i0 });
5309
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterLinkWithHref, decorators: [{
5293
+ RouterLinkWithHref.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterLinkWithHref, deps: [{ token: Router }, { token: ActivatedRoute }, { token: i3.LocationStrategy }], target: i0.ɵɵFactoryTarget.Directive });
5294
+ RouterLinkWithHref.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.12", type: RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: { target: "target", queryParams: "queryParams", fragment: "fragment", queryParamsHandling: "queryParamsHandling", preserveFragment: "preserveFragment", skipLocationChange: "skipLocationChange", replaceUrl: "replaceUrl", state: "state", relativeTo: "relativeTo", routerLink: "routerLink" }, host: { listeners: { "click": "onClick($event.button,$event.ctrlKey,$event.shiftKey,$event.altKey,$event.metaKey)" }, properties: { "attr.target": "this.target", "attr.href": "this.href" } }, usesOnChanges: true, ngImport: i0 });
5295
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterLinkWithHref, decorators: [{
5310
5296
  type: Directive,
5311
5297
  args: [{ selector: 'a[routerLink],area[routerLink]' }]
5312
5298
  }], ctorParameters: function () { return [{ type: Router }, { type: ActivatedRoute }, { type: i3.LocationStrategy }]; }, propDecorators: { target: [{
@@ -5340,9 +5326,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1",
5340
5326
  args: ['click',
5341
5327
  ['$event.button', '$event.ctrlKey', '$event.shiftKey', '$event.altKey', '$event.metaKey']]
5342
5328
  }] } });
5343
- function attrBoolValue(s) {
5344
- return s === '' || !!s;
5345
- }
5346
5329
 
5347
5330
  /**
5348
5331
  * @license
@@ -5520,9 +5503,9 @@ class RouterLinkActive {
5520
5503
  this.links.some(isActiveCheckFn) || this.linksWithHrefs.some(isActiveCheckFn);
5521
5504
  }
5522
5505
  }
5523
- RouterLinkActive.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterLinkActive, deps: [{ token: Router }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: RouterLink, optional: true }, { token: RouterLinkWithHref, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
5524
- RouterLinkActive.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.1", type: RouterLinkActive, selector: "[routerLinkActive]", inputs: { routerLinkActiveOptions: "routerLinkActiveOptions", routerLinkActive: "routerLinkActive" }, outputs: { isActiveChange: "isActiveChange" }, queries: [{ propertyName: "links", predicate: RouterLink, descendants: true }, { propertyName: "linksWithHrefs", predicate: RouterLinkWithHref, descendants: true }], exportAs: ["routerLinkActive"], usesOnChanges: true, ngImport: i0 });
5525
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterLinkActive, decorators: [{
5506
+ RouterLinkActive.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterLinkActive, deps: [{ token: Router }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: RouterLink, optional: true }, { token: RouterLinkWithHref, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
5507
+ RouterLinkActive.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "14.0.0-next.12", type: RouterLinkActive, selector: "[routerLinkActive]", inputs: { routerLinkActiveOptions: "routerLinkActiveOptions", routerLinkActive: "routerLinkActive" }, outputs: { isActiveChange: "isActiveChange" }, queries: [{ propertyName: "links", predicate: RouterLink, descendants: true }, { propertyName: "linksWithHrefs", predicate: RouterLinkWithHref, descendants: true }], exportAs: ["routerLinkActive"], usesOnChanges: true, ngImport: i0 });
5508
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterLinkActive, decorators: [{
5526
5509
  type: Directive,
5527
5510
  args: [{
5528
5511
  selector: '[routerLinkActive]',
@@ -5626,9 +5609,9 @@ class DefaultTitleStrategy extends TitleStrategy {
5626
5609
  }
5627
5610
  }
5628
5611
  }
5629
- DefaultTitleStrategy.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: DefaultTitleStrategy, deps: [{ token: i1.Title }], target: i0.ɵɵFactoryTarget.Injectable });
5630
- DefaultTitleStrategy.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: DefaultTitleStrategy, providedIn: 'root' });
5631
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: DefaultTitleStrategy, decorators: [{
5612
+ DefaultTitleStrategy.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: DefaultTitleStrategy, deps: [{ token: i1.Title }], target: i0.ɵɵFactoryTarget.Injectable });
5613
+ DefaultTitleStrategy.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: DefaultTitleStrategy, providedIn: 'root' });
5614
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: DefaultTitleStrategy, decorators: [{
5632
5615
  type: Injectable,
5633
5616
  args: [{ providedIn: 'root' }]
5634
5617
  }], ctorParameters: function () { return [{ type: i1.Title }]; } });
@@ -5746,9 +5729,9 @@ class RouterPreloader {
5746
5729
  });
5747
5730
  }
5748
5731
  }
5749
- RouterPreloader.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterPreloader, deps: [{ token: Router }, { token: i0.Compiler }, { token: i0.Injector }, { token: PreloadingStrategy }], target: i0.ɵɵFactoryTarget.Injectable });
5750
- RouterPreloader.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterPreloader });
5751
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterPreloader, decorators: [{
5732
+ RouterPreloader.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterPreloader, deps: [{ token: Router }, { token: i0.Compiler }, { token: i0.Injector }, { token: PreloadingStrategy }], target: i0.ɵɵFactoryTarget.Injectable });
5733
+ RouterPreloader.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterPreloader });
5734
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterPreloader, decorators: [{
5752
5735
  type: Injectable
5753
5736
  }], ctorParameters: function () { return [{ type: Router }, { type: i0.Compiler }, { type: i0.Injector }, { type: PreloadingStrategy }]; } });
5754
5737
 
@@ -5827,9 +5810,9 @@ class RouterScroller {
5827
5810
  }
5828
5811
  }
5829
5812
  }
5830
- RouterScroller.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterScroller, deps: "invalid", target: i0.ɵɵFactoryTarget.Injectable });
5831
- RouterScroller.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterScroller });
5832
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterScroller, decorators: [{
5813
+ RouterScroller.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterScroller, deps: "invalid", target: i0.ɵɵFactoryTarget.Injectable });
5814
+ RouterScroller.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterScroller });
5815
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterScroller, decorators: [{
5833
5816
  type: Injectable
5834
5817
  }], ctorParameters: function () { return [{ type: Router }, { type: i3.ViewportScroller }, { type: undefined }]; } });
5835
5818
 
@@ -5970,10 +5953,10 @@ class RouterModule {
5970
5953
  return { ngModule: RouterModule, providers: [provideRoutes(routes)] };
5971
5954
  }
5972
5955
  }
5973
- RouterModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterModule, deps: [{ token: ROUTER_FORROOT_GUARD, optional: true }, { token: Router, optional: true }], target: i0.ɵɵFactoryTarget.NgModule });
5974
- RouterModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterModule, declarations: [RouterOutlet, RouterLink, RouterLinkWithHref, RouterLinkActive, ɵEmptyOutletComponent], exports: [RouterOutlet, RouterLink, RouterLinkWithHref, RouterLinkActive, ɵEmptyOutletComponent] });
5975
- RouterModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterModule });
5976
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterModule, decorators: [{
5956
+ RouterModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterModule, deps: [{ token: ROUTER_FORROOT_GUARD, optional: true }, { token: Router, optional: true }], target: i0.ɵɵFactoryTarget.NgModule });
5957
+ RouterModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterModule, declarations: [RouterOutlet, RouterLink, RouterLinkWithHref, RouterLinkActive, ɵEmptyOutletComponent], exports: [RouterOutlet, RouterLink, RouterLinkWithHref, RouterLinkActive, ɵEmptyOutletComponent] });
5958
+ RouterModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterModule });
5959
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterModule, decorators: [{
5977
5960
  type: NgModule,
5978
5961
  args: [{
5979
5962
  declarations: ROUTER_DIRECTIVES,
@@ -6155,9 +6138,9 @@ class RouterInitializer {
6155
6138
  this.destroyed = true;
6156
6139
  }
6157
6140
  }
6158
- RouterInitializer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterInitializer, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
6159
- RouterInitializer.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterInitializer });
6160
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.1", ngImport: i0, type: RouterInitializer, decorators: [{
6141
+ RouterInitializer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterInitializer, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
6142
+ RouterInitializer.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterInitializer });
6143
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-next.12", ngImport: i0, type: RouterInitializer, decorators: [{
6161
6144
  type: Injectable
6162
6145
  }], ctorParameters: function () { return [{ type: i0.Injector }]; } });
6163
6146
  function getAppInitializer(r) {
@@ -6197,7 +6180,7 @@ function provideRouterInitializer() {
6197
6180
  /**
6198
6181
  * @publicApi
6199
6182
  */
6200
- const VERSION = new Version('14.0.0-next.1');
6183
+ const VERSION = new Version('14.0.0-next.12');
6201
6184
 
6202
6185
  /**
6203
6186
  * @license