@angular/router 19.0.0-next.0 → 19.0.0-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/fesm2022/router.mjs +86 -96
- package/fesm2022/router.mjs.map +1 -1
- package/fesm2022/testing.mjs +11 -11
- package/fesm2022/upgrade.mjs +1 -1
- package/index.d.ts +1 -1
- package/package.json +4 -10
- package/testing/index.d.ts +1 -1
- package/upgrade/index.d.ts +1 -1
- package/esm2022/index.mjs +0 -13
- package/esm2022/public_api.mjs +0 -15
- package/esm2022/router.mjs +0 -5
- package/esm2022/src/apply_redirects.mjs +0 -124
- package/esm2022/src/components/empty_outlet.mjs +0 -49
- package/esm2022/src/create_router_state.mjs +0 -52
- package/esm2022/src/create_url_tree.mjs +0 -420
- package/esm2022/src/directives/router_link.mjs +0 -361
- package/esm2022/src/directives/router_link_active.mjs +0 -237
- package/esm2022/src/directives/router_outlet.mjs +0 -388
- package/esm2022/src/errors.mjs +0 -2
- package/esm2022/src/events.mjs +0 -588
- package/esm2022/src/index.mjs +0 -31
- package/esm2022/src/models.mjs +0 -45
- package/esm2022/src/models_deprecated.mjs +0 -9
- package/esm2022/src/navigation_canceling_error.mjs +0 -33
- package/esm2022/src/navigation_transition.mjs +0 -437
- package/esm2022/src/operators/activate_routes.mjs +0 -190
- package/esm2022/src/operators/check_guards.mjs +0 -157
- package/esm2022/src/operators/prioritized_guard_value.mjs +0 -40
- package/esm2022/src/operators/recognize.mjs +0 -15
- package/esm2022/src/operators/resolve_data.mjs +0 -92
- package/esm2022/src/operators/switch_tap.mjs +0 -25
- package/esm2022/src/page_title_strategy.mjs +0 -89
- package/esm2022/src/private_export.mjs +0 -12
- package/esm2022/src/provide_router.mjs +0 -549
- package/esm2022/src/recognize.mjs +0 -321
- package/esm2022/src/route_reuse_strategy.mjs +0 -79
- package/esm2022/src/router.mjs +0 -571
- package/esm2022/src/router_config.mjs +0 -18
- package/esm2022/src/router_config_loader.mjs +0 -137
- package/esm2022/src/router_module.mjs +0 -226
- package/esm2022/src/router_outlet_context.mjs +0 -90
- package/esm2022/src/router_preloader.mjs +0 -162
- package/esm2022/src/router_scroller.mjs +0 -111
- package/esm2022/src/router_state.mjs +0 -419
- package/esm2022/src/shared.mjs +0 -97
- package/esm2022/src/statemanager/state_manager.mjs +0 -200
- package/esm2022/src/url_handling_strategy.mjs +0 -45
- package/esm2022/src/url_tree.mjs +0 -643
- package/esm2022/src/utils/collection.mjs +0 -75
- package/esm2022/src/utils/config.mjs +0 -191
- package/esm2022/src/utils/config_matching.mjs +0 -150
- package/esm2022/src/utils/functional_guards.mjs +0 -69
- package/esm2022/src/utils/navigations.mjs +0 -44
- package/esm2022/src/utils/preactivation.mjs +0 -154
- package/esm2022/src/utils/tree.mjs +0 -94
- package/esm2022/src/utils/type_guards.mjs +0 -46
- package/esm2022/src/utils/view_transition.mjs +0 -61
- package/esm2022/src/version.mjs +0 -18
- package/esm2022/testing/index.mjs +0 -13
- package/esm2022/testing/public_api.mjs +0 -15
- package/esm2022/testing/src/router_testing_harness.mjs +0 -127
- package/esm2022/testing/src/router_testing_module.mjs +0 -75
- package/esm2022/testing/src/testing.mjs +0 -15
- package/esm2022/testing/testing.mjs +0 -5
- package/esm2022/upgrade/index.mjs +0 -13
- package/esm2022/upgrade/public_api.mjs +0 -15
- package/esm2022/upgrade/src/upgrade.mjs +0 -128
- package/esm2022/upgrade/upgrade.mjs +0 -5
|
@@ -1,361 +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 { LocationStrategy } from '@angular/common';
|
|
9
|
-
import { Attribute, booleanAttribute, Directive, ElementRef, HostBinding, HostListener, Input, Renderer2, ɵRuntimeError as RuntimeError, ɵɵsanitizeUrlOrResourceUrl, } from '@angular/core';
|
|
10
|
-
import { Subject } from 'rxjs';
|
|
11
|
-
import { NavigationEnd } from '../events';
|
|
12
|
-
import { Router } from '../router';
|
|
13
|
-
import { ActivatedRoute } from '../router_state';
|
|
14
|
-
import { isUrlTree } from '../url_tree';
|
|
15
|
-
import * as i0 from "@angular/core";
|
|
16
|
-
import * as i1 from "../router";
|
|
17
|
-
import * as i2 from "../router_state";
|
|
18
|
-
import * as i3 from "@angular/common";
|
|
19
|
-
/**
|
|
20
|
-
* @description
|
|
21
|
-
*
|
|
22
|
-
* When applied to an element in a template, makes that element a link
|
|
23
|
-
* that initiates navigation to a route. Navigation opens one or more routed components
|
|
24
|
-
* in one or more `<router-outlet>` locations on the page.
|
|
25
|
-
*
|
|
26
|
-
* Given a route configuration `[{ path: 'user/:name', component: UserCmp }]`,
|
|
27
|
-
* the following creates a static link to the route:
|
|
28
|
-
* `<a routerLink="/user/bob">link to user component</a>`
|
|
29
|
-
*
|
|
30
|
-
* You can use dynamic values to generate the link.
|
|
31
|
-
* For a dynamic link, pass an array of path segments,
|
|
32
|
-
* followed by the params for each segment.
|
|
33
|
-
* For example, `['/team', teamId, 'user', userName, {details: true}]`
|
|
34
|
-
* generates a link to `/team/11/user/bob;details=true`.
|
|
35
|
-
*
|
|
36
|
-
* Multiple static segments can be merged into one term and combined with dynamic segments.
|
|
37
|
-
* For example, `['/team/11/user', userName, {details: true}]`
|
|
38
|
-
*
|
|
39
|
-
* The input that you provide to the link is treated as a delta to the current URL.
|
|
40
|
-
* For instance, suppose the current URL is `/user/(box//aux:team)`.
|
|
41
|
-
* The link `<a [routerLink]="['/user/jim']">Jim</a>` creates the URL
|
|
42
|
-
* `/user/(jim//aux:team)`.
|
|
43
|
-
* See {@link Router#createUrlTree} for more information.
|
|
44
|
-
*
|
|
45
|
-
* @usageNotes
|
|
46
|
-
*
|
|
47
|
-
* You can use absolute or relative paths in a link, set query parameters,
|
|
48
|
-
* control how parameters are handled, and keep a history of navigation states.
|
|
49
|
-
*
|
|
50
|
-
* ### Relative link paths
|
|
51
|
-
*
|
|
52
|
-
* The first segment name can be prepended with `/`, `./`, or `../`.
|
|
53
|
-
* * If the first segment begins with `/`, the router looks up the route from the root of the
|
|
54
|
-
* app.
|
|
55
|
-
* * If the first segment begins with `./`, or doesn't begin with a slash, the router
|
|
56
|
-
* looks in the children of the current activated route.
|
|
57
|
-
* * If the first segment begins with `../`, the router goes up one level in the route tree.
|
|
58
|
-
*
|
|
59
|
-
* ### Setting and handling query params and fragments
|
|
60
|
-
*
|
|
61
|
-
* The following link adds a query parameter and a fragment to the generated URL:
|
|
62
|
-
*
|
|
63
|
-
* ```
|
|
64
|
-
* <a [routerLink]="['/user/bob']" [queryParams]="{debug: true}" fragment="education">
|
|
65
|
-
* link to user component
|
|
66
|
-
* </a>
|
|
67
|
-
* ```
|
|
68
|
-
* By default, the directive constructs the new URL using the given query parameters.
|
|
69
|
-
* The example generates the link: `/user/bob?debug=true#education`.
|
|
70
|
-
*
|
|
71
|
-
* You can instruct the directive to handle query parameters differently
|
|
72
|
-
* by specifying the `queryParamsHandling` option in the link.
|
|
73
|
-
* Allowed values are:
|
|
74
|
-
*
|
|
75
|
-
* - `'merge'`: Merge the given `queryParams` into the current query params.
|
|
76
|
-
* - `'preserve'`: Preserve the current query params.
|
|
77
|
-
*
|
|
78
|
-
* For example:
|
|
79
|
-
*
|
|
80
|
-
* ```
|
|
81
|
-
* <a [routerLink]="['/user/bob']" [queryParams]="{debug: true}" queryParamsHandling="merge">
|
|
82
|
-
* link to user component
|
|
83
|
-
* </a>
|
|
84
|
-
* ```
|
|
85
|
-
*
|
|
86
|
-
* `queryParams`, `fragment`, `queryParamsHandling`, `preserveFragment`, and `relativeTo`
|
|
87
|
-
* cannot be used when the `routerLink` input is a `UrlTree`.
|
|
88
|
-
*
|
|
89
|
-
* See {@link UrlCreationOptions#queryParamsHandling}.
|
|
90
|
-
*
|
|
91
|
-
* ### Preserving navigation history
|
|
92
|
-
*
|
|
93
|
-
* You can provide a `state` value to be persisted to the browser's
|
|
94
|
-
* [`History.state` property](https://developer.mozilla.org/en-US/docs/Web/API/History#Properties).
|
|
95
|
-
* For example:
|
|
96
|
-
*
|
|
97
|
-
* ```
|
|
98
|
-
* <a [routerLink]="['/user/bob']" [state]="{tracingId: 123}">
|
|
99
|
-
* link to user component
|
|
100
|
-
* </a>
|
|
101
|
-
* ```
|
|
102
|
-
*
|
|
103
|
-
* Use {@link Router#getCurrentNavigation} to retrieve a saved
|
|
104
|
-
* navigation-state value. For example, to capture the `tracingId` during the `NavigationStart`
|
|
105
|
-
* event:
|
|
106
|
-
*
|
|
107
|
-
* ```
|
|
108
|
-
* // Get NavigationStart events
|
|
109
|
-
* router.events.pipe(filter(e => e instanceof NavigationStart)).subscribe(e => {
|
|
110
|
-
* const navigation = router.getCurrentNavigation();
|
|
111
|
-
* tracingService.trace({id: navigation.extras.state.tracingId});
|
|
112
|
-
* });
|
|
113
|
-
* ```
|
|
114
|
-
*
|
|
115
|
-
* @ngModule RouterModule
|
|
116
|
-
*
|
|
117
|
-
* @publicApi
|
|
118
|
-
*/
|
|
119
|
-
export class RouterLink {
|
|
120
|
-
constructor(router, route, tabIndexAttribute, renderer, el, locationStrategy) {
|
|
121
|
-
this.router = router;
|
|
122
|
-
this.route = route;
|
|
123
|
-
this.tabIndexAttribute = tabIndexAttribute;
|
|
124
|
-
this.renderer = renderer;
|
|
125
|
-
this.el = el;
|
|
126
|
-
this.locationStrategy = locationStrategy;
|
|
127
|
-
/**
|
|
128
|
-
* Represents an `href` attribute value applied to a host element,
|
|
129
|
-
* when a host element is `<a>`. For other tags, the value is `null`.
|
|
130
|
-
*/
|
|
131
|
-
this.href = null;
|
|
132
|
-
/** @internal */
|
|
133
|
-
this.onChanges = new Subject();
|
|
134
|
-
/**
|
|
135
|
-
* Passed to {@link Router#createUrlTree} as part of the
|
|
136
|
-
* `UrlCreationOptions`.
|
|
137
|
-
* @see {@link UrlCreationOptions#preserveFragment}
|
|
138
|
-
* @see {@link Router#createUrlTree}
|
|
139
|
-
*/
|
|
140
|
-
this.preserveFragment = false;
|
|
141
|
-
/**
|
|
142
|
-
* Passed to {@link Router#navigateByUrl} as part of the
|
|
143
|
-
* `NavigationBehaviorOptions`.
|
|
144
|
-
* @see {@link NavigationBehaviorOptions#skipLocationChange}
|
|
145
|
-
* @see {@link Router#navigateByUrl}
|
|
146
|
-
*/
|
|
147
|
-
this.skipLocationChange = false;
|
|
148
|
-
/**
|
|
149
|
-
* Passed to {@link Router#navigateByUrl} as part of the
|
|
150
|
-
* `NavigationBehaviorOptions`.
|
|
151
|
-
* @see {@link NavigationBehaviorOptions#replaceUrl}
|
|
152
|
-
* @see {@link Router#navigateByUrl}
|
|
153
|
-
*/
|
|
154
|
-
this.replaceUrl = false;
|
|
155
|
-
this.routerLinkInput = null;
|
|
156
|
-
const tagName = el.nativeElement.tagName?.toLowerCase();
|
|
157
|
-
this.isAnchorElement = tagName === 'a' || tagName === 'area';
|
|
158
|
-
if (this.isAnchorElement) {
|
|
159
|
-
this.subscription = router.events.subscribe((s) => {
|
|
160
|
-
if (s instanceof NavigationEnd) {
|
|
161
|
-
this.updateHref();
|
|
162
|
-
}
|
|
163
|
-
});
|
|
164
|
-
}
|
|
165
|
-
else {
|
|
166
|
-
this.setTabIndexIfNotOnNativeEl('0');
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
/**
|
|
170
|
-
* Modifies the tab index if there was not a tabindex attribute on the element during
|
|
171
|
-
* instantiation.
|
|
172
|
-
*/
|
|
173
|
-
setTabIndexIfNotOnNativeEl(newTabIndex) {
|
|
174
|
-
if (this.tabIndexAttribute != null /* both `null` and `undefined` */ || this.isAnchorElement) {
|
|
175
|
-
return;
|
|
176
|
-
}
|
|
177
|
-
this.applyAttributeValue('tabindex', newTabIndex);
|
|
178
|
-
}
|
|
179
|
-
/** @nodoc */
|
|
180
|
-
// TODO(atscott): Remove changes parameter in major version as a breaking change.
|
|
181
|
-
ngOnChanges(changes) {
|
|
182
|
-
if (ngDevMode &&
|
|
183
|
-
isUrlTree(this.routerLinkInput) &&
|
|
184
|
-
(this.fragment !== undefined ||
|
|
185
|
-
this.queryParams ||
|
|
186
|
-
this.queryParamsHandling ||
|
|
187
|
-
this.preserveFragment ||
|
|
188
|
-
this.relativeTo)) {
|
|
189
|
-
throw new RuntimeError(4016 /* RuntimeErrorCode.INVALID_ROUTER_LINK_INPUTS */, 'Cannot configure queryParams or fragment when using a UrlTree as the routerLink input value.');
|
|
190
|
-
}
|
|
191
|
-
if (this.isAnchorElement) {
|
|
192
|
-
this.updateHref();
|
|
193
|
-
}
|
|
194
|
-
// This is subscribed to by `RouterLinkActive` so that it knows to update when there are changes
|
|
195
|
-
// to the RouterLinks it's tracking.
|
|
196
|
-
this.onChanges.next(this);
|
|
197
|
-
}
|
|
198
|
-
/**
|
|
199
|
-
* Commands to pass to {@link Router#createUrlTree} or a `UrlTree`.
|
|
200
|
-
* - **array**: commands to pass to {@link Router#createUrlTree}.
|
|
201
|
-
* - **string**: shorthand for array of commands with just the string, i.e. `['/route']`
|
|
202
|
-
* - **UrlTree**: a `UrlTree` for this link rather than creating one from the commands
|
|
203
|
-
* and other inputs that correspond to properties of `UrlCreationOptions`.
|
|
204
|
-
* - **null|undefined**: effectively disables the `routerLink`
|
|
205
|
-
* @see {@link Router#createUrlTree}
|
|
206
|
-
*/
|
|
207
|
-
set routerLink(commandsOrUrlTree) {
|
|
208
|
-
if (commandsOrUrlTree == null) {
|
|
209
|
-
this.routerLinkInput = null;
|
|
210
|
-
this.setTabIndexIfNotOnNativeEl(null);
|
|
211
|
-
}
|
|
212
|
-
else {
|
|
213
|
-
if (isUrlTree(commandsOrUrlTree)) {
|
|
214
|
-
this.routerLinkInput = commandsOrUrlTree;
|
|
215
|
-
}
|
|
216
|
-
else {
|
|
217
|
-
this.routerLinkInput = Array.isArray(commandsOrUrlTree)
|
|
218
|
-
? commandsOrUrlTree
|
|
219
|
-
: [commandsOrUrlTree];
|
|
220
|
-
}
|
|
221
|
-
this.setTabIndexIfNotOnNativeEl('0');
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
/** @nodoc */
|
|
225
|
-
onClick(button, ctrlKey, shiftKey, altKey, metaKey) {
|
|
226
|
-
const urlTree = this.urlTree;
|
|
227
|
-
if (urlTree === null) {
|
|
228
|
-
return true;
|
|
229
|
-
}
|
|
230
|
-
if (this.isAnchorElement) {
|
|
231
|
-
if (button !== 0 || ctrlKey || shiftKey || altKey || metaKey) {
|
|
232
|
-
return true;
|
|
233
|
-
}
|
|
234
|
-
if (typeof this.target === 'string' && this.target != '_self') {
|
|
235
|
-
return true;
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
const extras = {
|
|
239
|
-
skipLocationChange: this.skipLocationChange,
|
|
240
|
-
replaceUrl: this.replaceUrl,
|
|
241
|
-
state: this.state,
|
|
242
|
-
info: this.info,
|
|
243
|
-
};
|
|
244
|
-
this.router.navigateByUrl(urlTree, extras);
|
|
245
|
-
// Return `false` for `<a>` elements to prevent default action
|
|
246
|
-
// and cancel the native behavior, since the navigation is handled
|
|
247
|
-
// by the Router.
|
|
248
|
-
return !this.isAnchorElement;
|
|
249
|
-
}
|
|
250
|
-
/** @nodoc */
|
|
251
|
-
ngOnDestroy() {
|
|
252
|
-
this.subscription?.unsubscribe();
|
|
253
|
-
}
|
|
254
|
-
updateHref() {
|
|
255
|
-
const urlTree = this.urlTree;
|
|
256
|
-
this.href =
|
|
257
|
-
urlTree !== null && this.locationStrategy
|
|
258
|
-
? this.locationStrategy?.prepareExternalUrl(this.router.serializeUrl(urlTree))
|
|
259
|
-
: null;
|
|
260
|
-
const sanitizedValue = this.href === null
|
|
261
|
-
? null
|
|
262
|
-
: // This class represents a directive that can be added to both `<a>` elements,
|
|
263
|
-
// as well as other elements. As a result, we can't define security context at
|
|
264
|
-
// compile time. So the security context is deferred to runtime.
|
|
265
|
-
// The `ɵɵsanitizeUrlOrResourceUrl` selects the necessary sanitizer function
|
|
266
|
-
// based on the tag and property names. The logic mimics the one from
|
|
267
|
-
// `packages/compiler/src/schema/dom_security_schema.ts`, which is used at compile time.
|
|
268
|
-
//
|
|
269
|
-
// Note: we should investigate whether we can switch to using `@HostBinding('attr.href')`
|
|
270
|
-
// instead of applying a value via a renderer, after a final merge of the
|
|
271
|
-
// `RouterLinkWithHref` directive.
|
|
272
|
-
ɵɵsanitizeUrlOrResourceUrl(this.href, this.el.nativeElement.tagName.toLowerCase(), 'href');
|
|
273
|
-
this.applyAttributeValue('href', sanitizedValue);
|
|
274
|
-
}
|
|
275
|
-
applyAttributeValue(attrName, attrValue) {
|
|
276
|
-
const renderer = this.renderer;
|
|
277
|
-
const nativeElement = this.el.nativeElement;
|
|
278
|
-
if (attrValue !== null) {
|
|
279
|
-
renderer.setAttribute(nativeElement, attrName, attrValue);
|
|
280
|
-
}
|
|
281
|
-
else {
|
|
282
|
-
renderer.removeAttribute(nativeElement, attrName);
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
get urlTree() {
|
|
286
|
-
if (this.routerLinkInput === null) {
|
|
287
|
-
return null;
|
|
288
|
-
}
|
|
289
|
-
else if (isUrlTree(this.routerLinkInput)) {
|
|
290
|
-
return this.routerLinkInput;
|
|
291
|
-
}
|
|
292
|
-
return this.router.createUrlTree(this.routerLinkInput, {
|
|
293
|
-
// If the `relativeTo` input is not defined, we want to use `this.route` by default.
|
|
294
|
-
// Otherwise, we should use the value provided by the user in the input.
|
|
295
|
-
relativeTo: this.relativeTo !== undefined ? this.relativeTo : this.route,
|
|
296
|
-
queryParams: this.queryParams,
|
|
297
|
-
fragment: this.fragment,
|
|
298
|
-
queryParamsHandling: this.queryParamsHandling,
|
|
299
|
-
preserveFragment: this.preserveFragment,
|
|
300
|
-
});
|
|
301
|
-
}
|
|
302
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.0", ngImport: i0, type: RouterLink, deps: [{ token: i1.Router }, { token: i2.ActivatedRoute }, { token: 'tabindex', attribute: true }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i3.LocationStrategy }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
303
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "19.0.0-next.0", type: RouterLink, isStandalone: true, selector: "[routerLink]", inputs: { target: "target", queryParams: "queryParams", fragment: "fragment", queryParamsHandling: "queryParamsHandling", state: "state", info: "info", relativeTo: "relativeTo", preserveFragment: ["preserveFragment", "preserveFragment", booleanAttribute], skipLocationChange: ["skipLocationChange", "skipLocationChange", booleanAttribute], replaceUrl: ["replaceUrl", "replaceUrl", booleanAttribute], routerLink: "routerLink" }, host: { listeners: { "click": "onClick($event.button,$event.ctrlKey,$event.shiftKey,$event.altKey,$event.metaKey)" }, properties: { "attr.target": "this.target" } }, usesOnChanges: true, ngImport: i0 }); }
|
|
304
|
-
}
|
|
305
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.0", ngImport: i0, type: RouterLink, decorators: [{
|
|
306
|
-
type: Directive,
|
|
307
|
-
args: [{
|
|
308
|
-
selector: '[routerLink]',
|
|
309
|
-
standalone: true,
|
|
310
|
-
}]
|
|
311
|
-
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.ActivatedRoute }, { type: undefined, decorators: [{
|
|
312
|
-
type: Attribute,
|
|
313
|
-
args: ['tabindex']
|
|
314
|
-
}] }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i3.LocationStrategy }], propDecorators: { target: [{
|
|
315
|
-
type: HostBinding,
|
|
316
|
-
args: ['attr.target']
|
|
317
|
-
}, {
|
|
318
|
-
type: Input
|
|
319
|
-
}], queryParams: [{
|
|
320
|
-
type: Input
|
|
321
|
-
}], fragment: [{
|
|
322
|
-
type: Input
|
|
323
|
-
}], queryParamsHandling: [{
|
|
324
|
-
type: Input
|
|
325
|
-
}], state: [{
|
|
326
|
-
type: Input
|
|
327
|
-
}], info: [{
|
|
328
|
-
type: Input
|
|
329
|
-
}], relativeTo: [{
|
|
330
|
-
type: Input
|
|
331
|
-
}], preserveFragment: [{
|
|
332
|
-
type: Input,
|
|
333
|
-
args: [{ transform: booleanAttribute }]
|
|
334
|
-
}], skipLocationChange: [{
|
|
335
|
-
type: Input,
|
|
336
|
-
args: [{ transform: booleanAttribute }]
|
|
337
|
-
}], replaceUrl: [{
|
|
338
|
-
type: Input,
|
|
339
|
-
args: [{ transform: booleanAttribute }]
|
|
340
|
-
}], routerLink: [{
|
|
341
|
-
type: Input
|
|
342
|
-
}], onClick: [{
|
|
343
|
-
type: HostListener,
|
|
344
|
-
args: ['click', [
|
|
345
|
-
'$event.button',
|
|
346
|
-
'$event.ctrlKey',
|
|
347
|
-
'$event.shiftKey',
|
|
348
|
-
'$event.altKey',
|
|
349
|
-
'$event.metaKey',
|
|
350
|
-
]]
|
|
351
|
-
}] } });
|
|
352
|
-
/**
|
|
353
|
-
* @description
|
|
354
|
-
* An alias for the `RouterLink` directive.
|
|
355
|
-
* Deprecated since v15, use `RouterLink` directive instead.
|
|
356
|
-
*
|
|
357
|
-
* @deprecated use `RouterLink` directive instead.
|
|
358
|
-
* @publicApi
|
|
359
|
-
*/
|
|
360
|
-
export { RouterLink as RouterLinkWithHref };
|
|
361
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_link.js","sourceRoot":"","sources":["../../../../../../../packages/router/src/directives/router_link.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 {LocationStrategy} from '@angular/common';\nimport {\n  Attribute,\n  booleanAttribute,\n  Directive,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  ɵRuntimeError as RuntimeError,\n  SimpleChanges,\n  ɵɵsanitizeUrlOrResourceUrl,\n} from '@angular/core';\nimport {Subject, Subscription} from 'rxjs';\n\nimport {Event, NavigationEnd} from '../events';\nimport {QueryParamsHandling} from '../models';\nimport {Router} from '../router';\nimport {ActivatedRoute} from '../router_state';\nimport {Params} from '../shared';\nimport {isUrlTree, UrlTree} from '../url_tree';\nimport {RuntimeErrorCode} from '../errors';\n\n/**\n * @description\n *\n * When applied to an element in a template, makes that element a link\n * that initiates navigation to a route. Navigation opens one or more routed components\n * in one or more `<router-outlet>` locations on the page.\n *\n * Given a route configuration `[{ path: 'user/:name', component: UserCmp }]`,\n * the following creates a static link to the route:\n * `<a routerLink=\"/user/bob\">link to user component</a>`\n *\n * You can use dynamic values to generate the link.\n * For a dynamic link, pass an array of path segments,\n * followed by the params for each segment.\n * For example, `['/team', teamId, 'user', userName, {details: true}]`\n * generates a link to `/team/11/user/bob;details=true`.\n *\n * Multiple static segments can be merged into one term and combined with dynamic segments.\n * For example, `['/team/11/user', userName, {details: true}]`\n *\n * The input that you provide to the link is treated as a delta to the current URL.\n * For instance, suppose the current URL is `/user/(box//aux:team)`.\n * The link `<a [routerLink]=\"['/user/jim']\">Jim</a>` creates the URL\n * `/user/(jim//aux:team)`.\n * See {@link Router#createUrlTree} for more information.\n *\n * @usageNotes\n *\n * You can use absolute or relative paths in a link, set query parameters,\n * control how parameters are handled, and keep a history of navigation states.\n *\n * ### Relative link paths\n *\n * The first segment name can be prepended with `/`, `./`, or `../`.\n * * If the first segment begins with `/`, the router looks up the route from the root of the\n *   app.\n * * If the first segment begins with `./`, or doesn't begin with a slash, the router\n *   looks in the children of the current activated route.\n * * If the first segment begins with `../`, the router goes up one level in the route tree.\n *\n * ### Setting and handling query params and fragments\n *\n * The following link adds a query parameter and a fragment to the generated URL:\n *\n * ```\n * <a [routerLink]=\"['/user/bob']\" [queryParams]=\"{debug: true}\" fragment=\"education\">\n *   link to user component\n * </a>\n * ```\n * By default, the directive constructs the new URL using the given query parameters.\n * The example generates the link: `/user/bob?debug=true#education`.\n *\n * You can instruct the directive to handle query parameters differently\n * by specifying the `queryParamsHandling` option in the link.\n * Allowed values are:\n *\n *  - `'merge'`: Merge the given `queryParams` into the current query params.\n *  - `'preserve'`: Preserve the current query params.\n *\n * For example:\n *\n * ```\n * <a [routerLink]=\"['/user/bob']\" [queryParams]=\"{debug: true}\" queryParamsHandling=\"merge\">\n *   link to user component\n * </a>\n * ```\n *\n * `queryParams`, `fragment`, `queryParamsHandling`, `preserveFragment`, and `relativeTo`\n * cannot be used when the `routerLink` input is a `UrlTree`.\n *\n * See {@link UrlCreationOptions#queryParamsHandling}.\n *\n * ### Preserving navigation history\n *\n * You can provide a `state` value to be persisted to the browser's\n * [`History.state` property](https://developer.mozilla.org/en-US/docs/Web/API/History#Properties).\n * For example:\n *\n * ```\n * <a [routerLink]=\"['/user/bob']\" [state]=\"{tracingId: 123}\">\n *   link to user component\n * </a>\n * ```\n *\n * Use {@link Router#getCurrentNavigation} to retrieve a saved\n * navigation-state value. For example, to capture the `tracingId` during the `NavigationStart`\n * event:\n *\n * ```\n * // Get NavigationStart events\n * router.events.pipe(filter(e => e instanceof NavigationStart)).subscribe(e => {\n *   const navigation = router.getCurrentNavigation();\n *   tracingService.trace({id: navigation.extras.state.tracingId});\n * });\n * ```\n *\n * @ngModule RouterModule\n *\n * @publicApi\n */\n@Directive({\n  selector: '[routerLink]',\n  standalone: true,\n})\nexport class RouterLink implements OnChanges, OnDestroy {\n  /**\n   * Represents an `href` attribute value applied to a host element,\n   * when a host element is `<a>`. For other tags, the value is `null`.\n   */\n  href: string | null = null;\n\n  /**\n   * Represents the `target` attribute on a host element.\n   * This is only used when the host element is an `<a>` tag.\n   */\n  @HostBinding('attr.target') @Input() target?: string;\n\n  /**\n   * Passed to {@link Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#queryParams}\n   * @see {@link Router#createUrlTree}\n   */\n  @Input() queryParams?: Params | null;\n  /**\n   * Passed to {@link Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#fragment}\n   * @see {@link Router#createUrlTree}\n   */\n  @Input() fragment?: string;\n  /**\n   * Passed to {@link Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#queryParamsHandling}\n   * @see {@link Router#createUrlTree}\n   */\n  @Input() queryParamsHandling?: QueryParamsHandling | null;\n  /**\n   * Passed to {@link Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#state}\n   * @see {@link Router#navigateByUrl}\n   */\n  @Input() state?: {[k: string]: any};\n  /**\n   * Passed to {@link Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#info}\n   * @see {@link Router#navigateByUrl}\n   */\n  @Input() info?: unknown;\n  /**\n   * Passed to {@link Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * Specify a value here when you do not want to use the default value\n   * for `routerLink`, which is the current activated route.\n   * Note that a value of `undefined` here will use the `routerLink` default.\n   * @see {@link UrlCreationOptions#relativeTo}\n   * @see {@link Router#createUrlTree}\n   */\n  @Input() relativeTo?: ActivatedRoute | null;\n\n  /** Whether a host element is an `<a>` tag. */\n  private isAnchorElement: boolean;\n\n  private subscription?: Subscription;\n\n  /** @internal */\n  onChanges = new Subject<RouterLink>();\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    @Attribute('tabindex') private readonly tabIndexAttribute: string | null | undefined,\n    private readonly renderer: Renderer2,\n    private readonly el: ElementRef,\n    private locationStrategy?: LocationStrategy,\n  ) {\n    const tagName = el.nativeElement.tagName?.toLowerCase();\n    this.isAnchorElement = tagName === 'a' || tagName === 'area';\n\n    if (this.isAnchorElement) {\n      this.subscription = router.events.subscribe((s: Event) => {\n        if (s instanceof NavigationEnd) {\n          this.updateHref();\n        }\n      });\n    } else {\n      this.setTabIndexIfNotOnNativeEl('0');\n    }\n  }\n\n  /**\n   * Passed to {@link Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#preserveFragment}\n   * @see {@link Router#createUrlTree}\n   */\n  @Input({transform: booleanAttribute}) preserveFragment: boolean = false;\n\n  /**\n   * Passed to {@link Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#skipLocationChange}\n   * @see {@link Router#navigateByUrl}\n   */\n  @Input({transform: booleanAttribute}) skipLocationChange: boolean = false;\n\n  /**\n   * Passed to {@link Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#replaceUrl}\n   * @see {@link Router#navigateByUrl}\n   */\n  @Input({transform: booleanAttribute}) replaceUrl: boolean = false;\n\n  /**\n   * Modifies the tab index if there was not a tabindex attribute on the element during\n   * instantiation.\n   */\n  private setTabIndexIfNotOnNativeEl(newTabIndex: string | null) {\n    if (this.tabIndexAttribute != null /* both `null` and `undefined` */ || this.isAnchorElement) {\n      return;\n    }\n    this.applyAttributeValue('tabindex', newTabIndex);\n  }\n\n  /** @nodoc */\n  // TODO(atscott): Remove changes parameter in major version as a breaking change.\n  ngOnChanges(changes?: SimpleChanges) {\n    if (\n      ngDevMode &&\n      isUrlTree(this.routerLinkInput) &&\n      (this.fragment !== undefined ||\n        this.queryParams ||\n        this.queryParamsHandling ||\n        this.preserveFragment ||\n        this.relativeTo)\n    ) {\n      throw new RuntimeError(\n        RuntimeErrorCode.INVALID_ROUTER_LINK_INPUTS,\n        'Cannot configure queryParams or fragment when using a UrlTree as the routerLink input value.',\n      );\n    }\n    if (this.isAnchorElement) {\n      this.updateHref();\n    }\n    // This is subscribed to by `RouterLinkActive` so that it knows to update when there are changes\n    // to the RouterLinks it's tracking.\n    this.onChanges.next(this);\n  }\n\n  private routerLinkInput: any[] | UrlTree | null = null;\n\n  /**\n   * Commands to pass to {@link Router#createUrlTree} or a `UrlTree`.\n   *   - **array**: commands to pass to {@link Router#createUrlTree}.\n   *   - **string**: shorthand for array of commands with just the string, i.e. `['/route']`\n   *   - **UrlTree**: a `UrlTree` for this link rather than creating one from the commands\n   *     and other inputs that correspond to properties of `UrlCreationOptions`.\n   *   - **null|undefined**: effectively disables the `routerLink`\n   * @see {@link Router#createUrlTree}\n   */\n  @Input()\n  set routerLink(commandsOrUrlTree: any[] | string | UrlTree | null | undefined) {\n    if (commandsOrUrlTree == null) {\n      this.routerLinkInput = null;\n      this.setTabIndexIfNotOnNativeEl(null);\n    } else {\n      if (isUrlTree(commandsOrUrlTree)) {\n        this.routerLinkInput = commandsOrUrlTree;\n      } else {\n        this.routerLinkInput = Array.isArray(commandsOrUrlTree)\n          ? commandsOrUrlTree\n          : [commandsOrUrlTree];\n      }\n      this.setTabIndexIfNotOnNativeEl('0');\n    }\n  }\n\n  /** @nodoc */\n  @HostListener('click', [\n    '$event.button',\n    '$event.ctrlKey',\n    '$event.shiftKey',\n    '$event.altKey',\n    '$event.metaKey',\n  ])\n  onClick(\n    button: number,\n    ctrlKey: boolean,\n    shiftKey: boolean,\n    altKey: boolean,\n    metaKey: boolean,\n  ): boolean {\n    const urlTree = this.urlTree;\n\n    if (urlTree === null) {\n      return true;\n    }\n\n    if (this.isAnchorElement) {\n      if (button !== 0 || ctrlKey || shiftKey || altKey || metaKey) {\n        return true;\n      }\n\n      if (typeof this.target === 'string' && this.target != '_self') {\n        return true;\n      }\n    }\n\n    const extras = {\n      skipLocationChange: this.skipLocationChange,\n      replaceUrl: this.replaceUrl,\n      state: this.state,\n      info: this.info,\n    };\n    this.router.navigateByUrl(urlTree, extras);\n\n    // Return `false` for `<a>` elements to prevent default action\n    // and cancel the native behavior, since the navigation is handled\n    // by the Router.\n    return !this.isAnchorElement;\n  }\n\n  /** @nodoc */\n  ngOnDestroy(): any {\n    this.subscription?.unsubscribe();\n  }\n\n  private updateHref(): void {\n    const urlTree = this.urlTree;\n    this.href =\n      urlTree !== null && this.locationStrategy\n        ? this.locationStrategy?.prepareExternalUrl(this.router.serializeUrl(urlTree))\n        : null;\n\n    const sanitizedValue =\n      this.href === null\n        ? null\n        : // This class represents a directive that can be added to both `<a>` elements,\n          // as well as other elements. As a result, we can't define security context at\n          // compile time. So the security context is deferred to runtime.\n          // The `ɵɵsanitizeUrlOrResourceUrl` selects the necessary sanitizer function\n          // based on the tag and property names. The logic mimics the one from\n          // `packages/compiler/src/schema/dom_security_schema.ts`, which is used at compile time.\n          //\n          // Note: we should investigate whether we can switch to using `@HostBinding('attr.href')`\n          // instead of applying a value via a renderer, after a final merge of the\n          // `RouterLinkWithHref` directive.\n          ɵɵsanitizeUrlOrResourceUrl(\n            this.href,\n            this.el.nativeElement.tagName.toLowerCase(),\n            'href',\n          );\n    this.applyAttributeValue('href', sanitizedValue);\n  }\n\n  private applyAttributeValue(attrName: string, attrValue: string | null) {\n    const renderer = this.renderer;\n    const nativeElement = this.el.nativeElement;\n    if (attrValue !== null) {\n      renderer.setAttribute(nativeElement, attrName, attrValue);\n    } else {\n      renderer.removeAttribute(nativeElement, attrName);\n    }\n  }\n\n  get urlTree(): UrlTree | null {\n    if (this.routerLinkInput === null) {\n      return null;\n    } else if (isUrlTree(this.routerLinkInput)) {\n      return this.routerLinkInput;\n    }\n    return this.router.createUrlTree(this.routerLinkInput, {\n      // If the `relativeTo` input is not defined, we want to use `this.route` by default.\n      // Otherwise, we should use the value provided by the user in the input.\n      relativeTo: this.relativeTo !== undefined ? this.relativeTo : this.route,\n      queryParams: this.queryParams,\n      fragment: this.fragment,\n      queryParamsHandling: this.queryParamsHandling,\n      preserveFragment: this.preserveFragment,\n    });\n  }\n}\n\n/**\n * @description\n * An alias for the `RouterLink` directive.\n * Deprecated since v15, use `RouterLink` directive instead.\n *\n * @deprecated use `RouterLink` directive instead.\n * @publicApi\n */\nexport {RouterLink as RouterLinkWithHref};\n"]}
|