source: trip-planner-front/node_modules/@angular/router/esm2015/src/directives/router_link.js

Last change on this file was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 37.1 KB
Line 
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 */
8import { LocationStrategy } from '@angular/common';
9import { Attribute, Directive, ElementRef, HostBinding, HostListener, Input, Renderer2 } from '@angular/core';
10import { Subject } from 'rxjs';
11import { NavigationEnd } from '../events';
12import { Router } from '../router';
13import { ActivatedRoute } from '../router_state';
14/**
15 * @description
16 *
17 * When applied to an element in a template, makes that element a link
18 * that initiates navigation to a route. Navigation opens one or more routed components
19 * in one or more `<router-outlet>` locations on the page.
20 *
21 * Given a route configuration `[{ path: 'user/:name', component: UserCmp }]`,
22 * the following creates a static link to the route:
23 * `<a routerLink="/user/bob">link to user component</a>`
24 *
25 * You can use dynamic values to generate the link.
26 * For a dynamic link, pass an array of path segments,
27 * followed by the params for each segment.
28 * For example, `['/team', teamId, 'user', userName, {details: true}]`
29 * generates a link to `/team/11/user/bob;details=true`.
30 *
31 * Multiple static segments can be merged into one term and combined with dynamic segements.
32 * For example, `['/team/11/user', userName, {details: true}]`
33 *
34 * The input that you provide to the link is treated as a delta to the current URL.
35 * For instance, suppose the current URL is `/user/(box//aux:team)`.
36 * The link `<a [routerLink]="['/user/jim']">Jim</a>` creates the URL
37 * `/user/(jim//aux:team)`.
38 * See {@link Router#createUrlTree createUrlTree} for more information.
39 *
40 * @usageNotes
41 *
42 * You can use absolute or relative paths in a link, set query parameters,
43 * control how parameters are handled, and keep a history of navigation states.
44 *
45 * ### Relative link paths
46 *
47 * The first segment name can be prepended with `/`, `./`, or `../`.
48 * * If the first segment begins with `/`, the router looks up the route from the root of the
49 * app.
50 * * If the first segment begins with `./`, or doesn't begin with a slash, the router
51 * looks in the children of the current activated route.
52 * * If the first segment begins with `../`, the router goes up one level in the route tree.
53 *
54 * ### Setting and handling query params and fragments
55 *
56 * The following link adds a query parameter and a fragment to the generated URL:
57 *
58 * ```
59 * <a [routerLink]="['/user/bob']" [queryParams]="{debug: true}" fragment="education">
60 * link to user component
61 * </a>
62 * ```
63 * By default, the directive constructs the new URL using the given query parameters.
64 * The example generates the link: `/user/bob?debug=true#education`.
65 *
66 * You can instruct the directive to handle query parameters differently
67 * by specifying the `queryParamsHandling` option in the link.
68 * Allowed values are:
69 *
70 * - `'merge'`: Merge the given `queryParams` into the current query params.
71 * - `'preserve'`: Preserve the current query params.
72 *
73 * For example:
74 *
75 * ```
76 * <a [routerLink]="['/user/bob']" [queryParams]="{debug: true}" queryParamsHandling="merge">
77 * link to user component
78 * </a>
79 * ```
80 *
81 * See {@link UrlCreationOptions.queryParamsHandling UrlCreationOptions#queryParamsHandling}.
82 *
83 * ### Preserving navigation history
84 *
85 * You can provide a `state` value to be persisted to the browser's
86 * [`History.state` property](https://developer.mozilla.org/en-US/docs/Web/API/History#Properties).
87 * For example:
88 *
89 * ```
90 * <a [routerLink]="['/user/bob']" [state]="{tracingId: 123}">
91 * link to user component
92 * </a>
93 * ```
94 *
95 * Use {@link Router.getCurrentNavigation() Router#getCurrentNavigation} to retrieve a saved
96 * navigation-state value. For example, to capture the `tracingId` during the `NavigationStart`
97 * event:
98 *
99 * ```
100 * // Get NavigationStart events
101 * router.events.pipe(filter(e => e instanceof NavigationStart)).subscribe(e => {
102 * const navigation = router.getCurrentNavigation();
103 * tracingService.trace({id: navigation.extras.state.tracingId});
104 * });
105 * ```
106 *
107 * @ngModule RouterModule
108 *
109 * @publicApi
110 */
111export class RouterLink {
112 constructor(router, route, tabIndex, renderer, el) {
113 this.router = router;
114 this.route = route;
115 this.commands = [];
116 /** @internal */
117 this.onChanges = new Subject();
118 if (tabIndex == null) {
119 renderer.setAttribute(el.nativeElement, 'tabindex', '0');
120 }
121 }
122 /** @nodoc */
123 ngOnChanges(changes) {
124 // This is subscribed to by `RouterLinkActive` so that it knows to update when there are changes
125 // to the RouterLinks it's tracking.
126 this.onChanges.next(this);
127 }
128 /**
129 * Commands to pass to {@link Router#createUrlTree Router#createUrlTree}.
130 * - **array**: commands to pass to {@link Router#createUrlTree Router#createUrlTree}.
131 * - **string**: shorthand for array of commands with just the string, i.e. `['/route']`
132 * - **null|undefined**: shorthand for an empty array of commands, i.e. `[]`
133 * @see {@link Router#createUrlTree Router#createUrlTree}
134 */
135 set routerLink(commands) {
136 if (commands != null) {
137 this.commands = Array.isArray(commands) ? commands : [commands];
138 }
139 else {
140 this.commands = [];
141 }
142 }
143 /** @nodoc */
144 onClick() {
145 const extras = {
146 skipLocationChange: attrBoolValue(this.skipLocationChange),
147 replaceUrl: attrBoolValue(this.replaceUrl),
148 state: this.state,
149 };
150 this.router.navigateByUrl(this.urlTree, extras);
151 return true;
152 }
153 get urlTree() {
154 return this.router.createUrlTree(this.commands, {
155 // If the `relativeTo` input is not defined, we want to use `this.route` by default.
156 // Otherwise, we should use the value provided by the user in the input.
157 relativeTo: this.relativeTo !== undefined ? this.relativeTo : this.route,
158 queryParams: this.queryParams,
159 fragment: this.fragment,
160 queryParamsHandling: this.queryParamsHandling,
161 preserveFragment: attrBoolValue(this.preserveFragment),
162 });
163 }
164}
165RouterLink.decorators = [
166 { type: Directive, args: [{ selector: ':not(a):not(area)[routerLink]' },] }
167];
168RouterLink.ctorParameters = () => [
169 { type: Router },
170 { type: ActivatedRoute },
171 { type: String, decorators: [{ type: Attribute, args: ['tabindex',] }] },
172 { type: Renderer2 },
173 { type: ElementRef }
174];
175RouterLink.propDecorators = {
176 queryParams: [{ type: Input }],
177 fragment: [{ type: Input }],
178 queryParamsHandling: [{ type: Input }],
179 preserveFragment: [{ type: Input }],
180 skipLocationChange: [{ type: Input }],
181 replaceUrl: [{ type: Input }],
182 state: [{ type: Input }],
183 relativeTo: [{ type: Input }],
184 routerLink: [{ type: Input }],
185 onClick: [{ type: HostListener, args: ['click',] }]
186};
187/**
188 * @description
189 *
190 * Lets you link to specific routes in your app.
191 *
192 * See `RouterLink` for more information.
193 *
194 * @ngModule RouterModule
195 *
196 * @publicApi
197 */
198export class RouterLinkWithHref {
199 constructor(router, route, locationStrategy) {
200 this.router = router;
201 this.route = route;
202 this.locationStrategy = locationStrategy;
203 this.commands = [];
204 /** @internal */
205 this.onChanges = new Subject();
206 this.subscription = router.events.subscribe((s) => {
207 if (s instanceof NavigationEnd) {
208 this.updateTargetUrlAndHref();
209 }
210 });
211 }
212 /**
213 * Commands to pass to {@link Router#createUrlTree Router#createUrlTree}.
214 * - **array**: commands to pass to {@link Router#createUrlTree Router#createUrlTree}.
215 * - **string**: shorthand for array of commands with just the string, i.e. `['/route']`
216 * - **null|undefined**: shorthand for an empty array of commands, i.e. `[]`
217 * @see {@link Router#createUrlTree Router#createUrlTree}
218 */
219 set routerLink(commands) {
220 if (commands != null) {
221 this.commands = Array.isArray(commands) ? commands : [commands];
222 }
223 else {
224 this.commands = [];
225 }
226 }
227 /** @nodoc */
228 ngOnChanges(changes) {
229 this.updateTargetUrlAndHref();
230 this.onChanges.next(this);
231 }
232 /** @nodoc */
233 ngOnDestroy() {
234 this.subscription.unsubscribe();
235 }
236 /** @nodoc */
237 onClick(button, ctrlKey, shiftKey, altKey, metaKey) {
238 if (button !== 0 || ctrlKey || shiftKey || altKey || metaKey) {
239 return true;
240 }
241 if (typeof this.target === 'string' && this.target != '_self') {
242 return true;
243 }
244 const extras = {
245 skipLocationChange: attrBoolValue(this.skipLocationChange),
246 replaceUrl: attrBoolValue(this.replaceUrl),
247 state: this.state
248 };
249 this.router.navigateByUrl(this.urlTree, extras);
250 return false;
251 }
252 updateTargetUrlAndHref() {
253 this.href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.urlTree));
254 }
255 get urlTree() {
256 return this.router.createUrlTree(this.commands, {
257 // If the `relativeTo` input is not defined, we want to use `this.route` by default.
258 // Otherwise, we should use the value provided by the user in the input.
259 relativeTo: this.relativeTo !== undefined ? this.relativeTo : this.route,
260 queryParams: this.queryParams,
261 fragment: this.fragment,
262 queryParamsHandling: this.queryParamsHandling,
263 preserveFragment: attrBoolValue(this.preserveFragment),
264 });
265 }
266}
267RouterLinkWithHref.decorators = [
268 { type: Directive, args: [{ selector: 'a[routerLink],area[routerLink]' },] }
269];
270RouterLinkWithHref.ctorParameters = () => [
271 { type: Router },
272 { type: ActivatedRoute },
273 { type: LocationStrategy }
274];
275RouterLinkWithHref.propDecorators = {
276 target: [{ type: HostBinding, args: ['attr.target',] }, { type: Input }],
277 queryParams: [{ type: Input }],
278 fragment: [{ type: Input }],
279 queryParamsHandling: [{ type: Input }],
280 preserveFragment: [{ type: Input }],
281 skipLocationChange: [{ type: Input }],
282 replaceUrl: [{ type: Input }],
283 state: [{ type: Input }],
284 relativeTo: [{ type: Input }],
285 href: [{ type: HostBinding }],
286 routerLink: [{ type: Input }],
287 onClick: [{ type: HostListener, args: ['click',
288 ['$event.button', '$event.ctrlKey', '$event.shiftKey', '$event.altKey', '$event.metaKey'],] }]
289};
290function attrBoolValue(s) {
291 return s === '' || !!s;
292}
293//# 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 {Attribute, Directive, ElementRef, HostBinding, HostListener, Input, OnChanges, OnDestroy, Renderer2, SimpleChanges} from '@angular/core';\nimport {Subject, Subscription} from 'rxjs';\n\nimport {QueryParamsHandling} from '../config';\nimport {Event, NavigationEnd} from '../events';\nimport {Router} from '../router';\nimport {ActivatedRoute} from '../router_state';\nimport {Params} from '../shared';\nimport {UrlTree} from '../url_tree';\n\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 segements.\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 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 * See {@link UrlCreationOptions.queryParamsHandling 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() 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({selector: ':not(a):not(area)[routerLink]'})\nexport class RouterLink implements OnChanges {\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#queryParams UrlCreationOptions#queryParams}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() queryParams?: Params|null;\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#fragment UrlCreationOptions#fragment}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() fragment?: string;\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#queryParamsHandling UrlCreationOptions#queryParamsHandling}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() queryParamsHandling?: QueryParamsHandling|null;\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#preserveFragment UrlCreationOptions#preserveFragment}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() preserveFragment!: boolean;\n  /**\n   * Passed to {@link Router#navigateByUrl Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#skipLocationChange NavigationBehaviorOptions#skipLocationChange}\n   * @see {@link Router#navigateByUrl Router#navigateByUrl}\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() skipLocationChange!: boolean;\n  /**\n   * Passed to {@link Router#navigateByUrl Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#replaceUrl NavigationBehaviorOptions#replaceUrl}\n   * @see {@link Router#navigateByUrl Router#navigateByUrl}\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() replaceUrl!: boolean;\n  /**\n   * Passed to {@link Router#navigateByUrl Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#state NavigationBehaviorOptions#state}\n   * @see {@link Router#navigateByUrl Router#navigateByUrl}\n   */\n  @Input() state?: {[k: string]: any};\n  /**\n   * Passed to {@link Router#createUrlTree 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 UrlCreationOptions#relativeTo}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() relativeTo?: ActivatedRoute|null;\n\n  private commands: any[] = [];\n  private preserve!: boolean;\n\n  /** @internal */\n  onChanges = new Subject<RouterLink>();\n\n  constructor(\n      private router: Router, private route: ActivatedRoute,\n      @Attribute('tabindex') tabIndex: string, renderer: Renderer2, el: ElementRef) {\n    if (tabIndex == null) {\n      renderer.setAttribute(el.nativeElement, 'tabindex', '0');\n    }\n  }\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges) {\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  /**\n   * Commands to pass to {@link Router#createUrlTree Router#createUrlTree}.\n   *   - **array**: commands to pass to {@link Router#createUrlTree Router#createUrlTree}.\n   *   - **string**: shorthand for array of commands with just the string, i.e. `['/route']`\n   *   - **null|undefined**: shorthand for an empty array of commands, i.e. `[]`\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input()\n  set routerLink(commands: any[]|string|null|undefined) {\n    if (commands != null) {\n      this.commands = Array.isArray(commands) ? commands : [commands];\n    } else {\n      this.commands = [];\n    }\n  }\n\n  /** @nodoc */\n  @HostListener('click')\n  onClick(): boolean {\n    const extras = {\n      skipLocationChange: attrBoolValue(this.skipLocationChange),\n      replaceUrl: attrBoolValue(this.replaceUrl),\n      state: this.state,\n    };\n    this.router.navigateByUrl(this.urlTree, extras);\n    return true;\n  }\n\n  get urlTree(): UrlTree {\n    return this.router.createUrlTree(this.commands, {\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: attrBoolValue(this.preserveFragment),\n    });\n  }\n}\n\n/**\n * @description\n *\n * Lets you link to specific routes in your app.\n *\n * See `RouterLink` for more information.\n *\n * @ngModule RouterModule\n *\n * @publicApi\n */\n@Directive({selector: 'a[routerLink],area[routerLink]'})\nexport class RouterLinkWithHref implements OnChanges, OnDestroy {\n  // TODO(issue/24571): remove '!'.\n  @HostBinding('attr.target') @Input() target!: string;\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#queryParams UrlCreationOptions#queryParams}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() queryParams?: Params|null;\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#fragment UrlCreationOptions#fragment}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() fragment?: string;\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#queryParamsHandling UrlCreationOptions#queryParamsHandling}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() queryParamsHandling?: QueryParamsHandling|null;\n  /**\n   * Passed to {@link Router#createUrlTree Router#createUrlTree} as part of the\n   * `UrlCreationOptions`.\n   * @see {@link UrlCreationOptions#preserveFragment UrlCreationOptions#preserveFragment}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() preserveFragment!: boolean;\n  /**\n   * Passed to {@link Router#navigateByUrl Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#skipLocationChange NavigationBehaviorOptions#skipLocationChange}\n   * @see {@link Router#navigateByUrl Router#navigateByUrl}\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() skipLocationChange!: boolean;\n  /**\n   * Passed to {@link Router#navigateByUrl Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#replaceUrl NavigationBehaviorOptions#replaceUrl}\n   * @see {@link Router#navigateByUrl Router#navigateByUrl}\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() replaceUrl!: boolean;\n  /**\n   * Passed to {@link Router#navigateByUrl Router#navigateByUrl} as part of the\n   * `NavigationBehaviorOptions`.\n   * @see {@link NavigationBehaviorOptions#state NavigationBehaviorOptions#state}\n   * @see {@link Router#navigateByUrl Router#navigateByUrl}\n   */\n  @Input() state?: {[k: string]: any};\n  /**\n   * Passed to {@link Router#createUrlTree 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 UrlCreationOptions#relativeTo}\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input() relativeTo?: ActivatedRoute|null;\n\n  private commands: any[] = [];\n  private subscription: Subscription;\n  // TODO(issue/24571): remove '!'.\n  private preserve!: boolean;\n\n  // the url displayed on the anchor element.\n  // TODO(issue/24571): remove '!'.\n  @HostBinding() href!: string;\n\n  /** @internal */\n  onChanges = new Subject<RouterLinkWithHref>();\n\n  constructor(\n      private router: Router, private route: ActivatedRoute,\n      private locationStrategy: LocationStrategy) {\n    this.subscription = router.events.subscribe((s: Event) => {\n      if (s instanceof NavigationEnd) {\n        this.updateTargetUrlAndHref();\n      }\n    });\n  }\n\n  /**\n   * Commands to pass to {@link Router#createUrlTree Router#createUrlTree}.\n   *   - **array**: commands to pass to {@link Router#createUrlTree Router#createUrlTree}.\n   *   - **string**: shorthand for array of commands with just the string, i.e. `['/route']`\n   *   - **null|undefined**: shorthand for an empty array of commands, i.e. `[]`\n   * @see {@link Router#createUrlTree Router#createUrlTree}\n   */\n  @Input()\n  set routerLink(commands: any[]|string|null|undefined) {\n    if (commands != null) {\n      this.commands = Array.isArray(commands) ? commands : [commands];\n    } else {\n      this.commands = [];\n    }\n  }\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges): any {\n    this.updateTargetUrlAndHref();\n    this.onChanges.next(this);\n  }\n  /** @nodoc */\n  ngOnDestroy(): any {\n    this.subscription.unsubscribe();\n  }\n\n  /** @nodoc */\n  @HostListener(\n      'click',\n      ['$event.button', '$event.ctrlKey', '$event.shiftKey', '$event.altKey', '$event.metaKey'])\n  onClick(button: number, ctrlKey: boolean, shiftKey: boolean, altKey: boolean, metaKey: boolean):\n      boolean {\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    const extras = {\n      skipLocationChange: attrBoolValue(this.skipLocationChange),\n      replaceUrl: attrBoolValue(this.replaceUrl),\n      state: this.state\n    };\n    this.router.navigateByUrl(this.urlTree, extras);\n    return false;\n  }\n\n  private updateTargetUrlAndHref(): void {\n    this.href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.urlTree));\n  }\n\n  get urlTree(): UrlTree {\n    return this.router.createUrlTree(this.commands, {\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: attrBoolValue(this.preserveFragment),\n    });\n  }\n}\n\nfunction attrBoolValue(s: any): boolean {\n  return s === '' || !!s;\n}\n"]}
Note: See TracBrowser for help on using the repository browser.