router-link-delegate.mjs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. import { Directive, HostListener, Input, Optional } from '@angular/core';
  2. import * as i0 from "@angular/core";
  3. import * as i1 from "@angular/common";
  4. import * as i2 from "../../providers/nav-controller";
  5. import * as i3 from "@angular/router";
  6. /**
  7. * Adds support for Ionic routing directions and animations to the base Angular router link directive.
  8. *
  9. * When the router link is clicked, the directive will assign the direction and
  10. * animation so that the routing integration will transition correctly.
  11. */
  12. export class RouterLinkDelegateDirective {
  13. locationStrategy;
  14. navCtrl;
  15. elementRef;
  16. router;
  17. routerLink;
  18. routerDirection = 'forward';
  19. routerAnimation;
  20. constructor(locationStrategy, navCtrl, elementRef, router, routerLink) {
  21. this.locationStrategy = locationStrategy;
  22. this.navCtrl = navCtrl;
  23. this.elementRef = elementRef;
  24. this.router = router;
  25. this.routerLink = routerLink;
  26. }
  27. ngOnInit() {
  28. this.updateTargetUrlAndHref();
  29. this.updateTabindex();
  30. }
  31. ngOnChanges() {
  32. this.updateTargetUrlAndHref();
  33. }
  34. /**
  35. * The `tabindex` is set to `0` by default on the host element when
  36. * the `routerLink` directive is used. This causes issues with Ionic
  37. * components that wrap an `a` or `button` element, such as `ion-item`.
  38. * See issue https://github.com/angular/angular/issues/28345
  39. *
  40. * This method removes the `tabindex` attribute from the host element
  41. * to allow the Ionic component to manage the focus state correctly.
  42. */
  43. updateTabindex() {
  44. // Ionic components that render a native anchor or button element
  45. const ionicComponents = [
  46. 'ION-BACK-BUTTON',
  47. 'ION-BREADCRUMB',
  48. 'ION-BUTTON',
  49. 'ION-CARD',
  50. 'ION-FAB-BUTTON',
  51. 'ION-ITEM',
  52. 'ION-ITEM-OPTION',
  53. 'ION-MENU-BUTTON',
  54. 'ION-SEGMENT-BUTTON',
  55. 'ION-TAB-BUTTON',
  56. ];
  57. const hostElement = this.elementRef.nativeElement;
  58. if (ionicComponents.includes(hostElement.tagName)) {
  59. if (hostElement.getAttribute('tabindex') === '0') {
  60. hostElement.removeAttribute('tabindex');
  61. }
  62. }
  63. }
  64. updateTargetUrlAndHref() {
  65. if (this.routerLink?.urlTree) {
  66. const href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.routerLink.urlTree));
  67. this.elementRef.nativeElement.href = href;
  68. }
  69. }
  70. /**
  71. * @internal
  72. */
  73. onClick(ev) {
  74. this.navCtrl.setDirection(this.routerDirection, undefined, undefined, this.routerAnimation);
  75. /**
  76. * This prevents the browser from
  77. * performing a page reload when pressing
  78. * an Ionic component with routerLink.
  79. * The page reload interferes with routing
  80. * and causes ion-back-button to disappear
  81. * since the local history is wiped on reload.
  82. */
  83. ev.preventDefault();
  84. }
  85. /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RouterLinkDelegateDirective, deps: [{ token: i1.LocationStrategy }, { token: i2.NavController }, { token: i0.ElementRef }, { token: i3.Router }, { token: i3.RouterLink, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
  86. /** @nocollapse */ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: RouterLinkDelegateDirective, selector: ":not(a):not(area)[routerLink]", inputs: { routerDirection: "routerDirection", routerAnimation: "routerAnimation" }, host: { listeners: { "click": "onClick($event)" } }, usesOnChanges: true, ngImport: i0 });
  87. }
  88. i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RouterLinkDelegateDirective, decorators: [{
  89. type: Directive,
  90. args: [{
  91. selector: ':not(a):not(area)[routerLink]',
  92. }]
  93. }], ctorParameters: function () { return [{ type: i1.LocationStrategy }, { type: i2.NavController }, { type: i0.ElementRef }, { type: i3.Router }, { type: i3.RouterLink, decorators: [{
  94. type: Optional
  95. }] }]; }, propDecorators: { routerDirection: [{
  96. type: Input
  97. }], routerAnimation: [{
  98. type: Input
  99. }], onClick: [{
  100. type: HostListener,
  101. args: ['click', ['$event']]
  102. }] } });
  103. export class RouterLinkWithHrefDelegateDirective {
  104. locationStrategy;
  105. navCtrl;
  106. elementRef;
  107. router;
  108. routerLink;
  109. routerDirection = 'forward';
  110. routerAnimation;
  111. constructor(locationStrategy, navCtrl, elementRef, router, routerLink) {
  112. this.locationStrategy = locationStrategy;
  113. this.navCtrl = navCtrl;
  114. this.elementRef = elementRef;
  115. this.router = router;
  116. this.routerLink = routerLink;
  117. }
  118. ngOnInit() {
  119. this.updateTargetUrlAndHref();
  120. }
  121. ngOnChanges() {
  122. this.updateTargetUrlAndHref();
  123. }
  124. updateTargetUrlAndHref() {
  125. if (this.routerLink?.urlTree) {
  126. const href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.routerLink.urlTree));
  127. this.elementRef.nativeElement.href = href;
  128. }
  129. }
  130. /**
  131. * @internal
  132. */
  133. onClick() {
  134. this.navCtrl.setDirection(this.routerDirection, undefined, undefined, this.routerAnimation);
  135. }
  136. /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RouterLinkWithHrefDelegateDirective, deps: [{ token: i1.LocationStrategy }, { token: i2.NavController }, { token: i0.ElementRef }, { token: i3.Router }, { token: i3.RouterLink, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
  137. /** @nocollapse */ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: RouterLinkWithHrefDelegateDirective, selector: "a[routerLink],area[routerLink]", inputs: { routerDirection: "routerDirection", routerAnimation: "routerAnimation" }, host: { listeners: { "click": "onClick()" } }, usesOnChanges: true, ngImport: i0 });
  138. }
  139. i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RouterLinkWithHrefDelegateDirective, decorators: [{
  140. type: Directive,
  141. args: [{
  142. selector: 'a[routerLink],area[routerLink]',
  143. }]
  144. }], ctorParameters: function () { return [{ type: i1.LocationStrategy }, { type: i2.NavController }, { type: i0.ElementRef }, { type: i3.Router }, { type: i3.RouterLink, decorators: [{
  145. type: Optional
  146. }] }]; }, propDecorators: { routerDirection: [{
  147. type: Input
  148. }], routerAnimation: [{
  149. type: Input
  150. }], onClick: [{
  151. type: HostListener,
  152. args: ['click']
  153. }] } });
  154. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router-link-delegate.js","sourceRoot":"","sources":["../../../../../common/src/directives/navigation/router-link-delegate.ts"],"names":[],"mappings":"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","sourcesContent":["import { LocationStrategy } from '@angular/common';\nimport { ElementRef, OnChanges, OnInit, Directive, HostListener, Input, Optional } from '@angular/core';\nimport { Router, RouterLink } from '@angular/router';\nimport type { AnimationBuilder, RouterDirection } from '@ionic/core/components';\n\nimport { NavController } from '../../providers/nav-controller';\n\n/**\n * Adds support for Ionic routing directions and animations to the base Angular router link directive.\n *\n * When the router link is clicked, the directive will assign the direction and\n * animation so that the routing integration will transition correctly.\n */\n@Directive({\n  selector: ':not(a):not(area)[routerLink]',\n})\nexport class RouterLinkDelegateDirective implements OnInit, OnChanges {\n  @Input()\n  routerDirection: RouterDirection = 'forward';\n\n  @Input()\n  routerAnimation?: AnimationBuilder;\n\n  constructor(\n    private locationStrategy: LocationStrategy,\n    private navCtrl: NavController,\n    private elementRef: ElementRef,\n    private router: Router,\n    @Optional() private routerLink?: RouterLink\n  ) {}\n\n  ngOnInit(): void {\n    this.updateTargetUrlAndHref();\n    this.updateTabindex();\n  }\n\n  ngOnChanges(): void {\n    this.updateTargetUrlAndHref();\n  }\n\n  /**\n   * The `tabindex` is set to `0` by default on the host element when\n   * the `routerLink` directive is used. This causes issues with Ionic\n   * components that wrap an `a` or `button` element, such as `ion-item`.\n   * See issue https://github.com/angular/angular/issues/28345\n   *\n   * This method removes the `tabindex` attribute from the host element\n   * to allow the Ionic component to manage the focus state correctly.\n   */\n  private updateTabindex() {\n    // Ionic components that render a native anchor or button element\n    const ionicComponents = [\n      'ION-BACK-BUTTON',\n      'ION-BREADCRUMB',\n      'ION-BUTTON',\n      'ION-CARD',\n      'ION-FAB-BUTTON',\n      'ION-ITEM',\n      'ION-ITEM-OPTION',\n      'ION-MENU-BUTTON',\n      'ION-SEGMENT-BUTTON',\n      'ION-TAB-BUTTON',\n    ];\n    const hostElement = this.elementRef.nativeElement;\n\n    if (ionicComponents.includes(hostElement.tagName)) {\n      if (hostElement.getAttribute('tabindex') === '0') {\n        hostElement.removeAttribute('tabindex');\n      }\n    }\n  }\n\n  private updateTargetUrlAndHref() {\n    if (this.routerLink?.urlTree) {\n      const href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.routerLink.urlTree));\n      this.elementRef.nativeElement.href = href;\n    }\n  }\n\n  /**\n   * @internal\n   */\n  @HostListener('click', ['$event'])\n  onClick(ev: UIEvent): void {\n    this.navCtrl.setDirection(this.routerDirection, undefined, undefined, this.routerAnimation);\n\n    /**\n     * This prevents the browser from\n     * performing a page reload when pressing\n     * an Ionic component with routerLink.\n     * The page reload interferes with routing\n     * and causes ion-back-button to disappear\n     * since the local history is wiped on reload.\n     */\n    ev.preventDefault();\n  }\n}\n\n@Directive({\n  selector: 'a[routerLink],area[routerLink]',\n})\nexport class RouterLinkWithHrefDelegateDirective implements OnInit, OnChanges {\n  @Input()\n  routerDirection: RouterDirection = 'forward';\n\n  @Input()\n  routerAnimation?: AnimationBuilder;\n\n  constructor(\n    private locationStrategy: LocationStrategy,\n    private navCtrl: NavController,\n    private elementRef: ElementRef,\n    private router: Router,\n    @Optional() private routerLink?: RouterLink\n  ) {}\n\n  ngOnInit(): void {\n    this.updateTargetUrlAndHref();\n  }\n\n  ngOnChanges(): void {\n    this.updateTargetUrlAndHref();\n  }\n\n  private updateTargetUrlAndHref() {\n    if (this.routerLink?.urlTree) {\n      const href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.routerLink.urlTree));\n      this.elementRef.nativeElement.href = href;\n    }\n  }\n\n  /**\n   * @internal\n   */\n  @HostListener('click')\n  onClick(): void {\n    this.navCtrl.setDirection(this.routerDirection, undefined, undefined, this.routerAnimation);\n  }\n}\n"]}