@angular/router 13.0.0-next.9 → 13.0.0-rc.3
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/{esm2015/index.js → esm2020/index.mjs} +0 -0
- package/{esm2015/public_api.js → esm2020/public_api.mjs} +0 -0
- package/esm2020/router.mjs +5 -0
- package/{esm2015/src/apply_redirects.js → esm2020/src/apply_redirects.mjs} +0 -0
- package/esm2020/src/components/empty_outlet.mjs +29 -0
- package/{esm2015/src/config.js → esm2020/src/config.mjs} +0 -0
- package/esm2020/src/create_router_state.mjs +52 -0
- package/{esm2015/src/create_url_tree.js → esm2020/src/create_url_tree.mjs} +0 -0
- package/esm2020/src/directives/router_link.mjs +353 -0
- package/esm2020/src/directives/router_link_active.mjs +215 -0
- package/esm2020/src/directives/router_outlet.mjs +219 -0
- package/{esm2015/src/events.js → esm2020/src/events.mjs} +0 -0
- package/{esm2015/src/index.js → esm2020/src/index.mjs} +0 -0
- package/{esm2015/src/interfaces.js → esm2020/src/interfaces.mjs} +0 -0
- package/{esm2015/src/operators/activate_routes.js → esm2020/src/operators/activate_routes.mjs} +8 -6
- package/esm2020/src/operators/apply_redirects.mjs +14 -0
- package/esm2020/src/operators/check_guards.mjs +138 -0
- package/{esm2015/src/operators/prioritized_guard_value.js → esm2020/src/operators/prioritized_guard_value.mjs} +0 -0
- package/esm2020/src/operators/recognize.mjs +14 -0
- package/esm2020/src/operators/resolve_data.mjs +59 -0
- package/{esm2015/src/operators/switch_tap.js → esm2020/src/operators/switch_tap.mjs} +0 -0
- package/{esm2015/src/private_export.js → esm2020/src/private_export.mjs} +0 -0
- package/esm2020/src/recognize.mjs +262 -0
- package/{esm2015/src/route_reuse_strategy.js → esm2020/src/route_reuse_strategy.mjs} +0 -0
- package/esm2020/src/router.mjs +1009 -0
- package/{esm2015/src/router_config_loader.js → esm2020/src/router_config_loader.mjs} +0 -0
- package/esm2020/src/router_module.mjs +370 -0
- package/esm2020/src/router_outlet_context.mjs +74 -0
- package/esm2020/src/router_preloader.mjs +127 -0
- package/esm2020/src/router_scroller.mjs +95 -0
- package/esm2020/src/router_state.mjs +404 -0
- package/{esm2015/src/shared.js → esm2020/src/shared.mjs} +0 -0
- package/{esm2015/src/url_handling_strategy.js → esm2020/src/url_handling_strategy.mjs} +0 -0
- package/{esm2015/src/url_tree.js → esm2020/src/url_tree.mjs} +0 -0
- package/{esm2015/src/utils/collection.js → esm2020/src/utils/collection.mjs} +0 -0
- package/{esm2015/src/utils/config.js → esm2020/src/utils/config.mjs} +2 -2
- package/esm2020/src/utils/config_matching.mjs +145 -0
- package/{esm2015/src/utils/preactivation.js → esm2020/src/utils/preactivation.mjs} +0 -0
- package/{esm2015/src/utils/tree.js → esm2020/src/utils/tree.mjs} +0 -0
- package/{esm2015/src/utils/type_guards.js → esm2020/src/utils/type_guards.mjs} +0 -0
- package/{esm2015/src/version.js → esm2020/src/version.mjs} +1 -1
- package/{esm2015/testing/index.js → esm2020/testing/index.mjs} +0 -0
- package/{esm2015/testing/public_api.js → esm2020/testing/public_api.mjs} +0 -0
- package/esm2020/testing/src/extra_router_testing_providers.mjs +10 -0
- package/esm2020/testing/src/router_testing_module.mjs +122 -0
- package/esm2020/testing/src/spy_ng_module_factory_loader.mjs +10 -0
- package/esm2020/testing/src/testing.mjs +15 -0
- package/{esm2015/testing/testing.js → esm2020/testing/testing.mjs} +0 -0
- package/{esm2015/upgrade/index.js → esm2020/upgrade/index.mjs} +0 -0
- package/{esm2015/upgrade/public_api.js → esm2020/upgrade/public_api.mjs} +0 -0
- package/esm2020/upgrade/src/upgrade.mjs +120 -0
- package/{esm2015/upgrade/upgrade.js → esm2020/upgrade/upgrade.mjs} +0 -0
- package/fesm2015/{router.js → router.mjs} +507 -505
- package/fesm2015/router.mjs.map +1 -0
- package/fesm2015/{testing.js → testing.mjs} +66 -21
- package/fesm2015/testing.mjs.map +1 -0
- package/fesm2015/{upgrade.js → upgrade.mjs} +4 -5
- package/fesm2015/upgrade.mjs.map +1 -0
- package/fesm2020/router.mjs +6157 -0
- package/fesm2020/router.mjs.map +1 -0
- package/fesm2020/testing.mjs +179 -0
- package/fesm2020/testing.mjs.map +1 -0
- package/fesm2020/upgrade.mjs +150 -0
- package/fesm2020/upgrade.mjs.map +1 -0
- package/package.json +41 -11
- package/router.d.ts +84 -93
- package/testing/package.json +5 -5
- package/testing/testing.d.ts +6 -1
- package/upgrade/package.json +5 -5
- package/upgrade/upgrade.d.ts +1 -1
- package/bundles/router-testing.umd.js +0 -143
- package/bundles/router-testing.umd.js.map +0 -1
- package/bundles/router-upgrade.umd.js +0 -157
- package/bundles/router-upgrade.umd.js.map +0 -1
- package/bundles/router.umd.js +0 -6878
- package/bundles/router.umd.js.map +0 -1
- package/esm2015/router.externs.js +0 -6
- package/esm2015/router.js +0 -9
- package/esm2015/src/components/empty_outlet.js +0 -24
- package/esm2015/src/create_router_state.js +0 -63
- package/esm2015/src/directives/router_link.js +0 -328
- package/esm2015/src/directives/router_link_active.js +0 -210
- package/esm2015/src/directives/router_outlet.js +0 -212
- package/esm2015/src/operators/apply_redirects.js +0 -14
- package/esm2015/src/operators/check_guards.js +0 -138
- package/esm2015/src/operators/recognize.js +0 -14
- package/esm2015/src/operators/resolve_data.js +0 -56
- package/esm2015/src/recognize.js +0 -262
- package/esm2015/src/router.js +0 -1011
- package/esm2015/src/router_module.js +0 -362
- package/esm2015/src/router_outlet_context.js +0 -73
- package/esm2015/src/router_preloader.js +0 -129
- package/esm2015/src/router_scroller.js +0 -95
- package/esm2015/src/router_state.js +0 -404
- package/esm2015/src/utils/config_matching.js +0 -145
- package/esm2015/testing/src/router_testing_module.js +0 -96
- package/esm2015/testing/src/testing.js +0 -14
- package/esm2015/testing/testing.externs.js +0 -6
- package/esm2015/upgrade/src/upgrade.js +0 -122
- package/esm2015/upgrade/upgrade.externs.js +0 -6
- package/fesm2015/router.js.map +0 -1
- package/fesm2015/testing.js.map +0 -1
- package/fesm2015/upgrade.js.map +0 -1
- package/router.metadata.json +0 -1
- package/testing/testing.metadata.json +0 -1
- package/testing.d.ts +0 -7
- package/testing.metadata.json +0 -1
- package/upgrade/upgrade.metadata.json +0 -1
- package/upgrade.d.ts +0 -7
- package/upgrade.metadata.json +0 -1
|
@@ -1,210 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { ChangeDetectorRef, ContentChildren, Directive, ElementRef, EventEmitter, Input, Optional, Output, QueryList, Renderer2 } from '@angular/core';
|
|
9
|
-
import { from, of } from 'rxjs';
|
|
10
|
-
import { mergeAll } from 'rxjs/operators';
|
|
11
|
-
import { NavigationEnd } from '../events';
|
|
12
|
-
import { Router } from '../router';
|
|
13
|
-
import { RouterLink, RouterLinkWithHref } from './router_link';
|
|
14
|
-
/**
|
|
15
|
-
*
|
|
16
|
-
* @description
|
|
17
|
-
*
|
|
18
|
-
* Tracks whether the linked route of an element is currently active, and allows you
|
|
19
|
-
* to specify one or more CSS classes to add to the element when the linked route
|
|
20
|
-
* is active.
|
|
21
|
-
*
|
|
22
|
-
* Use this directive to create a visual distinction for elements associated with an active route.
|
|
23
|
-
* For example, the following code highlights the word "Bob" when the router
|
|
24
|
-
* activates the associated route:
|
|
25
|
-
*
|
|
26
|
-
* ```
|
|
27
|
-
* <a routerLink="/user/bob" routerLinkActive="active-link">Bob</a>
|
|
28
|
-
* ```
|
|
29
|
-
*
|
|
30
|
-
* Whenever the URL is either '/user' or '/user/bob', the "active-link" class is
|
|
31
|
-
* added to the anchor tag. If the URL changes, the class is removed.
|
|
32
|
-
*
|
|
33
|
-
* You can set more than one class using a space-separated string or an array.
|
|
34
|
-
* For example:
|
|
35
|
-
*
|
|
36
|
-
* ```
|
|
37
|
-
* <a routerLink="/user/bob" routerLinkActive="class1 class2">Bob</a>
|
|
38
|
-
* <a routerLink="/user/bob" [routerLinkActive]="['class1', 'class2']">Bob</a>
|
|
39
|
-
* ```
|
|
40
|
-
*
|
|
41
|
-
* To add the classes only when the URL matches the link exactly, add the option `exact: true`:
|
|
42
|
-
*
|
|
43
|
-
* ```
|
|
44
|
-
* <a routerLink="/user/bob" routerLinkActive="active-link" [routerLinkActiveOptions]="{exact:
|
|
45
|
-
* true}">Bob</a>
|
|
46
|
-
* ```
|
|
47
|
-
*
|
|
48
|
-
* To directly check the `isActive` status of the link, assign the `RouterLinkActive`
|
|
49
|
-
* instance to a template variable.
|
|
50
|
-
* For example, the following checks the status without assigning any CSS classes:
|
|
51
|
-
*
|
|
52
|
-
* ```
|
|
53
|
-
* <a routerLink="/user/bob" routerLinkActive #rla="routerLinkActive">
|
|
54
|
-
* Bob {{ rla.isActive ? '(already open)' : ''}}
|
|
55
|
-
* </a>
|
|
56
|
-
* ```
|
|
57
|
-
*
|
|
58
|
-
* You can apply the `RouterLinkActive` directive to an ancestor of linked elements.
|
|
59
|
-
* For example, the following sets the active-link class on the `<div>` parent tag
|
|
60
|
-
* when the URL is either '/user/jim' or '/user/bob'.
|
|
61
|
-
*
|
|
62
|
-
* ```
|
|
63
|
-
* <div routerLinkActive="active-link" [routerLinkActiveOptions]="{exact: true}">
|
|
64
|
-
* <a routerLink="/user/jim">Jim</a>
|
|
65
|
-
* <a routerLink="/user/bob">Bob</a>
|
|
66
|
-
* </div>
|
|
67
|
-
* ```
|
|
68
|
-
*
|
|
69
|
-
* @ngModule RouterModule
|
|
70
|
-
*
|
|
71
|
-
* @publicApi
|
|
72
|
-
*/
|
|
73
|
-
export class RouterLinkActive {
|
|
74
|
-
constructor(router, element, renderer, cdr, link, linkWithHref) {
|
|
75
|
-
this.router = router;
|
|
76
|
-
this.element = element;
|
|
77
|
-
this.renderer = renderer;
|
|
78
|
-
this.cdr = cdr;
|
|
79
|
-
this.link = link;
|
|
80
|
-
this.linkWithHref = linkWithHref;
|
|
81
|
-
this.classes = [];
|
|
82
|
-
this.isActive = false;
|
|
83
|
-
/**
|
|
84
|
-
* Options to configure how to determine if the router link is active.
|
|
85
|
-
*
|
|
86
|
-
* These options are passed to the `Router.isActive()` function.
|
|
87
|
-
*
|
|
88
|
-
* @see Router.isActive
|
|
89
|
-
*/
|
|
90
|
-
this.routerLinkActiveOptions = { exact: false };
|
|
91
|
-
/**
|
|
92
|
-
*
|
|
93
|
-
* You can use the output `isActiveChange` to get notified each time the link becomes
|
|
94
|
-
* active or inactive.
|
|
95
|
-
*
|
|
96
|
-
* Emits:
|
|
97
|
-
* true -> Route is active
|
|
98
|
-
* false -> Route is inactive
|
|
99
|
-
*
|
|
100
|
-
* ```
|
|
101
|
-
* <a
|
|
102
|
-
* routerLink="/user/bob"
|
|
103
|
-
* routerLinkActive="active-link"
|
|
104
|
-
* (isActiveChange)="this.onRouterLinkActive($event)">Bob</a>
|
|
105
|
-
* ```
|
|
106
|
-
*/
|
|
107
|
-
this.isActiveChange = new EventEmitter();
|
|
108
|
-
this.routerEventsSubscription = router.events.subscribe((s) => {
|
|
109
|
-
if (s instanceof NavigationEnd) {
|
|
110
|
-
this.update();
|
|
111
|
-
}
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
/** @nodoc */
|
|
115
|
-
ngAfterContentInit() {
|
|
116
|
-
// `of(null)` is used to force subscribe body to execute once immediately (like `startWith`).
|
|
117
|
-
of(this.links.changes, this.linksWithHrefs.changes, of(null)).pipe(mergeAll()).subscribe(_ => {
|
|
118
|
-
this.update();
|
|
119
|
-
this.subscribeToEachLinkOnChanges();
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
subscribeToEachLinkOnChanges() {
|
|
123
|
-
var _a;
|
|
124
|
-
(_a = this.linkInputChangesSubscription) === null || _a === void 0 ? void 0 : _a.unsubscribe();
|
|
125
|
-
const allLinkChanges = [...this.links.toArray(), ...this.linksWithHrefs.toArray(), this.link, this.linkWithHref]
|
|
126
|
-
.filter((link) => !!link)
|
|
127
|
-
.map(link => link.onChanges);
|
|
128
|
-
this.linkInputChangesSubscription = from(allLinkChanges).pipe(mergeAll()).subscribe(link => {
|
|
129
|
-
if (this.isActive !== this.isLinkActive(this.router)(link)) {
|
|
130
|
-
this.update();
|
|
131
|
-
}
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
set routerLinkActive(data) {
|
|
135
|
-
const classes = Array.isArray(data) ? data : data.split(' ');
|
|
136
|
-
this.classes = classes.filter(c => !!c);
|
|
137
|
-
}
|
|
138
|
-
/** @nodoc */
|
|
139
|
-
ngOnChanges(changes) {
|
|
140
|
-
this.update();
|
|
141
|
-
}
|
|
142
|
-
/** @nodoc */
|
|
143
|
-
ngOnDestroy() {
|
|
144
|
-
var _a;
|
|
145
|
-
this.routerEventsSubscription.unsubscribe();
|
|
146
|
-
(_a = this.linkInputChangesSubscription) === null || _a === void 0 ? void 0 : _a.unsubscribe();
|
|
147
|
-
}
|
|
148
|
-
update() {
|
|
149
|
-
if (!this.links || !this.linksWithHrefs || !this.router.navigated)
|
|
150
|
-
return;
|
|
151
|
-
Promise.resolve().then(() => {
|
|
152
|
-
const hasActiveLinks = this.hasActiveLinks();
|
|
153
|
-
if (this.isActive !== hasActiveLinks) {
|
|
154
|
-
this.isActive = hasActiveLinks;
|
|
155
|
-
this.cdr.markForCheck();
|
|
156
|
-
this.classes.forEach((c) => {
|
|
157
|
-
if (hasActiveLinks) {
|
|
158
|
-
this.renderer.addClass(this.element.nativeElement, c);
|
|
159
|
-
}
|
|
160
|
-
else {
|
|
161
|
-
this.renderer.removeClass(this.element.nativeElement, c);
|
|
162
|
-
}
|
|
163
|
-
});
|
|
164
|
-
// Emit on isActiveChange after classes are updated
|
|
165
|
-
this.isActiveChange.emit(hasActiveLinks);
|
|
166
|
-
}
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
isLinkActive(router) {
|
|
170
|
-
const options = isActiveMatchOptions(this.routerLinkActiveOptions) ?
|
|
171
|
-
this.routerLinkActiveOptions :
|
|
172
|
-
// While the types should disallow `undefined` here, it's possible without strict inputs
|
|
173
|
-
(this.routerLinkActiveOptions.exact || false);
|
|
174
|
-
return (link) => link.urlTree ? router.isActive(link.urlTree, options) : false;
|
|
175
|
-
}
|
|
176
|
-
hasActiveLinks() {
|
|
177
|
-
const isActiveCheckFn = this.isLinkActive(this.router);
|
|
178
|
-
return this.link && isActiveCheckFn(this.link) ||
|
|
179
|
-
this.linkWithHref && isActiveCheckFn(this.linkWithHref) ||
|
|
180
|
-
this.links.some(isActiveCheckFn) || this.linksWithHrefs.some(isActiveCheckFn);
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
RouterLinkActive.decorators = [
|
|
184
|
-
{ type: Directive, args: [{
|
|
185
|
-
selector: '[routerLinkActive]',
|
|
186
|
-
exportAs: 'routerLinkActive',
|
|
187
|
-
},] }
|
|
188
|
-
];
|
|
189
|
-
RouterLinkActive.ctorParameters = () => [
|
|
190
|
-
{ type: Router },
|
|
191
|
-
{ type: ElementRef },
|
|
192
|
-
{ type: Renderer2 },
|
|
193
|
-
{ type: ChangeDetectorRef },
|
|
194
|
-
{ type: RouterLink, decorators: [{ type: Optional }] },
|
|
195
|
-
{ type: RouterLinkWithHref, decorators: [{ type: Optional }] }
|
|
196
|
-
];
|
|
197
|
-
RouterLinkActive.propDecorators = {
|
|
198
|
-
links: [{ type: ContentChildren, args: [RouterLink, { descendants: true },] }],
|
|
199
|
-
linksWithHrefs: [{ type: ContentChildren, args: [RouterLinkWithHref, { descendants: true },] }],
|
|
200
|
-
routerLinkActiveOptions: [{ type: Input }],
|
|
201
|
-
isActiveChange: [{ type: Output }],
|
|
202
|
-
routerLinkActive: [{ type: Input }]
|
|
203
|
-
};
|
|
204
|
-
/**
|
|
205
|
-
* Use instead of `'paths' in options` to be compatible with property renaming
|
|
206
|
-
*/
|
|
207
|
-
function isActiveMatchOptions(options) {
|
|
208
|
-
return !!options.paths;
|
|
209
|
-
}
|
|
210
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_link_active.js","sourceRoot":"","sources":["../../../../../../../packages/router/src/directives/router_link_active.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 {AfterContentInit, ChangeDetectorRef, ContentChildren, Directive, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, Optional, Output, QueryList, Renderer2, SimpleChanges} from '@angular/core';\nimport {from, of, Subscription} from 'rxjs';\nimport {mergeAll} from 'rxjs/operators';\n\nimport {Event, NavigationEnd} from '../events';\nimport {Router} from '../router';\nimport {IsActiveMatchOptions} from '../url_tree';\n\nimport {RouterLink, RouterLinkWithHref} from './router_link';\n\n\n/**\n *\n * @description\n *\n * Tracks whether the linked route of an element is currently active, and allows you\n * to specify one or more CSS classes to add to the element when the linked route\n * is active.\n *\n * Use this directive to create a visual distinction for elements associated with an active route.\n * For example, the following code highlights the word \"Bob\" when the router\n * activates the associated route:\n *\n * ```\n * <a routerLink=\"/user/bob\" routerLinkActive=\"active-link\">Bob</a>\n * ```\n *\n * Whenever the URL is either '/user' or '/user/bob', the \"active-link\" class is\n * added to the anchor tag. If the URL changes, the class is removed.\n *\n * You can set more than one class using a space-separated string or an array.\n * For example:\n *\n * ```\n * <a routerLink=\"/user/bob\" routerLinkActive=\"class1 class2\">Bob</a>\n * <a routerLink=\"/user/bob\" [routerLinkActive]=\"['class1', 'class2']\">Bob</a>\n * ```\n *\n * To add the classes only when the URL matches the link exactly, add the option `exact: true`:\n *\n * ```\n * <a routerLink=\"/user/bob\" routerLinkActive=\"active-link\" [routerLinkActiveOptions]=\"{exact:\n * true}\">Bob</a>\n * ```\n *\n * To directly check the `isActive` status of the link, assign the `RouterLinkActive`\n * instance to a template variable.\n * For example, the following checks the status without assigning any CSS classes:\n *\n * ```\n * <a routerLink=\"/user/bob\" routerLinkActive #rla=\"routerLinkActive\">\n *   Bob {{ rla.isActive ? '(already open)' : ''}}\n * </a>\n * ```\n *\n * You can apply the `RouterLinkActive` directive to an ancestor of linked elements.\n * For example, the following sets the active-link class on the `<div>`  parent tag\n * when the URL is either '/user/jim' or '/user/bob'.\n *\n * ```\n * <div routerLinkActive=\"active-link\" [routerLinkActiveOptions]=\"{exact: true}\">\n *   <a routerLink=\"/user/jim\">Jim</a>\n *   <a routerLink=\"/user/bob\">Bob</a>\n * </div>\n * ```\n *\n * @ngModule RouterModule\n *\n * @publicApi\n */\n@Directive({\n  selector: '[routerLinkActive]',\n  exportAs: 'routerLinkActive',\n})\nexport class RouterLinkActive implements OnChanges, OnDestroy, AfterContentInit {\n  @ContentChildren(RouterLink, {descendants: true}) links!: QueryList<RouterLink>;\n  @ContentChildren(RouterLinkWithHref, {descendants: true})\n  linksWithHrefs!: QueryList<RouterLinkWithHref>;\n\n  private classes: string[] = [];\n  private routerEventsSubscription: Subscription;\n  private linkInputChangesSubscription?: Subscription;\n  public readonly isActive: boolean = false;\n\n  /**\n   * Options to configure how to determine if the router link is active.\n   *\n   * These options are passed to the `Router.isActive()` function.\n   *\n   * @see Router.isActive\n   */\n  @Input() routerLinkActiveOptions: {exact: boolean}|IsActiveMatchOptions = {exact: false};\n\n  /**\n   *\n   * You can use the output `isActiveChange` to get notified each time the link becomes\n   * active or inactive.\n   *\n   * Emits:\n   * true  -> Route is active\n   * false -> Route is inactive\n   *\n   * ```\n   * <a\n   *  routerLink=\"/user/bob\"\n   *  routerLinkActive=\"active-link\"\n   *  (isActiveChange)=\"this.onRouterLinkActive($event)\">Bob</a>\n   * ```\n   */\n  @Output() readonly isActiveChange: EventEmitter<boolean> = new EventEmitter();\n\n  constructor(\n      private router: Router, private element: ElementRef, private renderer: Renderer2,\n      private readonly cdr: ChangeDetectorRef, @Optional() private link?: RouterLink,\n      @Optional() private linkWithHref?: RouterLinkWithHref) {\n    this.routerEventsSubscription = router.events.subscribe((s: Event) => {\n      if (s instanceof NavigationEnd) {\n        this.update();\n      }\n    });\n  }\n\n  /** @nodoc */\n  ngAfterContentInit(): void {\n    // `of(null)` is used to force subscribe body to execute once immediately (like `startWith`).\n    of(this.links.changes, this.linksWithHrefs.changes, of(null)).pipe(mergeAll()).subscribe(_ => {\n      this.update();\n      this.subscribeToEachLinkOnChanges();\n    });\n  }\n\n  private subscribeToEachLinkOnChanges() {\n    this.linkInputChangesSubscription?.unsubscribe();\n    const allLinkChanges =\n        [...this.links.toArray(), ...this.linksWithHrefs.toArray(), this.link, this.linkWithHref]\n            .filter((link): link is RouterLink|RouterLinkWithHref => !!link)\n            .map(link => link.onChanges);\n    this.linkInputChangesSubscription = from(allLinkChanges).pipe(mergeAll()).subscribe(link => {\n      if (this.isActive !== this.isLinkActive(this.router)(link)) {\n        this.update();\n      }\n    });\n  }\n\n  @Input()\n  set routerLinkActive(data: string[]|string) {\n    const classes = Array.isArray(data) ? data : data.split(' ');\n    this.classes = classes.filter(c => !!c);\n  }\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges): void {\n    this.update();\n  }\n  /** @nodoc */\n  ngOnDestroy(): void {\n    this.routerEventsSubscription.unsubscribe();\n    this.linkInputChangesSubscription?.unsubscribe();\n  }\n\n  private update(): void {\n    if (!this.links || !this.linksWithHrefs || !this.router.navigated) return;\n    Promise.resolve().then(() => {\n      const hasActiveLinks = this.hasActiveLinks();\n      if (this.isActive !== hasActiveLinks) {\n        (this as any).isActive = hasActiveLinks;\n        this.cdr.markForCheck();\n        this.classes.forEach((c) => {\n          if (hasActiveLinks) {\n            this.renderer.addClass(this.element.nativeElement, c);\n          } else {\n            this.renderer.removeClass(this.element.nativeElement, c);\n          }\n        });\n\n        // Emit on isActiveChange after classes are updated\n        this.isActiveChange.emit(hasActiveLinks);\n      }\n    });\n  }\n\n  private isLinkActive(router: Router): (link: (RouterLink|RouterLinkWithHref)) => boolean {\n    const options: boolean|IsActiveMatchOptions =\n        isActiveMatchOptions(this.routerLinkActiveOptions) ?\n        this.routerLinkActiveOptions :\n        // While the types should disallow `undefined` here, it's possible without strict inputs\n        (this.routerLinkActiveOptions.exact || false);\n    return (link: RouterLink|RouterLinkWithHref) =>\n               link.urlTree ? router.isActive(link.urlTree, options) : false;\n  }\n\n  private hasActiveLinks(): boolean {\n    const isActiveCheckFn = this.isLinkActive(this.router);\n    return this.link && isActiveCheckFn(this.link) ||\n        this.linkWithHref && isActiveCheckFn(this.linkWithHref) ||\n        this.links.some(isActiveCheckFn) || this.linksWithHrefs.some(isActiveCheckFn);\n  }\n}\n\n/**\n * Use instead of `'paths' in options` to be compatible with property renaming\n */\nfunction isActiveMatchOptions(options: {exact: boolean}|\n                              IsActiveMatchOptions): options is IsActiveMatchOptions {\n  return !!(options as IsActiveMatchOptions).paths;\n}\n"]}
|
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { Attribute, ChangeDetectorRef, ComponentFactoryResolver, Directive, EventEmitter, Output, ViewContainerRef, } from '@angular/core';
|
|
9
|
-
import { ChildrenOutletContexts } from '../router_outlet_context';
|
|
10
|
-
import { ActivatedRoute } from '../router_state';
|
|
11
|
-
import { PRIMARY_OUTLET } from '../shared';
|
|
12
|
-
/**
|
|
13
|
-
* @description
|
|
14
|
-
*
|
|
15
|
-
* Acts as a placeholder that Angular dynamically fills based on the current router state.
|
|
16
|
-
*
|
|
17
|
-
* Each outlet can have a unique name, determined by the optional `name` attribute.
|
|
18
|
-
* The name cannot be set or changed dynamically. If not set, default value is "primary".
|
|
19
|
-
*
|
|
20
|
-
* ```
|
|
21
|
-
* <router-outlet></router-outlet>
|
|
22
|
-
* <router-outlet name='left'></router-outlet>
|
|
23
|
-
* <router-outlet name='right'></router-outlet>
|
|
24
|
-
* ```
|
|
25
|
-
*
|
|
26
|
-
* Named outlets can be the targets of secondary routes.
|
|
27
|
-
* The `Route` object for a secondary route has an `outlet` property to identify the target outlet:
|
|
28
|
-
*
|
|
29
|
-
* `{path: <base-path>, component: <component>, outlet: <target_outlet_name>}`
|
|
30
|
-
*
|
|
31
|
-
* Using named outlets and secondary routes, you can target multiple outlets in
|
|
32
|
-
* the same `RouterLink` directive.
|
|
33
|
-
*
|
|
34
|
-
* The router keeps track of separate branches in a navigation tree for each named outlet and
|
|
35
|
-
* generates a representation of that tree in the URL.
|
|
36
|
-
* The URL for a secondary route uses the following syntax to specify both the primary and secondary
|
|
37
|
-
* routes at the same time:
|
|
38
|
-
*
|
|
39
|
-
* `http://base-path/primary-route-path(outlet-name:route-path)`
|
|
40
|
-
*
|
|
41
|
-
* A router outlet emits an activate event when a new component is instantiated,
|
|
42
|
-
* deactivate event when a component is destroyed.
|
|
43
|
-
* An attached event emits when the `RouteReuseStrategy` instructs the outlet to reattach the
|
|
44
|
-
* subtree, and the detached event emits when the `RouteReuseStrategy` instructs the outlet to
|
|
45
|
-
* detach the subtree.
|
|
46
|
-
*
|
|
47
|
-
* ```
|
|
48
|
-
* <router-outlet
|
|
49
|
-
* (activate)='onActivate($event)'
|
|
50
|
-
* (deactivate)='onDeactivate($event)'
|
|
51
|
-
* (attach)='onAttach($event)'
|
|
52
|
-
* (detach)='onDetach($event)'></router-outlet>
|
|
53
|
-
* ```
|
|
54
|
-
*
|
|
55
|
-
* @see [Routing tutorial](guide/router-tutorial-toh#named-outlets "Example of a named
|
|
56
|
-
* outlet and secondary route configuration").
|
|
57
|
-
* @see `RouterLink`
|
|
58
|
-
* @see `Route`
|
|
59
|
-
* @ngModule RouterModule
|
|
60
|
-
*
|
|
61
|
-
* @publicApi
|
|
62
|
-
*/
|
|
63
|
-
export class RouterOutlet {
|
|
64
|
-
constructor(parentContexts, location, resolver, name, changeDetector) {
|
|
65
|
-
this.parentContexts = parentContexts;
|
|
66
|
-
this.location = location;
|
|
67
|
-
this.resolver = resolver;
|
|
68
|
-
this.changeDetector = changeDetector;
|
|
69
|
-
this.activated = null;
|
|
70
|
-
this._activatedRoute = null;
|
|
71
|
-
this.activateEvents = new EventEmitter();
|
|
72
|
-
this.deactivateEvents = new EventEmitter();
|
|
73
|
-
/**
|
|
74
|
-
* Emits an attached component instance when the `RouteReuseStrategy` instructs to re-attach a
|
|
75
|
-
* previously detached subtree.
|
|
76
|
-
**/
|
|
77
|
-
this.attachEvents = new EventEmitter();
|
|
78
|
-
/**
|
|
79
|
-
* Emits a detached component instance when the `RouteReuseStrategy` instructs to detach the
|
|
80
|
-
* subtree.
|
|
81
|
-
*/
|
|
82
|
-
this.detachEvents = new EventEmitter();
|
|
83
|
-
this.name = name || PRIMARY_OUTLET;
|
|
84
|
-
parentContexts.onChildOutletCreated(this.name, this);
|
|
85
|
-
}
|
|
86
|
-
/** @nodoc */
|
|
87
|
-
ngOnDestroy() {
|
|
88
|
-
this.parentContexts.onChildOutletDestroyed(this.name);
|
|
89
|
-
}
|
|
90
|
-
/** @nodoc */
|
|
91
|
-
ngOnInit() {
|
|
92
|
-
if (!this.activated) {
|
|
93
|
-
// If the outlet was not instantiated at the time the route got activated we need to populate
|
|
94
|
-
// the outlet when it is initialized (ie inside a NgIf)
|
|
95
|
-
const context = this.parentContexts.getContext(this.name);
|
|
96
|
-
if (context && context.route) {
|
|
97
|
-
if (context.attachRef) {
|
|
98
|
-
// `attachRef` is populated when there is an existing component to mount
|
|
99
|
-
this.attach(context.attachRef, context.route);
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
// otherwise the component defined in the configuration is created
|
|
103
|
-
this.activateWith(context.route, context.resolver || null);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
get isActivated() {
|
|
109
|
-
return !!this.activated;
|
|
110
|
-
}
|
|
111
|
-
/**
|
|
112
|
-
* @returns The currently activated component instance.
|
|
113
|
-
* @throws An error if the outlet is not activated.
|
|
114
|
-
*/
|
|
115
|
-
get component() {
|
|
116
|
-
if (!this.activated)
|
|
117
|
-
throw new Error('Outlet is not activated');
|
|
118
|
-
return this.activated.instance;
|
|
119
|
-
}
|
|
120
|
-
get activatedRoute() {
|
|
121
|
-
if (!this.activated)
|
|
122
|
-
throw new Error('Outlet is not activated');
|
|
123
|
-
return this._activatedRoute;
|
|
124
|
-
}
|
|
125
|
-
get activatedRouteData() {
|
|
126
|
-
if (this._activatedRoute) {
|
|
127
|
-
return this._activatedRoute.snapshot.data;
|
|
128
|
-
}
|
|
129
|
-
return {};
|
|
130
|
-
}
|
|
131
|
-
/**
|
|
132
|
-
* Called when the `RouteReuseStrategy` instructs to detach the subtree
|
|
133
|
-
*/
|
|
134
|
-
detach() {
|
|
135
|
-
if (!this.activated)
|
|
136
|
-
throw new Error('Outlet is not activated');
|
|
137
|
-
this.location.detach();
|
|
138
|
-
const cmp = this.activated;
|
|
139
|
-
this.activated = null;
|
|
140
|
-
this._activatedRoute = null;
|
|
141
|
-
this.detachEvents.emit(cmp.instance);
|
|
142
|
-
return cmp;
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Called when the `RouteReuseStrategy` instructs to re-attach a previously detached subtree
|
|
146
|
-
*/
|
|
147
|
-
attach(ref, activatedRoute) {
|
|
148
|
-
this.activated = ref;
|
|
149
|
-
this._activatedRoute = activatedRoute;
|
|
150
|
-
this.location.insert(ref.hostView);
|
|
151
|
-
this.attachEvents.emit(ref.instance);
|
|
152
|
-
}
|
|
153
|
-
deactivate() {
|
|
154
|
-
if (this.activated) {
|
|
155
|
-
const c = this.component;
|
|
156
|
-
this.activated.destroy();
|
|
157
|
-
this.activated = null;
|
|
158
|
-
this._activatedRoute = null;
|
|
159
|
-
this.deactivateEvents.emit(c);
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
activateWith(activatedRoute, resolver) {
|
|
163
|
-
if (this.isActivated) {
|
|
164
|
-
throw new Error('Cannot activate an already activated outlet');
|
|
165
|
-
}
|
|
166
|
-
this._activatedRoute = activatedRoute;
|
|
167
|
-
const snapshot = activatedRoute._futureSnapshot;
|
|
168
|
-
const component = snapshot.routeConfig.component;
|
|
169
|
-
resolver = resolver || this.resolver;
|
|
170
|
-
const factory = resolver.resolveComponentFactory(component);
|
|
171
|
-
const childContexts = this.parentContexts.getOrCreateContext(this.name).children;
|
|
172
|
-
const injector = new OutletInjector(activatedRoute, childContexts, this.location.injector);
|
|
173
|
-
this.activated = this.location.createComponent(factory, this.location.length, injector);
|
|
174
|
-
// Calling `markForCheck` to make sure we will run the change detection when the
|
|
175
|
-
// `RouterOutlet` is inside a `ChangeDetectionStrategy.OnPush` component.
|
|
176
|
-
this.changeDetector.markForCheck();
|
|
177
|
-
this.activateEvents.emit(this.activated.instance);
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
RouterOutlet.decorators = [
|
|
181
|
-
{ type: Directive, args: [{ selector: 'router-outlet', exportAs: 'outlet' },] }
|
|
182
|
-
];
|
|
183
|
-
RouterOutlet.ctorParameters = () => [
|
|
184
|
-
{ type: ChildrenOutletContexts },
|
|
185
|
-
{ type: ViewContainerRef },
|
|
186
|
-
{ type: ComponentFactoryResolver },
|
|
187
|
-
{ type: String, decorators: [{ type: Attribute, args: ['name',] }] },
|
|
188
|
-
{ type: ChangeDetectorRef }
|
|
189
|
-
];
|
|
190
|
-
RouterOutlet.propDecorators = {
|
|
191
|
-
activateEvents: [{ type: Output, args: ['activate',] }],
|
|
192
|
-
deactivateEvents: [{ type: Output, args: ['deactivate',] }],
|
|
193
|
-
attachEvents: [{ type: Output, args: ['attach',] }],
|
|
194
|
-
detachEvents: [{ type: Output, args: ['detach',] }]
|
|
195
|
-
};
|
|
196
|
-
class OutletInjector {
|
|
197
|
-
constructor(route, childContexts, parent) {
|
|
198
|
-
this.route = route;
|
|
199
|
-
this.childContexts = childContexts;
|
|
200
|
-
this.parent = parent;
|
|
201
|
-
}
|
|
202
|
-
get(token, notFoundValue) {
|
|
203
|
-
if (token === ActivatedRoute) {
|
|
204
|
-
return this.route;
|
|
205
|
-
}
|
|
206
|
-
if (token === ChildrenOutletContexts) {
|
|
207
|
-
return this.childContexts;
|
|
208
|
-
}
|
|
209
|
-
return this.parent.get(token, notFoundValue);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_outlet.js","sourceRoot":"","sources":["../../../../../../../packages/router/src/directives/router_outlet.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 {Attribute, ChangeDetectorRef, ComponentFactoryResolver, ComponentRef, Directive, EventEmitter, Injector, OnDestroy, OnInit, Output, ViewContainerRef,} from '@angular/core';\nimport {Data} from '../config';\nimport {ChildrenOutletContexts} from '../router_outlet_context';\nimport {ActivatedRoute} from '../router_state';\nimport {PRIMARY_OUTLET} from '../shared';\n\n/**\n * An interface that defines the contract for developing a component outlet for the `Router`.\n *\n * An outlet acts as a placeholder that Angular dynamically fills based on the current router state.\n *\n * A router outlet should register itself with the `Router` via\n * `ChildrenOutletContexts#onChildOutletCreated` and unregister with\n * `ChildrenOutletContexts#onChildOutletDestroyed`. When the `Router` identifies a matched `Route`,\n * it looks for a registered outlet in the `ChildrenOutletContexts` and activates it.\n *\n * @see `ChildrenOutletContexts`\n * @publicApi\n */\nexport interface RouterOutletContract {\n  /**\n   * Whether the given outlet is activated.\n   *\n   * An outlet is considered \"activated\" if it has an active component.\n   */\n  isActivated: boolean;\n\n  /** The instance of the activated component or `null` if the outlet is not activated. */\n  component: Object|null;\n\n  /**\n   * The `Data` of the `ActivatedRoute` snapshot.\n   */\n  activatedRouteData: Data;\n\n  /**\n   * The `ActivatedRoute` for the outlet or `null` if the outlet is not activated.\n   */\n  activatedRoute: ActivatedRoute|null;\n\n  /**\n   * Called by the `Router` when the outlet should activate (create a component).\n   */\n  activateWith(activatedRoute: ActivatedRoute, resolver: ComponentFactoryResolver|null): void;\n\n  /**\n   * A request to destroy the currently activated component.\n   *\n   * When a `RouteReuseStrategy` indicates that an `ActivatedRoute` should be removed but stored for\n   * later re-use rather than destroyed, the `Router` will call `detach` instead.\n   */\n  deactivate(): void;\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to detach the subtree.\n   *\n   * This is similar to `deactivate`, but the activated component should _not_ be destroyed.\n   * Instead, it is returned so that it can be reattached later via the `attach` method.\n   */\n  detach(): ComponentRef<unknown>;\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to re-attach a previously detached subtree.\n   */\n  attach(ref: ComponentRef<unknown>, activatedRoute: ActivatedRoute): void;\n\n  /**\n   * Emits an activate event when a new component is instantiated\n   **/\n  activateEvents?: EventEmitter<unknown>;\n\n  /**\n   * Emits a deactivate event when a component is destroyed.\n   */\n  deactivateEvents?: EventEmitter<unknown>;\n\n  /**\n   * Emits an attached component instance when the `RouteReuseStrategy` instructs to re-attach a\n   * previously detached subtree.\n   **/\n  attachEvents?: EventEmitter<unknown>;\n\n  /**\n   * Emits a detached component instance when the `RouteReuseStrategy` instructs to detach the\n   * subtree.\n   */\n  detachEvents?: EventEmitter<unknown>;\n}\n\n/**\n * @description\n *\n * Acts as a placeholder that Angular dynamically fills based on the current router state.\n *\n * Each outlet can have a unique name, determined by the optional `name` attribute.\n * The name cannot be set or changed dynamically. If not set, default value is \"primary\".\n *\n * ```\n * <router-outlet></router-outlet>\n * <router-outlet name='left'></router-outlet>\n * <router-outlet name='right'></router-outlet>\n * ```\n *\n * Named outlets can be the targets of secondary routes.\n * The `Route` object for a secondary route has an `outlet` property to identify the target outlet:\n *\n * `{path: <base-path>, component: <component>, outlet: <target_outlet_name>}`\n *\n * Using named outlets and secondary routes, you can target multiple outlets in\n * the same `RouterLink` directive.\n *\n * The router keeps track of separate branches in a navigation tree for each named outlet and\n * generates a representation of that tree in the URL.\n * The URL for a secondary route uses the following syntax to specify both the primary and secondary\n * routes at the same time:\n *\n * `http://base-path/primary-route-path(outlet-name:route-path)`\n *\n * A router outlet emits an activate event when a new component is instantiated,\n * deactivate event when a component is destroyed.\n * An attached event emits when the `RouteReuseStrategy` instructs the outlet to reattach the\n * subtree, and the detached event emits when the `RouteReuseStrategy` instructs the outlet to\n * detach the subtree.\n *\n * ```\n * <router-outlet\n *   (activate)='onActivate($event)'\n *   (deactivate)='onDeactivate($event)'\n *   (attach)='onAttach($event)'\n *   (detach)='onDetach($event)'></router-outlet>\n * ```\n *\n * @see [Routing tutorial](guide/router-tutorial-toh#named-outlets \"Example of a named\n * outlet and secondary route configuration\").\n * @see `RouterLink`\n * @see `Route`\n * @ngModule RouterModule\n *\n * @publicApi\n */\n@Directive({selector: 'router-outlet', exportAs: 'outlet'})\nexport class RouterOutlet implements OnDestroy, OnInit, RouterOutletContract {\n  private activated: ComponentRef<any>|null = null;\n  private _activatedRoute: ActivatedRoute|null = null;\n  private name: string;\n\n  @Output('activate') activateEvents = new EventEmitter<any>();\n  @Output('deactivate') deactivateEvents = new EventEmitter<any>();\n  /**\n   * Emits an attached component instance when the `RouteReuseStrategy` instructs to re-attach a\n   * previously detached subtree.\n   **/\n  @Output('attach') attachEvents = new EventEmitter<unknown>();\n  /**\n   * Emits a detached component instance when the `RouteReuseStrategy` instructs to detach the\n   * subtree.\n   */\n  @Output('detach') detachEvents = new EventEmitter<unknown>();\n\n  constructor(\n      private parentContexts: ChildrenOutletContexts, private location: ViewContainerRef,\n      private resolver: ComponentFactoryResolver, @Attribute('name') name: string,\n      private changeDetector: ChangeDetectorRef) {\n    this.name = name || PRIMARY_OUTLET;\n    parentContexts.onChildOutletCreated(this.name, this);\n  }\n\n  /** @nodoc */\n  ngOnDestroy(): void {\n    this.parentContexts.onChildOutletDestroyed(this.name);\n  }\n\n  /** @nodoc */\n  ngOnInit(): void {\n    if (!this.activated) {\n      // If the outlet was not instantiated at the time the route got activated we need to populate\n      // the outlet when it is initialized (ie inside a NgIf)\n      const context = this.parentContexts.getContext(this.name);\n      if (context && context.route) {\n        if (context.attachRef) {\n          // `attachRef` is populated when there is an existing component to mount\n          this.attach(context.attachRef, context.route);\n        } else {\n          // otherwise the component defined in the configuration is created\n          this.activateWith(context.route, context.resolver || null);\n        }\n      }\n    }\n  }\n\n  get isActivated(): boolean {\n    return !!this.activated;\n  }\n\n  /**\n   * @returns The currently activated component instance.\n   * @throws An error if the outlet is not activated.\n   */\n  get component(): Object {\n    if (!this.activated) throw new Error('Outlet is not activated');\n    return this.activated.instance;\n  }\n\n  get activatedRoute(): ActivatedRoute {\n    if (!this.activated) throw new Error('Outlet is not activated');\n    return this._activatedRoute as ActivatedRoute;\n  }\n\n  get activatedRouteData(): Data {\n    if (this._activatedRoute) {\n      return this._activatedRoute.snapshot.data;\n    }\n    return {};\n  }\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to detach the subtree\n   */\n  detach(): ComponentRef<any> {\n    if (!this.activated) throw new Error('Outlet is not activated');\n    this.location.detach();\n    const cmp = this.activated;\n    this.activated = null;\n    this._activatedRoute = null;\n    this.detachEvents.emit(cmp.instance);\n    return cmp;\n  }\n\n  /**\n   * Called when the `RouteReuseStrategy` instructs to re-attach a previously detached subtree\n   */\n  attach(ref: ComponentRef<any>, activatedRoute: ActivatedRoute) {\n    this.activated = ref;\n    this._activatedRoute = activatedRoute;\n    this.location.insert(ref.hostView);\n    this.attachEvents.emit(ref.instance);\n  }\n\n  deactivate(): void {\n    if (this.activated) {\n      const c = this.component;\n      this.activated.destroy();\n      this.activated = null;\n      this._activatedRoute = null;\n      this.deactivateEvents.emit(c);\n    }\n  }\n\n  activateWith(activatedRoute: ActivatedRoute, resolver: ComponentFactoryResolver|null) {\n    if (this.isActivated) {\n      throw new Error('Cannot activate an already activated outlet');\n    }\n    this._activatedRoute = activatedRoute;\n    const snapshot = activatedRoute._futureSnapshot;\n    const component = <any>snapshot.routeConfig!.component;\n    resolver = resolver || this.resolver;\n    const factory = resolver.resolveComponentFactory(component);\n    const childContexts = this.parentContexts.getOrCreateContext(this.name).children;\n    const injector = new OutletInjector(activatedRoute, childContexts, this.location.injector);\n    this.activated = this.location.createComponent(factory, this.location.length, injector);\n    // Calling `markForCheck` to make sure we will run the change detection when the\n    // `RouterOutlet` is inside a `ChangeDetectionStrategy.OnPush` component.\n    this.changeDetector.markForCheck();\n    this.activateEvents.emit(this.activated.instance);\n  }\n}\n\nclass OutletInjector implements Injector {\n  constructor(\n      private route: ActivatedRoute, private childContexts: ChildrenOutletContexts,\n      private parent: Injector) {}\n\n  get(token: any, notFoundValue?: any): any {\n    if (token === ActivatedRoute) {\n      return this.route;\n    }\n\n    if (token === ChildrenOutletContexts) {\n      return this.childContexts;\n    }\n\n    return this.parent.get(token, notFoundValue);\n  }\n}\n"]}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { map, switchMap } from 'rxjs/operators';
|
|
9
|
-
import { applyRedirects as applyRedirectsFn } from '../apply_redirects';
|
|
10
|
-
export function applyRedirects(moduleInjector, configLoader, urlSerializer, config) {
|
|
11
|
-
return switchMap(t => applyRedirectsFn(moduleInjector, configLoader, urlSerializer, t.extractedUrl, config)
|
|
12
|
-
.pipe(map(urlAfterRedirects => (Object.assign(Object.assign({}, t), { urlAfterRedirects })))));
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbHlfcmVkaXJlY3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcm91dGVyL3NyYy9vcGVyYXRvcnMvYXBwbHlfcmVkaXJlY3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUlILE9BQU8sRUFBQyxHQUFHLEVBQUUsU0FBUyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFOUMsT0FBTyxFQUFDLGNBQWMsSUFBSSxnQkFBZ0IsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBTXRFLE1BQU0sVUFBVSxjQUFjLENBQzFCLGNBQXdCLEVBQUUsWUFBZ0MsRUFBRSxhQUE0QixFQUN4RixNQUFjO0lBQ2hCLE9BQU8sU0FBUyxDQUNaLENBQUMsQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsQ0FBQyxDQUFDLFlBQVksRUFBRSxNQUFNLENBQUM7U0FDaEYsSUFBSSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLENBQUMsaUNBQUssQ0FBQyxLQUFFLGlCQUFpQixJQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDN0UsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge0luamVjdG9yfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TW9ub1R5cGVPcGVyYXRvckZ1bmN0aW9ufSBmcm9tICdyeGpzJztcbmltcG9ydCB7bWFwLCBzd2l0Y2hNYXB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHthcHBseVJlZGlyZWN0cyBhcyBhcHBseVJlZGlyZWN0c0ZufSBmcm9tICcuLi9hcHBseV9yZWRpcmVjdHMnO1xuaW1wb3J0IHtSb3V0ZXN9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05hdmlnYXRpb25UcmFuc2l0aW9ufSBmcm9tICcuLi9yb3V0ZXInO1xuaW1wb3J0IHtSb3V0ZXJDb25maWdMb2FkZXJ9IGZyb20gJy4uL3JvdXRlcl9jb25maWdfbG9hZGVyJztcbmltcG9ydCB7VXJsU2VyaWFsaXplcn0gZnJvbSAnLi4vdXJsX3RyZWUnO1xuXG5leHBvcnQgZnVuY3Rpb24gYXBwbHlSZWRpcmVjdHMoXG4gICAgbW9kdWxlSW5qZWN0b3I6IEluamVjdG9yLCBjb25maWdMb2FkZXI6IFJvdXRlckNvbmZpZ0xvYWRlciwgdXJsU2VyaWFsaXplcjogVXJsU2VyaWFsaXplcixcbiAgICBjb25maWc6IFJvdXRlcyk6IE1vbm9UeXBlT3BlcmF0b3JGdW5jdGlvbjxOYXZpZ2F0aW9uVHJhbnNpdGlvbj4ge1xuICByZXR1cm4gc3dpdGNoTWFwKFxuICAgICAgdCA9PiBhcHBseVJlZGlyZWN0c0ZuKG1vZHVsZUluamVjdG9yLCBjb25maWdMb2FkZXIsIHVybFNlcmlhbGl6ZXIsIHQuZXh0cmFjdGVkVXJsLCBjb25maWcpXG4gICAgICAgICAgICAgICAucGlwZShtYXAodXJsQWZ0ZXJSZWRpcmVjdHMgPT4gKHsuLi50LCB1cmxBZnRlclJlZGlyZWN0c30pKSkpO1xufVxuIl19
|