@taiga-ui/core 3.23.1-dev.main-d8b7500 → 3.23.1-dev.main-3d032b2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (184) hide show
  1. package/bundles/taiga-ui-core-components-alert.umd.js +5 -5
  2. package/bundles/taiga-ui-core-components-alert.umd.js.map +1 -1
  3. package/bundles/taiga-ui-core-components-button.umd.js +4 -4
  4. package/bundles/taiga-ui-core-components-button.umd.js.map +1 -1
  5. package/bundles/taiga-ui-core-components-data-list.umd.js +7 -7
  6. package/bundles/taiga-ui-core-components-data-list.umd.js.map +1 -1
  7. package/bundles/taiga-ui-core-components-dialog.umd.js +18 -11
  8. package/bundles/taiga-ui-core-components-dialog.umd.js.map +1 -1
  9. package/bundles/taiga-ui-core-components-expand.umd.js +3 -3
  10. package/bundles/taiga-ui-core-components-expand.umd.js.map +1 -1
  11. package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js +5 -5
  12. package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js.map +1 -1
  13. package/bundles/taiga-ui-core-components-link.umd.js +4 -4
  14. package/bundles/taiga-ui-core-components-link.umd.js.map +1 -1
  15. package/bundles/taiga-ui-core-components-loader.umd.js +6 -6
  16. package/bundles/taiga-ui-core-components-loader.umd.js.map +1 -1
  17. package/bundles/taiga-ui-core-components-primitive-textfield.umd.js +8 -8
  18. package/bundles/taiga-ui-core-components-primitive-textfield.umd.js.map +1 -1
  19. package/bundles/taiga-ui-core-components-root.umd.js +2 -10
  20. package/bundles/taiga-ui-core-components-root.umd.js.map +1 -1
  21. package/bundles/taiga-ui-core-components-scroll-controls.umd.js +14 -14
  22. package/bundles/taiga-ui-core-components-scroll-controls.umd.js.map +1 -1
  23. package/bundles/taiga-ui-core-components-scrollbar.umd.js +7 -7
  24. package/bundles/taiga-ui-core-components-scrollbar.umd.js.map +1 -1
  25. package/bundles/taiga-ui-core-components-svg.umd.js +10 -13
  26. package/bundles/taiga-ui-core-components-svg.umd.js.map +1 -1
  27. package/bundles/taiga-ui-core-directives-dropdown.umd.js +26 -30
  28. package/bundles/taiga-ui-core-directives-dropdown.umd.js.map +1 -1
  29. package/bundles/taiga-ui-core-directives-hint.umd.js +17 -19
  30. package/bundles/taiga-ui-core-directives-hint.umd.js.map +1 -1
  31. package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js +4 -4
  32. package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js.map +1 -1
  33. package/bundles/taiga-ui-core-directives-textfield-controller.umd.js +2 -2
  34. package/bundles/taiga-ui-core-directives-textfield-controller.umd.js.map +1 -1
  35. package/bundles/taiga-ui-core-internal-svg-defs-host.umd.js +3 -3
  36. package/bundles/taiga-ui-core-internal-svg-defs-host.umd.js.map +1 -1
  37. package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js +4 -4
  38. package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js.map +1 -1
  39. package/bundles/taiga-ui-core-pipes-format-phone.umd.js +2 -1
  40. package/bundles/taiga-ui-core-pipes-format-phone.umd.js.map +1 -1
  41. package/bundles/taiga-ui-core-providers.umd.js +2 -2
  42. package/bundles/taiga-ui-core-providers.umd.js.map +1 -1
  43. package/bundles/taiga-ui-core-services.umd.js +11 -10
  44. package/bundles/taiga-ui-core-services.umd.js.map +1 -1
  45. package/bundles/taiga-ui-core-tokens.umd.js +13 -9
  46. package/bundles/taiga-ui-core-tokens.umd.js.map +1 -1
  47. package/bundles/taiga-ui-core-utils-dom.umd.js +2 -2
  48. package/bundles/taiga-ui-core-utils-dom.umd.js.map +1 -1
  49. package/bundles/taiga-ui-core-utils-mask.umd.js +6 -5
  50. package/bundles/taiga-ui-core-utils-mask.umd.js.map +1 -1
  51. package/bundles/taiga-ui-core-utils-mobile.umd.js +2 -2
  52. package/bundles/taiga-ui-core-utils-mobile.umd.js.map +1 -1
  53. package/components/alert/alert.component.d.ts +2 -2
  54. package/components/button/button.component.d.ts +2 -2
  55. package/components/data-list/data-list.component.d.ts +2 -2
  56. package/components/data-list/option/option.component.d.ts +2 -2
  57. package/components/dialog/dialog-close.service.d.ts +4 -4
  58. package/components/dialog/dialog.component.d.ts +1 -0
  59. package/components/expand/expand.component.d.ts +2 -2
  60. package/components/hosted-dropdown/hosted-dropdown.component.d.ts +2 -2
  61. package/components/link/link.component.d.ts +2 -2
  62. package/components/loader/loader.component.d.ts +3 -3
  63. package/components/primitive-textfield/primitive-textfield.component.d.ts +2 -2
  64. package/components/primitive-textfield/textfield/textfield.component.d.ts +2 -2
  65. package/components/root/root.component.d.ts +1 -3
  66. package/components/scroll-controls/scroll-controls.component.d.ts +2 -2
  67. package/components/scroll-controls/scrollbar.directive.d.ts +4 -4
  68. package/components/scrollbar/scrollable.directive.d.ts +2 -2
  69. package/components/scrollbar/scrollbar.component.d.ts +2 -2
  70. package/components/svg/svg.component.d.ts +4 -4
  71. package/directives/dropdown/dropdown-selection.directive.d.ts +4 -4
  72. package/directives/dropdown/dropdown.component.d.ts +3 -3
  73. package/directives/dropdown/dropdown.directive.d.ts +2 -2
  74. package/directives/hint/hint-describe.directive.d.ts +3 -3
  75. package/directives/hint/hint-hover.directive.d.ts +2 -2
  76. package/directives/hint/hint.component.d.ts +2 -2
  77. package/directives/hint/hint.directive.d.ts +2 -2
  78. package/directives/scroll-into-view/scroll-into-view.directive.d.ts +2 -2
  79. package/esm2015/components/alert/alert.component.js +6 -6
  80. package/esm2015/components/button/button.component.js +5 -5
  81. package/esm2015/components/data-list/data-list.component.js +5 -5
  82. package/esm2015/components/data-list/option/option.component.js +4 -4
  83. package/esm2015/components/dialog/dialog-close.service.js +10 -10
  84. package/esm2015/components/dialog/dialog.component.js +6 -3
  85. package/esm2015/components/expand/expand.component.js +4 -4
  86. package/esm2015/components/hosted-dropdown/hosted-dropdown.component.js +6 -6
  87. package/esm2015/components/link/link.component.js +5 -5
  88. package/esm2015/components/loader/loader.component.js +7 -7
  89. package/esm2015/components/primitive-textfield/primitive-textfield.component.js +4 -4
  90. package/esm2015/components/primitive-textfield/textfield/textfield.component.js +6 -6
  91. package/esm2015/components/root/root.component.js +6 -14
  92. package/esm2015/components/scroll-controls/scroll-controls.component.js +5 -5
  93. package/esm2015/components/scroll-controls/scrollbar.directive.js +11 -11
  94. package/esm2015/components/scrollbar/scrollable.directive.js +5 -5
  95. package/esm2015/components/scrollbar/scrollbar.component.js +4 -4
  96. package/esm2015/components/svg/svg.component.js +11 -14
  97. package/esm2015/directives/dropdown/dropdown-selection.directive.js +15 -17
  98. package/esm2015/directives/dropdown/dropdown.component.js +9 -9
  99. package/esm2015/directives/dropdown/dropdown.directive.js +5 -7
  100. package/esm2015/directives/hint/hint-describe.directive.js +7 -8
  101. package/esm2015/directives/hint/hint-hover.directive.js +3 -3
  102. package/esm2015/directives/hint/hint.component.js +7 -8
  103. package/esm2015/directives/hint/hint.directive.js +4 -4
  104. package/esm2015/directives/scroll-into-view/scroll-into-view.directive.js +5 -5
  105. package/esm2015/directives/textfield-controller/textfield-controller.provider.js +3 -3
  106. package/esm2015/internal/svg-defs-host/svg-defs-host.component.js +4 -4
  107. package/esm2015/pipes/calendar-sheet/utils.js +5 -5
  108. package/esm2015/pipes/format-phone/format-phone.pipe.js +3 -2
  109. package/esm2015/providers/watched-controller-provider-factory.js +3 -3
  110. package/esm2015/services/breakpoint.service.js +5 -5
  111. package/esm2015/services/night-theme.service.js +3 -3
  112. package/esm2015/services/router-link-active.service.js +2 -1
  113. package/esm2015/services/svg.service.js +2 -2
  114. package/esm2015/services/visual-viewport.service.js +5 -5
  115. package/esm2015/tokens/assert-enabled.js +5 -1
  116. package/esm2015/tokens/is-mobile-resolution.js +3 -3
  117. package/esm2015/tokens/selection-stream.js +3 -3
  118. package/esm2015/tokens/viewport.js +6 -6
  119. package/esm2015/utils/dom/get-screen-width.js +3 -3
  120. package/esm2015/utils/mask/create-auto-corrected-money-pipe.js +2 -2
  121. package/esm2015/utils/mask/create-correction-mask.js +3 -2
  122. package/esm2015/utils/mask/create-number-mask.js +4 -4
  123. package/esm2015/utils/mobile/is-mobile.js +3 -3
  124. package/fesm2015/taiga-ui-core-components-alert.js +5 -5
  125. package/fesm2015/taiga-ui-core-components-alert.js.map +1 -1
  126. package/fesm2015/taiga-ui-core-components-button.js +4 -4
  127. package/fesm2015/taiga-ui-core-components-button.js.map +1 -1
  128. package/fesm2015/taiga-ui-core-components-data-list.js +7 -7
  129. package/fesm2015/taiga-ui-core-components-data-list.js.map +1 -1
  130. package/fesm2015/taiga-ui-core-components-dialog.js +14 -11
  131. package/fesm2015/taiga-ui-core-components-dialog.js.map +1 -1
  132. package/fesm2015/taiga-ui-core-components-expand.js +3 -3
  133. package/fesm2015/taiga-ui-core-components-expand.js.map +1 -1
  134. package/fesm2015/taiga-ui-core-components-hosted-dropdown.js +5 -5
  135. package/fesm2015/taiga-ui-core-components-hosted-dropdown.js.map +1 -1
  136. package/fesm2015/taiga-ui-core-components-link.js +4 -4
  137. package/fesm2015/taiga-ui-core-components-link.js.map +1 -1
  138. package/fesm2015/taiga-ui-core-components-loader.js +6 -6
  139. package/fesm2015/taiga-ui-core-components-loader.js.map +1 -1
  140. package/fesm2015/taiga-ui-core-components-primitive-textfield.js +8 -8
  141. package/fesm2015/taiga-ui-core-components-primitive-textfield.js.map +1 -1
  142. package/fesm2015/taiga-ui-core-components-root.js +5 -13
  143. package/fesm2015/taiga-ui-core-components-root.js.map +1 -1
  144. package/fesm2015/taiga-ui-core-components-scroll-controls.js +14 -14
  145. package/fesm2015/taiga-ui-core-components-scroll-controls.js.map +1 -1
  146. package/fesm2015/taiga-ui-core-components-scrollbar.js +7 -7
  147. package/fesm2015/taiga-ui-core-components-scrollbar.js.map +1 -1
  148. package/fesm2015/taiga-ui-core-components-svg.js +10 -13
  149. package/fesm2015/taiga-ui-core-components-svg.js.map +1 -1
  150. package/fesm2015/taiga-ui-core-directives-dropdown.js +26 -30
  151. package/fesm2015/taiga-ui-core-directives-dropdown.js.map +1 -1
  152. package/fesm2015/taiga-ui-core-directives-hint.js +17 -19
  153. package/fesm2015/taiga-ui-core-directives-hint.js.map +1 -1
  154. package/fesm2015/taiga-ui-core-directives-scroll-into-view.js +4 -4
  155. package/fesm2015/taiga-ui-core-directives-scroll-into-view.js.map +1 -1
  156. package/fesm2015/taiga-ui-core-directives-textfield-controller.js +2 -2
  157. package/fesm2015/taiga-ui-core-directives-textfield-controller.js.map +1 -1
  158. package/fesm2015/taiga-ui-core-internal-svg-defs-host.js +3 -3
  159. package/fesm2015/taiga-ui-core-internal-svg-defs-host.js.map +1 -1
  160. package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js +4 -4
  161. package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js.map +1 -1
  162. package/fesm2015/taiga-ui-core-pipes-format-phone.js +2 -1
  163. package/fesm2015/taiga-ui-core-pipes-format-phone.js.map +1 -1
  164. package/fesm2015/taiga-ui-core-providers.js +2 -2
  165. package/fesm2015/taiga-ui-core-providers.js.map +1 -1
  166. package/fesm2015/taiga-ui-core-services.js +12 -11
  167. package/fesm2015/taiga-ui-core-services.js.map +1 -1
  168. package/fesm2015/taiga-ui-core-tokens.js +13 -9
  169. package/fesm2015/taiga-ui-core-tokens.js.map +1 -1
  170. package/fesm2015/taiga-ui-core-utils-dom.js +2 -2
  171. package/fesm2015/taiga-ui-core-utils-dom.js.map +1 -1
  172. package/fesm2015/taiga-ui-core-utils-mask.js +6 -5
  173. package/fesm2015/taiga-ui-core-utils-mask.js.map +1 -1
  174. package/fesm2015/taiga-ui-core-utils-mobile.js +2 -2
  175. package/fesm2015/taiga-ui-core-utils-mobile.js.map +1 -1
  176. package/internal/svg-defs-host/svg-defs-host.component.d.ts +2 -2
  177. package/package.json +1 -1
  178. package/providers/watched-controller-provider-factory.d.ts +1 -1
  179. package/services/breakpoint.service.d.ts +1 -1
  180. package/services/night-theme.service.d.ts +1 -1
  181. package/services/visual-viewport.service.d.ts +2 -2
  182. package/tokens/assert-enabled.d.ts +4 -0
  183. package/utils/dom/get-screen-width.d.ts +1 -1
  184. package/utils/mobile/is-mobile.d.ts +1 -1
@@ -1,14 +1,12 @@
1
- import { ElementRef } from '@angular/core';
2
1
  import { Observable } from 'rxjs';
3
2
  import * as i0 from "@angular/core";
4
3
  export declare class TuiRootComponent {
5
4
  readonly duration: number;
6
- readonly elementRef: ElementRef<HTMLElement>;
7
5
  readonly dialogs: ReadonlyArray<Observable<readonly unknown[]>>;
8
6
  private readonly isMobile;
9
7
  readonly isMobileRes$: Observable<boolean>;
10
8
  readonly scrollbars$: Observable<boolean>;
11
- constructor(duration: number, elementRef: ElementRef<HTMLElement>, dialogs: ReadonlyArray<Observable<readonly unknown[]>>, isMobile: boolean, enabled: boolean, isMobileRes$: Observable<boolean>, { body }: Document, theme: string);
9
+ constructor(duration: number, dialogs: ReadonlyArray<Observable<readonly unknown[]>>, isMobile: boolean, isMobileRes$: Observable<boolean>, { body }: Document, theme: string);
12
10
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiRootComponent, never>;
13
11
  static ɵcmp: i0.ɵɵComponentDeclaration<TuiRootComponent, "tui-root", never, {}, {}, never, ["*", "tuiOverContent", "tuiOverDialogs", "tuiOverAlerts", "tuiOverPortals", "tuiOverHints"]>;
14
12
  }
@@ -6,7 +6,7 @@ import * as i0 from "@angular/core";
6
6
  export declare class TuiScrollControlsComponent {
7
7
  private readonly options;
8
8
  private readonly ngZone;
9
- private readonly documentRef;
9
+ private readonly doc;
10
10
  private readonly scrollRef;
11
11
  private readonly animationFrame$;
12
12
  readonly mode$: Observable<TuiBrightness | null>;
@@ -18,7 +18,7 @@ export declare class TuiScrollControlsComponent {
18
18
  } | undefined;
19
19
  readonly value: "";
20
20
  };
21
- constructor(options: AnimationOptions, ngZone: NgZone, documentRef: Document, scrollRef: ElementRef<HTMLElement> | null, animationFrame$: Observable<number>, mode$: Observable<TuiBrightness | null>);
21
+ constructor(options: AnimationOptions, ngZone: NgZone, doc: Document, scrollRef: ElementRef<HTMLElement> | null, animationFrame$: Observable<number>, mode$: Observable<TuiBrightness | null>);
22
22
  private get scrollbars();
23
23
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiScrollControlsComponent, [null, null, null, { optional: true; }, null, null]>;
24
24
  static ɵcmp: i0.ɵɵComponentDeclaration<TuiScrollControlsComponent, "tui-scroll-controls", never, {}, {}, never, never>;
@@ -6,12 +6,12 @@ import * as i0 from "@angular/core";
6
6
  export declare class TuiScrollbarDirective {
7
7
  private readonly wrapper;
8
8
  private readonly container;
9
- private readonly documentRef;
10
- private readonly windowRef;
11
- private readonly elementRef;
9
+ private readonly doc;
10
+ private readonly win;
11
+ private readonly el;
12
12
  private readonly viewportScroller;
13
13
  tuiScrollbar: TuiOrientation;
14
- constructor(ngZone: NgZone, renderer: Renderer2, destroy$: Observable<void>, animationFrame$: Observable<number>, wrapper: ElementRef<HTMLElement>, container: ElementRef<HTMLElement> | null, documentRef: Document, windowRef: Window, elementRef: ElementRef<HTMLElement>, viewportScroller: ViewportScroller);
14
+ constructor(ngZone: NgZone, renderer: Renderer2, destroy$: Observable<void>, animationFrame$: Observable<number>, wrapper: ElementRef<HTMLElement>, container: ElementRef<HTMLElement> | null, doc: Document, win: Window, el: ElementRef<HTMLElement>, viewportScroller: ViewportScroller);
15
15
  private get scrolled();
16
16
  private get compensation();
17
17
  private get thumb();
@@ -1,8 +1,8 @@
1
1
  import { ElementRef, OnInit } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class TuiScrollableDirective implements OnInit {
4
- private readonly elementRef;
5
- constructor(elementRef: ElementRef<HTMLElement>);
4
+ private readonly el;
5
+ constructor(el: ElementRef<HTMLElement>);
6
6
  ngOnInit(): void;
7
7
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiScrollableDirective, never>;
8
8
  static ɵdir: i0.ɵɵDirectiveDeclaration<TuiScrollableDirective, "[tuiScrollable]", never, {}, {}, never>;
@@ -4,14 +4,14 @@ import { TuiInjectionTokenType } from '@taiga-ui/cdk';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class TuiScrollbarComponent {
6
6
  private readonly cssRef;
7
- private readonly elementRef;
7
+ private readonly el;
8
8
  private readonly userAgent;
9
9
  private readonly isIos;
10
10
  private delegated;
11
11
  private readonly isLegacy;
12
12
  hidden: boolean;
13
13
  readonly browserScrollRef: ElementRef<HTMLElement>;
14
- constructor(cssRef: TuiInjectionTokenType<typeof CSS_TOKEN>, elementRef: ElementRef<HTMLElement>, userAgent: string, isIos: boolean);
14
+ constructor(cssRef: TuiInjectionTokenType<typeof CSS_TOKEN>, el: ElementRef<HTMLElement>, userAgent: string, isIos: boolean);
15
15
  get showScrollbars(): boolean;
16
16
  get showNative(): boolean;
17
17
  onScrollable(element: HTMLElement): void;
@@ -6,18 +6,18 @@ import { Observable } from 'rxjs';
6
6
  import { TuiSvgOptions } from './svg-options';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class TuiSvgComponent {
9
- private readonly documentRef;
10
- private readonly windowRef;
9
+ private readonly doc;
10
+ private readonly win;
11
11
  private readonly options;
12
12
  private readonly tuiSanitizer;
13
13
  private readonly svgService;
14
14
  private readonly staticRequestService;
15
15
  private readonly sanitizer;
16
- private readonly elementRef;
16
+ private readonly el;
17
17
  private readonly src$;
18
18
  private icon;
19
19
  readonly innerHTML$: Observable<SafeHtml>;
20
- constructor(documentRef: Document, windowRef: Window, options: TuiSvgOptions, tuiSanitizer: Sanitizer | null, svgService: TuiSvgService, staticRequestService: TuiStaticRequestService, sanitizer: DomSanitizer, elementRef: ElementRef<Element>);
20
+ constructor(doc: Document, win: Window, options: TuiSvgOptions, tuiSanitizer: Sanitizer | null, svgService: TuiSvgService, staticRequestService: TuiStaticRequestService, sanitizer: DomSanitizer, el: ElementRef<Element>);
21
21
  set src(src: SafeHtml | string);
22
22
  get src(): SafeHtml | string;
23
23
  get use(): string;
@@ -6,10 +6,10 @@ import { TuiDropdownDirective } from './dropdown.directive';
6
6
  import * as i0 from "@angular/core";
7
7
  export declare class TuiDropdownSelectionDirective extends TuiDriver implements TuiRectAccessor, OnDestroy {
8
8
  private range;
9
- private readonly documentRef;
9
+ private readonly doc;
10
10
  private readonly selection$;
11
- private readonly elementRef;
12
- private readonly viewContainerRef;
11
+ private readonly el;
12
+ private readonly vcr;
13
13
  private readonly dropdown;
14
14
  private readonly handler$;
15
15
  private readonly stream$;
@@ -17,7 +17,7 @@ export declare class TuiDropdownSelectionDirective extends TuiDriver implements
17
17
  position: 'selection' | 'tag' | 'word';
18
18
  set tuiDropdownSelection(visible: TuiBooleanHandler<Range> | string);
19
19
  readonly type = "dropdown";
20
- constructor(range: Range, documentRef: Document, selection$: Observable<unknown>, elementRef: ElementRef<HTMLElement>, viewContainerRef: ViewContainerRef, dropdown: TuiDropdownDirective);
20
+ constructor(range: Range, doc: Document, selection$: Observable<unknown>, el: ElementRef<HTMLElement>, vcr: ViewContainerRef, dropdown: TuiDropdownDirective);
21
21
  getClientRect(): ClientRect;
22
22
  ngOnDestroy(): void;
23
23
  private getRange;
@@ -17,10 +17,10 @@ import * as i0 from "@angular/core";
17
17
  */
18
18
  export declare class TuiDropdownComponent implements OnDestroy {
19
19
  readonly directive: TuiDropdownDirective;
20
- private readonly elementRef;
20
+ private readonly el;
21
21
  private readonly host;
22
22
  private readonly accessor;
23
- private readonly windowRef;
23
+ private readonly win;
24
24
  private readonly animationOptions;
25
25
  private readonly options;
26
26
  private readonly hoverDirective;
@@ -31,7 +31,7 @@ export declare class TuiDropdownComponent implements OnDestroy {
31
31
  } | undefined;
32
32
  value: TuiDropdownAnimation;
33
33
  };
34
- constructor(position$: Observable<TuiPoint>, destroy$: Observable<void>, directive: TuiDropdownDirective, elementRef: ElementRef<HTMLElement>, host: AbstractTuiPortalHostComponent, accessor: TuiRectAccessor, windowRef: Window, animationOptions: AnimationOptions, options: TuiDropdownOptions, hoverDirective: TuiDropdownHoverDirective | null, visualViewportService: TuiVisualViewportService);
34
+ constructor(position$: Observable<TuiPoint>, destroy$: Observable<void>, directive: TuiDropdownDirective, el: ElementRef<HTMLElement>, host: AbstractTuiPortalHostComponent, accessor: TuiRectAccessor, win: Window, animationOptions: AnimationOptions, options: TuiDropdownOptions, hoverDirective: TuiDropdownHoverDirective | null, visualViewportService: TuiVisualViewportService);
35
35
  ngOnDestroy(): void;
36
36
  onHoveredChange(hovered: boolean): void;
37
37
  onTopFocus(): void;
@@ -5,7 +5,7 @@ import { TuiPortalItem } from '@taiga-ui/core/interfaces';
5
5
  import { PolymorpheusComponent, PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
6
6
  import * as i0 from "@angular/core";
7
7
  export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy, OnChanges, TuiPortalItem, TuiRectAccessor, TuiVehicle {
8
- readonly elementRef: ElementRef<HTMLElement>;
8
+ readonly el: ElementRef<HTMLElement>;
9
9
  private readonly hapica;
10
10
  private readonly injector;
11
11
  private readonly dropdownService;
@@ -13,7 +13,7 @@ export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy
13
13
  dropdownBoxRef: ComponentRef<unknown> | null;
14
14
  readonly type = "dropdown";
15
15
  readonly component: PolymorpheusComponent<unknown, unknown>;
16
- constructor(elementRef: ElementRef<HTMLElement>, hapica: Type<unknown>, injector: Injector, dropdownService: TuiDropdownPortalService);
16
+ constructor(el: ElementRef<HTMLElement>, hapica: Type<unknown>, injector: Injector, dropdownService: TuiDropdownPortalService);
17
17
  get position(): 'absolute' | 'fixed';
18
18
  ngAfterViewChecked(): void;
19
19
  ngOnChanges(): void;
@@ -3,12 +3,12 @@ import { TuiDriver } from '@taiga-ui/core/abstract';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class TuiHintDescribeDirective extends TuiDriver {
5
5
  private readonly ngZone;
6
- private readonly documentRef;
7
- private readonly elementRef;
6
+ private readonly doc;
7
+ private readonly el;
8
8
  private readonly stream$;
9
9
  tuiHintDescribe: string | '';
10
10
  readonly type = "hint";
11
- constructor(ngZone: NgZone, documentRef: Document, elementRef: ElementRef<HTMLElement>);
11
+ constructor(ngZone: NgZone, doc: Document, el: ElementRef<HTMLElement>);
12
12
  private get focused();
13
13
  private get element();
14
14
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintDescribeDirective, never>;
@@ -6,7 +6,7 @@ import * as i0 from "@angular/core";
6
6
  export declare class TuiHintHoverDirective extends TuiDriver {
7
7
  private readonly hovered$;
8
8
  private readonly options;
9
- readonly elementRef: ElementRef<HTMLElement>;
9
+ readonly el: ElementRef<HTMLElement>;
10
10
  private visible;
11
11
  private readonly toggle$;
12
12
  private readonly stream$;
@@ -14,7 +14,7 @@ export declare class TuiHintHoverDirective extends TuiDriver {
14
14
  hideDelay: TuiHintOptions['hideDelay'];
15
15
  readonly type = "hint";
16
16
  enabled: boolean;
17
- constructor(hovered$: Observable<boolean>, options: TuiHintOptions, elementRef: ElementRef<HTMLElement>);
17
+ constructor(hovered$: Observable<boolean>, options: TuiHintOptions, el: ElementRef<HTMLElement>);
18
18
  toggle(visible?: boolean): void;
19
19
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintHoverDirective, never>;
20
20
  static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintHoverDirective, "[tuiHint]:not(ng-container)", ["tuiHintHover"], { "showDelay": "tuiHintShowDelay"; "hideDelay": "tuiHintHideDelay"; }, {}, never>;
@@ -12,7 +12,7 @@ import { TuiHintHoverDirective } from './hint-hover.directive';
12
12
  import * as i0 from "@angular/core";
13
13
  export declare class TuiHintComponent<C = any> {
14
14
  protected readonly accessor: TuiRectAccessor;
15
- private readonly elementRef;
15
+ private readonly el;
16
16
  private readonly options;
17
17
  private readonly polymorpheus;
18
18
  private readonly hover;
@@ -28,7 +28,7 @@ export declare class TuiHintComponent<C = any> {
28
28
  };
29
29
  readonly appearance: string | null | undefined;
30
30
  readonly untouchable: boolean;
31
- constructor(hovered$: Observable<boolean>, position$: Observable<TuiPoint>, destroy$: Observable<void>, accessor: TuiRectAccessor, elementRef: ElementRef<HTMLElement>, options: AnimationOptions, polymorpheus: TuiContextWithImplicit<TuiPortalItem<C>>, hover: TuiHintHoverDirective, pointer: unknown, mode: TuiModeDirective | null, visualViewportService: TuiVisualViewportService);
31
+ constructor(hovered$: Observable<boolean>, position$: Observable<TuiPoint>, destroy$: Observable<void>, accessor: TuiRectAccessor, el: ElementRef<HTMLElement>, options: AnimationOptions, polymorpheus: TuiContextWithImplicit<TuiPortalItem<C>>, hover: TuiHintHoverDirective, pointer: unknown, mode: TuiModeDirective | null, visualViewportService: TuiVisualViewportService);
32
32
  get content(): PolymorpheusContent<C>;
33
33
  get context(): C | undefined;
34
34
  onClick(target: HTMLElement): void;
@@ -7,7 +7,7 @@ import { PolymorpheusComponent, PolymorpheusContent } from '@tinkoff/ng-polymorp
7
7
  import { TuiHintOptions } from './hint-options.directive';
8
8
  import * as i0 from "@angular/core";
9
9
  export declare class TuiHintDirective<C> implements OnDestroy, OnChanges, TuiPortalItem<C>, TuiRectAccessor, TuiVehicle {
10
- private readonly elementRef;
10
+ private readonly el;
11
11
  readonly component: PolymorpheusComponent<unknown, any>;
12
12
  private readonly hintService;
13
13
  private readonly options;
@@ -16,7 +16,7 @@ export declare class TuiHintDirective<C> implements OnDestroy, OnChanges, TuiPor
16
16
  context?: C;
17
17
  tuiHintAppearance: string | null;
18
18
  readonly type = "hint";
19
- constructor(elementRef: ElementRef<HTMLElement>, component: PolymorpheusComponent<unknown, any>, hintService: TuiHintService, options: TuiHintOptions, activeZone?: TuiActiveZoneDirective | null | undefined);
19
+ constructor(el: ElementRef<HTMLElement>, component: PolymorpheusComponent<unknown, any>, hintService: TuiHintService, options: TuiHintOptions, activeZone?: TuiActiveZoneDirective | null | undefined);
20
20
  get appearance(): string;
21
21
  ngOnChanges(): void;
22
22
  ngOnDestroy(): void;
@@ -5,10 +5,10 @@ import * as i0 from "@angular/core";
5
5
  * Directive scrolls element into view inside tui-scrollbar
6
6
  */
7
7
  export declare class TuiScrollIntoViewDirective {
8
- private readonly elementRef;
8
+ private readonly el;
9
9
  private readonly destroy$;
10
10
  set tuiScrollIntoView(scroll: boolean);
11
- constructor(elementRef: ElementRef<Element>, destroy$: Observable<void>);
11
+ constructor(el: ElementRef<Element>, destroy$: Observable<void>);
12
12
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiScrollIntoViewDirective, [null, { self: true; }]>;
13
13
  static ɵdir: i0.ɵɵDirectiveDeclaration<TuiScrollIntoViewDirective, "[tuiScrollIntoView]", never, { "tuiScrollIntoView": "tuiScrollIntoView"; }, {}, never>;
14
14
  }
@@ -12,8 +12,8 @@ import * as i3 from "@tinkoff/ng-polymorpheus";
12
12
  import * as i4 from "@taiga-ui/cdk";
13
13
  // TODO: get rid of $any in template
14
14
  export class TuiAlertComponent {
15
- constructor(elementRef, destroy$, options, animationOptions, item) {
16
- this.elementRef = elementRef;
15
+ constructor(el, destroy$, options, animationOptions, item) {
16
+ this.el = el;
17
17
  this.destroy$ = destroy$;
18
18
  this.options = options;
19
19
  this.animationOptions = animationOptions;
@@ -36,17 +36,17 @@ export class TuiAlertComponent {
36
36
  timer(tuiIsNumber(this.autoClose)
37
37
  ? this.autoClose
38
38
  : this.options.defaultAutoCloseTime)
39
- .pipe(takeUntil(fromEvent(this.elementRef.nativeElement, 'mouseenter')),
39
+ .pipe(takeUntil(fromEvent(this.el.nativeElement, 'mouseenter')),
40
40
  /**
41
41
  * TODO: replace to
42
42
  * repeat({
43
- * delay: () => fromEvent(this.elementRef.nativeElement, 'mouseleave'),
43
+ * delay: () => fromEvent(this.el.nativeElement, 'mouseleave'),
44
44
  * })
45
45
  *
46
46
  * in RxJS 7
47
47
  */
48
48
  // eslint-disable-next-line rxjs/no-ignored-notifier
49
- repeatWhen(() => fromEvent(this.elementRef.nativeElement, 'mouseleave')), takeUntil(this.destroy$))
49
+ repeatWhen(() => fromEvent(this.el.nativeElement, 'mouseleave')), takeUntil(this.destroy$))
50
50
  .subscribe(() => this.closeNotification());
51
51
  }
52
52
  }
@@ -90,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
90
90
  type: HostBinding,
91
91
  args: ['@tuiHeightCollapse']
92
92
  }] } });
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/alert/alert.component.ts","../../../../../projects/core/components/alert/alert.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AnimationOptions} from '@angular/animations';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Inject,\n    OnInit,\n    Self,\n} from '@angular/core';\nimport {TuiDestroyService, TuiDialog, tuiIsNumber} from '@taiga-ui/cdk';\nimport {tuiFadeIn, tuiHeightCollapse, tuiSlideInRight} from '@taiga-ui/core/animations';\nimport {TuiAlertOptions} from '@taiga-ui/core/interfaces';\nimport {\n    TUI_ANIMATION_OPTIONS,\n    TUI_NOTIFICATION_OPTIONS,\n    TuiNotificationDefaultOptions,\n} from '@taiga-ui/core/tokens';\nimport {POLYMORPHEUS_CONTEXT} from '@tinkoff/ng-polymorpheus';\nimport {fromEvent, timer} from 'rxjs';\nimport {repeatWhen, takeUntil} from 'rxjs/operators';\n\n// TODO: get rid of $any in template\n@Component({\n    selector: 'tui-alert',\n    templateUrl: './alert.template.html',\n    styleUrls: ['./alert.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [TuiDestroyService],\n    animations: [tuiFadeIn, tuiSlideInRight, tuiHeightCollapse],\n    host: {role: 'alert'},\n})\nexport class TuiAlertComponent<O, I> implements OnInit {\n    private readonly autoClose =\n        typeof this.item.autoClose === 'function'\n            ? this.item.autoClose(this.item.status)\n            : this.item.autoClose;\n\n    @HostBinding('@tuiFadeIn')\n    @HostBinding('@tuiSlideInRight')\n    @HostBinding('@tuiHeightCollapse')\n    readonly animation = {value: '', ...this.animationOptions} as const;\n\n    constructor(\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Self() @Inject(TuiDestroyService) private readonly destroy$: TuiDestroyService,\n        @Inject(TUI_NOTIFICATION_OPTIONS)\n        private readonly options: TuiNotificationDefaultOptions,\n        @Inject(TUI_ANIMATION_OPTIONS)\n        private readonly animationOptions: AnimationOptions,\n        @Inject(POLYMORPHEUS_CONTEXT) readonly item: TuiDialog<TuiAlertOptions<I>, O>,\n    ) {}\n\n    ngOnInit(): void {\n        this.initAutoClose();\n    }\n\n    closeNotification(): void {\n        this.item.$implicit.complete();\n    }\n\n    private initAutoClose(): void {\n        if (!this.autoClose) {\n            return;\n        }\n\n        timer(\n            tuiIsNumber(this.autoClose)\n                ? this.autoClose\n                : this.options.defaultAutoCloseTime,\n        )\n            .pipe(\n                takeUntil(fromEvent(this.elementRef.nativeElement, 'mouseenter')),\n                /**\n                 * TODO: replace to\n                 * repeat({\n                 *    delay: () => fromEvent(this.elementRef.nativeElement, 'mouseleave'),\n                 * })\n                 *\n                 * in RxJS 7\n                 */\n                // eslint-disable-next-line rxjs/no-ignored-notifier\n                repeatWhen(() => fromEvent(this.elementRef.nativeElement, 'mouseleave')),\n                takeUntil(this.destroy$),\n            )\n            .subscribe(() => this.closeNotification());\n    }\n}\n","<tui-notification\n    *ngIf=\"item.hasCloseButton; else noClose\"\n    [status]=\"item.status\"\n    [hasIcon]=\"item.hasIcon\"\n    (close)=\"closeNotification()\"\n>\n    <label\n        *ngIf=\"item.label\"\n        automation-id=\"tui-notification-alert__heading\"\n        class=\"t-heading\"\n    >\n        <!-- TODO: Polymorpheus fix type -->\n        <ng-container *polymorpheusOutlet=\"$any(item.label) as text; context: item\">\n            {{ text }}\n        </ng-container>\n    </label>\n    <div\n        automation-id=\"tui-notification-alert__content\"\n        class=\"t-content\"\n    >\n        <!-- TODO: Polymorpheus fix type -->\n        <ng-container *polymorpheusOutlet=\"item.content as text; context: $any(item)\">\n            {{ text }}\n        </ng-container>\n    </div>\n</tui-notification>\n<ng-template #noClose>\n    <tui-notification\n        [status]=\"item.status\"\n        [hasIcon]=\"item.hasIcon\"\n    >\n        <label\n            *ngIf=\"item.label\"\n            automation-id=\"tui-notification-alert__heading\"\n            class=\"t-heading\"\n        >\n            <!-- TODO: Polymorpheus fix type -->\n            <ng-container *polymorpheusOutlet=\"$any(item.label) as text; context: item\">\n                {{ text }}\n            </ng-container>\n        </label>\n        <div\n            automation-id=\"tui-notification-alert__content\"\n            class=\"t-content\"\n        >\n            <!-- TODO: Polymorpheus fix type -->\n            <ng-container *polymorpheusOutlet=\"item.content as text; context: $any(item)\">\n                {{ text }}\n            </ng-container>\n        </div>\n    </tui-notification>\n</ng-template>\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/alert/alert.component.ts","../../../../../projects/core/components/alert/alert.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AnimationOptions} from '@angular/animations';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Inject,\n    OnInit,\n    Self,\n} from '@angular/core';\nimport {TuiDestroyService, TuiDialog, tuiIsNumber} from '@taiga-ui/cdk';\nimport {tuiFadeIn, tuiHeightCollapse, tuiSlideInRight} from '@taiga-ui/core/animations';\nimport {TuiAlertOptions} from '@taiga-ui/core/interfaces';\nimport {\n    TUI_ANIMATION_OPTIONS,\n    TUI_NOTIFICATION_OPTIONS,\n    TuiNotificationDefaultOptions,\n} from '@taiga-ui/core/tokens';\nimport {POLYMORPHEUS_CONTEXT} from '@tinkoff/ng-polymorpheus';\nimport {fromEvent, timer} from 'rxjs';\nimport {repeatWhen, takeUntil} from 'rxjs/operators';\n\n// TODO: get rid of $any in template\n@Component({\n    selector: 'tui-alert',\n    templateUrl: './alert.template.html',\n    styleUrls: ['./alert.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [TuiDestroyService],\n    animations: [tuiFadeIn, tuiSlideInRight, tuiHeightCollapse],\n    host: {role: 'alert'},\n})\nexport class TuiAlertComponent<O, I> implements OnInit {\n    private readonly autoClose =\n        typeof this.item.autoClose === 'function'\n            ? this.item.autoClose(this.item.status)\n            : this.item.autoClose;\n\n    @HostBinding('@tuiFadeIn')\n    @HostBinding('@tuiSlideInRight')\n    @HostBinding('@tuiHeightCollapse')\n    readonly animation = {value: '', ...this.animationOptions} as const;\n\n    constructor(\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Self() @Inject(TuiDestroyService) private readonly destroy$: TuiDestroyService,\n        @Inject(TUI_NOTIFICATION_OPTIONS)\n        private readonly options: TuiNotificationDefaultOptions,\n        @Inject(TUI_ANIMATION_OPTIONS)\n        private readonly animationOptions: AnimationOptions,\n        @Inject(POLYMORPHEUS_CONTEXT) readonly item: TuiDialog<TuiAlertOptions<I>, O>,\n    ) {}\n\n    ngOnInit(): void {\n        this.initAutoClose();\n    }\n\n    closeNotification(): void {\n        this.item.$implicit.complete();\n    }\n\n    private initAutoClose(): void {\n        if (!this.autoClose) {\n            return;\n        }\n\n        timer(\n            tuiIsNumber(this.autoClose)\n                ? this.autoClose\n                : this.options.defaultAutoCloseTime,\n        )\n            .pipe(\n                takeUntil(fromEvent(this.el.nativeElement, 'mouseenter')),\n                /**\n                 * TODO: replace to\n                 * repeat({\n                 *    delay: () => fromEvent(this.el.nativeElement, 'mouseleave'),\n                 * })\n                 *\n                 * in RxJS 7\n                 */\n                // eslint-disable-next-line rxjs/no-ignored-notifier\n                repeatWhen(() => fromEvent(this.el.nativeElement, 'mouseleave')),\n                takeUntil(this.destroy$),\n            )\n            .subscribe(() => this.closeNotification());\n    }\n}\n","<tui-notification\n    *ngIf=\"item.hasCloseButton; else noClose\"\n    [status]=\"item.status\"\n    [hasIcon]=\"item.hasIcon\"\n    (close)=\"closeNotification()\"\n>\n    <label\n        *ngIf=\"item.label\"\n        automation-id=\"tui-notification-alert__heading\"\n        class=\"t-heading\"\n    >\n        <!-- TODO: Polymorpheus fix type -->\n        <ng-container *polymorpheusOutlet=\"$any(item.label) as text; context: item\">\n            {{ text }}\n        </ng-container>\n    </label>\n    <div\n        automation-id=\"tui-notification-alert__content\"\n        class=\"t-content\"\n    >\n        <!-- TODO: Polymorpheus fix type -->\n        <ng-container *polymorpheusOutlet=\"item.content as text; context: $any(item)\">\n            {{ text }}\n        </ng-container>\n    </div>\n</tui-notification>\n<ng-template #noClose>\n    <tui-notification\n        [status]=\"item.status\"\n        [hasIcon]=\"item.hasIcon\"\n    >\n        <label\n            *ngIf=\"item.label\"\n            automation-id=\"tui-notification-alert__heading\"\n            class=\"t-heading\"\n        >\n            <!-- TODO: Polymorpheus fix type -->\n            <ng-container *polymorpheusOutlet=\"$any(item.label) as text; context: item\">\n                {{ text }}\n            </ng-container>\n        </label>\n        <div\n            automation-id=\"tui-notification-alert__content\"\n            class=\"t-content\"\n        >\n            <!-- TODO: Polymorpheus fix type -->\n            <ng-container *polymorpheusOutlet=\"item.content as text; context: $any(item)\">\n                {{ text }}\n            </ng-container>\n        </div>\n    </tui-notification>\n</ng-template>\n"]}
@@ -14,11 +14,11 @@ import * as i5 from "@tinkoff/ng-polymorpheus";
14
14
  import * as i6 from "@taiga-ui/core/directives";
15
15
  import * as i7 from "@taiga-ui/cdk";
16
16
  export class TuiButtonComponent extends AbstractTuiInteractive {
17
- constructor(mode, elementRef, focusVisible$, options) {
17
+ constructor(mode, el, focusVisible$, options) {
18
18
  var _a;
19
19
  super();
20
20
  this.mode = mode;
21
- this.elementRef = elementRef;
21
+ this.el = el;
22
22
  this.options = options;
23
23
  this.mode$ = ((_a = this.mode) === null || _a === void 0 ? void 0 : _a.change$) || EMPTY;
24
24
  this.appearance = null;
@@ -34,10 +34,10 @@ export class TuiButtonComponent extends AbstractTuiInteractive {
34
34
  });
35
35
  }
36
36
  get nativeFocusableElement() {
37
- return this.nativeDisabled ? null : this.elementRef.nativeElement;
37
+ return this.nativeDisabled ? null : this.el.nativeElement;
38
38
  }
39
39
  get focused() {
40
- return !this.showLoader && tuiIsNativeFocused(this.elementRef.nativeElement);
40
+ return !this.showLoader && tuiIsNativeFocused(this.el.nativeElement);
41
41
  }
42
42
  get loaderSize() {
43
43
  return this.size === 'l' || this.size === 'xl' ? 'm' : 's';
@@ -149,4 +149,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
149
149
  type: HostListener,
150
150
  args: ['focusout', ['false']]
151
151
  }] } });
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/button/button.component.ts","../../../../../projects/core/components/button/button.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n} from '@angular/core';\nimport {\n    AbstractTuiInteractive,\n    tuiAsFocusableItemAccessor,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiFocusableElementAccessor,\n    TuiFocusVisibleService,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiModeDirective} from '@taiga-ui/core/directives';\nimport {TuiSizeS} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {EMPTY, Observable} from 'rxjs';\nimport {distinctUntilChanged, map, startWith} from 'rxjs/operators';\n\nimport {TUI_BUTTON_OPTIONS, TuiButtonOptions} from './button-options';\n\n@Component({\n    selector: 'button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]',\n    templateUrl: './button.template.html',\n    styleUrls: ['./button.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiButtonComponent),\n        TuiDestroyService,\n        TuiFocusVisibleService,\n    ],\n})\nexport class TuiButtonComponent\n    extends AbstractTuiInteractive\n    implements TuiFocusableElementAccessor, TuiButtonOptions\n{\n    private readonly mode$: Observable<unknown> = this.mode?.change$ || EMPTY;\n\n    @Input()\n    @tuiDefaultProp()\n    appearance: TuiButtonOptions['appearance'] = null;\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    @tuiDefaultProp()\n    icon: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    iconRight: PolymorpheusContent = '';\n\n    @Input()\n    @HostBinding('attr.data-shape')\n    @tuiDefaultProp()\n    shape = this.options.shape;\n\n    @Input()\n    @HostBinding('class._loading')\n    @tuiDefaultProp()\n    showLoader = false;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    @tuiDefaultProp()\n    size = this.options.size;\n\n    readonly appearance$ = this.mode$.pipe(\n        startWith(null),\n        map(() => this.computedAppearance),\n        distinctUntilChanged(),\n    );\n\n    constructor(\n        @Optional()\n        @Inject(TuiModeDirective)\n        private readonly mode: TuiModeDirective | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(TuiFocusVisibleService) focusVisible$: TuiFocusVisibleService,\n        @Inject(TUI_BUTTON_OPTIONS) private readonly options: TuiButtonOptions,\n    ) {\n        super();\n        focusVisible$.subscribe(focusVisible => {\n            this.updateFocusVisible(focusVisible);\n        });\n    }\n\n    get nativeFocusableElement(): HTMLElement | null {\n        return this.nativeDisabled ? null : this.elementRef.nativeElement;\n    }\n\n    get focused(): boolean {\n        return !this.showLoader && tuiIsNativeFocused(this.elementRef.nativeElement);\n    }\n\n    get loaderSize(): TuiSizeS {\n        return this.size === 'l' || this.size === 'xl' ? 'm' : 's';\n    }\n\n    @HostBinding('attr.data-appearance')\n    get computedAppearance(): string {\n        return this.appearance ?? (this.options.appearance || '');\n    }\n\n    @HostBinding('attr.disabled')\n    get nativeDisabled(): '' | null {\n        return this.computedDisabled || this.showLoader ? '' : null;\n    }\n\n    @HostBinding('tabIndex')\n    get tabIndex(): number {\n        return this.focusable ? 0 : -1;\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n}\n","<ng-container *ngIf=\"appearance$ | async\"></ng-container>\n<div\n    tuiWrapper\n    class=\"t-wrapper\"\n    [appearance]=\"computedAppearance\"\n    [hover]=\"pseudoHover\"\n    [active]=\"pseudoActive\"\n    [disabled]=\"computedDisabled\"\n    [focus]=\"computedFocusVisible\"\n>\n    <span class=\"t-content\">\n        <span\n            *ngIf=\"icon\"\n            class=\"t-left\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"icon as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n        <ng-content></ng-content>\n        <span\n            *ngIf=\"iconRight\"\n            class=\"t-right\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconRight as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n    </span>\n    <tui-loader\n        *ngIf=\"showLoader\"\n        class=\"t-loader\"\n        [size]=\"loaderSize\"\n        [inheritColor]=\"true\"\n    ></tui-loader>\n</div>\n"]}
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/button/button.component.ts","../../../../../projects/core/components/button/button.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n} from '@angular/core';\nimport {\n    AbstractTuiInteractive,\n    tuiAsFocusableItemAccessor,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiFocusableElementAccessor,\n    TuiFocusVisibleService,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiModeDirective} from '@taiga-ui/core/directives';\nimport {TuiSizeS} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {EMPTY, Observable} from 'rxjs';\nimport {distinctUntilChanged, map, startWith} from 'rxjs/operators';\n\nimport {TUI_BUTTON_OPTIONS, TuiButtonOptions} from './button-options';\n\n@Component({\n    selector: 'button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]',\n    templateUrl: './button.template.html',\n    styleUrls: ['./button.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiButtonComponent),\n        TuiDestroyService,\n        TuiFocusVisibleService,\n    ],\n})\nexport class TuiButtonComponent\n    extends AbstractTuiInteractive\n    implements TuiFocusableElementAccessor, TuiButtonOptions\n{\n    private readonly mode$: Observable<unknown> = this.mode?.change$ || EMPTY;\n\n    @Input()\n    @tuiDefaultProp()\n    appearance: TuiButtonOptions['appearance'] = null;\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    @tuiDefaultProp()\n    icon: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    iconRight: PolymorpheusContent = '';\n\n    @Input()\n    @HostBinding('attr.data-shape')\n    @tuiDefaultProp()\n    shape = this.options.shape;\n\n    @Input()\n    @HostBinding('class._loading')\n    @tuiDefaultProp()\n    showLoader = false;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    @tuiDefaultProp()\n    size = this.options.size;\n\n    readonly appearance$ = this.mode$.pipe(\n        startWith(null),\n        map(() => this.computedAppearance),\n        distinctUntilChanged(),\n    );\n\n    constructor(\n        @Optional()\n        @Inject(TuiModeDirective)\n        private readonly mode: TuiModeDirective | null,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(TuiFocusVisibleService) focusVisible$: TuiFocusVisibleService,\n        @Inject(TUI_BUTTON_OPTIONS) private readonly options: TuiButtonOptions,\n    ) {\n        super();\n        focusVisible$.subscribe(focusVisible => {\n            this.updateFocusVisible(focusVisible);\n        });\n    }\n\n    get nativeFocusableElement(): HTMLElement | null {\n        return this.nativeDisabled ? null : this.el.nativeElement;\n    }\n\n    get focused(): boolean {\n        return !this.showLoader && tuiIsNativeFocused(this.el.nativeElement);\n    }\n\n    get loaderSize(): TuiSizeS {\n        return this.size === 'l' || this.size === 'xl' ? 'm' : 's';\n    }\n\n    @HostBinding('attr.data-appearance')\n    get computedAppearance(): string {\n        return this.appearance ?? (this.options.appearance || '');\n    }\n\n    @HostBinding('attr.disabled')\n    get nativeDisabled(): '' | null {\n        return this.computedDisabled || this.showLoader ? '' : null;\n    }\n\n    @HostBinding('tabIndex')\n    get tabIndex(): number {\n        return this.focusable ? 0 : -1;\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n}\n","<ng-container *ngIf=\"appearance$ | async\"></ng-container>\n<div\n    tuiWrapper\n    class=\"t-wrapper\"\n    [appearance]=\"computedAppearance\"\n    [hover]=\"pseudoHover\"\n    [active]=\"pseudoActive\"\n    [disabled]=\"computedDisabled\"\n    [focus]=\"computedFocusVisible\"\n>\n    <span class=\"t-content\">\n        <span\n            *ngIf=\"icon\"\n            class=\"t-left\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"icon as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n        <ng-content></ng-content>\n        <span\n            *ngIf=\"iconRight\"\n            class=\"t-right\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconRight as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n    </span>\n    <tui-loader\n        *ngIf=\"showLoader\"\n        class=\"t-loader\"\n        [size]=\"loaderSize\"\n        [inheritColor]=\"true\"\n    ></tui-loader>\n</div>\n"]}
@@ -14,10 +14,10 @@ import * as i3 from "@taiga-ui/core/directives";
14
14
  import * as i4 from "rxjs";
15
15
  // TODO: Consider aria-activedescendant for proper accessibility implementation
16
16
  export class TuiDataListComponent {
17
- constructor(controller, elementRef, defaultEmptyContent$) {
17
+ constructor(controller, el, defaultEmptyContent$) {
18
18
  var _a;
19
19
  this.controller = controller;
20
- this.elementRef = elementRef;
20
+ this.el = el;
21
21
  this.defaultEmptyContent$ = defaultEmptyContent$;
22
22
  this.options = EMPTY_QUERY;
23
23
  this.role = 'listbox';
@@ -38,7 +38,7 @@ export class TuiDataListComponent {
38
38
  tuiMoveFocus(elements.indexOf(current), elements, step);
39
39
  }
40
40
  // TODO: Consider aria-activedescendant for proper accessibility implementation
41
- handleFocusLossIfNecessary(element = this.elementRef.nativeElement) {
41
+ handleFocusLossIfNecessary(element = this.el.nativeElement) {
42
42
  if (this.origin && tuiIsNativeFocusedIn(element)) {
43
43
  tuiSetNativeMouseFocused(this.origin, true, true);
44
44
  }
@@ -58,7 +58,7 @@ export class TuiDataListComponent {
58
58
  this.handleFocusLossIfNecessary(target);
59
59
  }
60
60
  get elements() {
61
- return Array.from(this.elementRef.nativeElement.querySelectorAll('[tuiOption]'));
61
+ return Array.from(this.el.nativeElement.querySelectorAll('[tuiOption]'));
62
62
  }
63
63
  }
64
64
  TuiDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDataListComponent, deps: [{ token: TUI_TEXTFIELD_WATCHED_CONTROLLER, optional: true }, { token: ElementRef }, { token: TUI_NOTHING_FOUND_MESSAGE }], target: i0.ɵɵFactoryTarget.Component });
@@ -136,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
136
136
  type: HostListener,
137
137
  args: ['mouseleave', ['$event.target']]
138
138
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/data-list/data-list.component.ts","../../../../../projects/core/components/data-list/data-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiIsElement,\n    tuiIsNativeFocusedIn,\n    tuiIsPresent,\n    tuiMoveFocus,\n    tuiPure,\n    tuiQueryListChanges,\n    tuiSetNativeMouseFocused,\n} from '@taiga-ui/cdk';\nimport {\n    TEXTFIELD_CONTROLLER_PROVIDER,\n    TUI_TEXTFIELD_WATCHED_CONTROLLER,\n    TuiTextfieldController,\n} from '@taiga-ui/core/directives';\nimport {TuiDataListAccessor} from '@taiga-ui/core/interfaces';\nimport {TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor} from '@taiga-ui/core/tokens';\nimport {TuiDataListRole} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiOptionComponent} from './option/option.component';\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    selector: 'tui-data-list',\n    templateUrl: './data-list.template.html',\n    styleUrls: ['./data-list.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        tuiAsDataListAccessor(TuiDataListComponent),\n        TEXTFIELD_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOptionComponent), {descendants: true})\n    private readonly options: QueryList<TuiOptionComponent<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n\n    @Input()\n    @HostBinding('attr.role')\n    @tuiDefaultProp()\n    role: TuiDataListRole = 'listbox';\n\n    @Input()\n    @tuiDefaultProp()\n    emptyContent: PolymorpheusContent = '';\n\n    @Input()\n    @HostBinding('attr.data-list-size')\n    @tuiDefaultProp()\n    size = this.controller?.size || 'm';\n\n    constructor(\n        @Optional()\n        @Inject(TUI_TEXTFIELD_WATCHED_CONTROLLER)\n        private readonly controller: TuiTextfieldController | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(TUI_NOTHING_FOUND_MESSAGE)\n        readonly defaultEmptyContent$: Observable<string>,\n    ) {}\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener('focusin', ['$event.relatedTarget', '$event.currentTarget'])\n    onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener('mousedown.prevent')\n    noop(): void {}\n\n    @HostListener('keydown.arrowDown.prevent', ['$event.target', '1'])\n    @HostListener('keydown.arrowUp.prevent', ['$event.target', '-1'])\n    onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    // TODO: Consider aria-activedescendant for proper accessibility implementation\n    @HostListener('wheel.silent.passive')\n    @HostListener('mouseleave', ['$event.target'])\n    handleFocusLossIfNecessary(element: Element = this.elementRef.nativeElement): void {\n        if (this.origin && tuiIsNativeFocusedIn(element)) {\n            tuiSetNativeMouseFocused(this.origin, true, true);\n        }\n    }\n\n    getOptions(includeDisabled: boolean = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    onFocus({target}: Event, top: boolean): void {\n        if (!tuiIsElement(target)) {\n            return;\n        }\n\n        const {elements} = this;\n\n        tuiMoveFocus(top ? -1 : elements.length, elements, top ? 1 : -1);\n        this.handleFocusLossIfNecessary(target);\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.elementRef.nativeElement.querySelectorAll('[tuiOption]'));\n    }\n}\n","<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n    *ngIf=\"empty$ | async\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, false)\"\n></div>\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/data-list/data-list.component.ts","../../../../../projects/core/components/data-list/data-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiIsElement,\n    tuiIsNativeFocusedIn,\n    tuiIsPresent,\n    tuiMoveFocus,\n    tuiPure,\n    tuiQueryListChanges,\n    tuiSetNativeMouseFocused,\n} from '@taiga-ui/cdk';\nimport {\n    TEXTFIELD_CONTROLLER_PROVIDER,\n    TUI_TEXTFIELD_WATCHED_CONTROLLER,\n    TuiTextfieldController,\n} from '@taiga-ui/core/directives';\nimport {TuiDataListAccessor} from '@taiga-ui/core/interfaces';\nimport {TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor} from '@taiga-ui/core/tokens';\nimport {TuiDataListRole} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiOptionComponent} from './option/option.component';\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    selector: 'tui-data-list',\n    templateUrl: './data-list.template.html',\n    styleUrls: ['./data-list.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        tuiAsDataListAccessor(TuiDataListComponent),\n        TEXTFIELD_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOptionComponent), {descendants: true})\n    private readonly options: QueryList<TuiOptionComponent<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n\n    @Input()\n    @HostBinding('attr.role')\n    @tuiDefaultProp()\n    role: TuiDataListRole = 'listbox';\n\n    @Input()\n    @tuiDefaultProp()\n    emptyContent: PolymorpheusContent = '';\n\n    @Input()\n    @HostBinding('attr.data-list-size')\n    @tuiDefaultProp()\n    size = this.controller?.size || 'm';\n\n    constructor(\n        @Optional()\n        @Inject(TUI_TEXTFIELD_WATCHED_CONTROLLER)\n        private readonly controller: TuiTextfieldController | null,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(TUI_NOTHING_FOUND_MESSAGE)\n        readonly defaultEmptyContent$: Observable<string>,\n    ) {}\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener('focusin', ['$event.relatedTarget', '$event.currentTarget'])\n    onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener('mousedown.prevent')\n    noop(): void {}\n\n    @HostListener('keydown.arrowDown.prevent', ['$event.target', '1'])\n    @HostListener('keydown.arrowUp.prevent', ['$event.target', '-1'])\n    onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    // TODO: Consider aria-activedescendant for proper accessibility implementation\n    @HostListener('wheel.silent.passive')\n    @HostListener('mouseleave', ['$event.target'])\n    handleFocusLossIfNecessary(element: Element = this.el.nativeElement): void {\n        if (this.origin && tuiIsNativeFocusedIn(element)) {\n            tuiSetNativeMouseFocused(this.origin, true, true);\n        }\n    }\n\n    getOptions(includeDisabled: boolean = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    onFocus({target}: Event, top: boolean): void {\n        if (!tuiIsElement(target)) {\n            return;\n        }\n\n        const {elements} = this;\n\n        tuiMoveFocus(top ? -1 : elements.length, elements, top ? 1 : -1);\n        this.handleFocusLossIfNecessary(target);\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.el.nativeElement.querySelectorAll('[tuiOption]'));\n    }\n}\n","<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n    *ngIf=\"empty$ | async\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, false)\"\n></div>\n"]}
@@ -18,10 +18,10 @@ function shouldFocus({ currentTarget }) {
18
18
  }
19
19
  // TODO: Consider all use cases for aria roles
20
20
  export class TuiOptionComponent {
21
- constructor(content, dataList, elementRef, host, dropdown) {
21
+ constructor(content, dataList, el, host, dropdown) {
22
22
  this.content = content;
23
23
  this.dataList = dataList;
24
- this.elementRef = elementRef;
24
+ this.el = el;
25
25
  this.host = host;
26
26
  this.dropdown = dropdown;
27
27
  /** @deprecated use size on {@link TuiDataListComponent} instead */
@@ -43,7 +43,7 @@ export class TuiOptionComponent {
43
43
  }
44
44
  // Preventing focus loss upon focused option removal
45
45
  ngOnDestroy() {
46
- this.dataList.handleFocusLossIfNecessary(this.elementRef.nativeElement);
46
+ this.dataList.handleFocusLossIfNecessary(this.el.nativeElement);
47
47
  }
48
48
  }
49
49
  TuiOptionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiOptionComponent, deps: [{ token: TUI_OPTION_CONTENT, optional: true }, { token: forwardRef(() => TuiDataListComponent) }, { token: ElementRef }, { token: TUI_DATA_LIST_HOST, optional: true }, { token: TuiDropdownDirective, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
@@ -120,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
120
120
  type: HostListener,
121
121
  args: ['mousemove.silent', ['$event']]
122
122
  }] } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option.component.js","sourceRoot":"","sources":["../../../../../../projects/core/components/data-list/option/option.component.ts","../../../../../../projects/core/components/data-list/option/option.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Self,\n    TemplateRef,\n} from '@angular/core';\nimport {\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiEventWith,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiDropdownDirective} from '@taiga-ui/core/directives/dropdown';\nimport {TuiDataListHost} from '@taiga-ui/core/interfaces';\nimport {TUI_DATA_LIST_HOST, TUI_OPTION_CONTENT} from '@taiga-ui/core/tokens';\nimport {TuiOptionRole, TuiSizeL, TuiSizeXS} from '@taiga-ui/core/types';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiDataListComponent} from '../data-list.component';\n\nfunction shouldFocus({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): boolean {\n    return !tuiIsNativeFocused(currentTarget);\n}\n\n// TODO: Consider all use cases for aria roles\n@Component({\n    selector: 'button[tuiOption], a[tuiOption]',\n    templateUrl: './option.template.html',\n    styleUrls: ['./option.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        tabIndex: '-1',\n        type: 'button',\n        '[attr.disabled]': 'disabled || null',\n    },\n})\nexport class TuiOptionComponent<T = unknown> implements OnDestroy {\n    /** @deprecated use size on {@link TuiDataListComponent} instead */\n    @Input()\n    @HostBinding('attr.data-size')\n    @tuiDefaultProp()\n    size: TuiSizeL | TuiSizeXS | null = null;\n\n    @Input()\n    @HostBinding('attr.role')\n    @tuiDefaultProp()\n    role: TuiOptionRole = 'option';\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    value?: T;\n\n    constructor(\n        @Optional()\n        @Inject(TUI_OPTION_CONTENT)\n        readonly content: PolymorpheusContent<\n            TuiContextWithImplicit<TemplateRef<Record<string, unknown>>>\n        > | null,\n        @Inject(forwardRef(() => TuiDataListComponent))\n        private readonly dataList: TuiDataListComponent<T>,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(TUI_DATA_LIST_HOST)\n        private readonly host: TuiDataListHost<T> | null,\n        @Optional()\n        @Self()\n        @Inject(TuiDropdownDirective)\n        readonly dropdown: TuiDropdownDirective | null,\n    ) {}\n\n    @HostBinding('class._with-dropdown')\n    get active(): boolean {\n        return !!this.dropdown && !!this.dropdown.dropdownBoxRef;\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        if (this.host && this.value !== undefined) {\n            this.host.handleOption(this.value);\n        }\n    }\n\n    // @bad TODO: Consider aria-activedescendant for proper accessibility implementation\n    @shouldCall(shouldFocus)\n    @HostListener('mousemove.silent', ['$event'])\n    onMouseMove({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): void {\n        currentTarget.focus({preventScroll: true});\n    }\n\n    // Preventing focus loss upon focused option removal\n    ngOnDestroy(): void {\n        this.dataList.handleFocusLossIfNecessary(this.elementRef.nativeElement);\n    }\n}\n","<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n    {{ text }}\n</ng-container>\n<ng-template #base>\n    <ng-content></ng-content>\n    <tui-svg\n        *ngIf=\"dropdown\"\n        src=\"tuiIconChevronRight\"\n        class=\"t-arrow\"\n    ></tui-svg>\n</ng-template>\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option.component.js","sourceRoot":"","sources":["../../../../../../projects/core/components/data-list/option/option.component.ts","../../../../../../projects/core/components/data-list/option/option.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Self,\n    TemplateRef,\n} from '@angular/core';\nimport {\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiEventWith,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiDropdownDirective} from '@taiga-ui/core/directives/dropdown';\nimport {TuiDataListHost} from '@taiga-ui/core/interfaces';\nimport {TUI_DATA_LIST_HOST, TUI_OPTION_CONTENT} from '@taiga-ui/core/tokens';\nimport {TuiOptionRole, TuiSizeL, TuiSizeXS} from '@taiga-ui/core/types';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiDataListComponent} from '../data-list.component';\n\nfunction shouldFocus({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): boolean {\n    return !tuiIsNativeFocused(currentTarget);\n}\n\n// TODO: Consider all use cases for aria roles\n@Component({\n    selector: 'button[tuiOption], a[tuiOption]',\n    templateUrl: './option.template.html',\n    styleUrls: ['./option.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        tabIndex: '-1',\n        type: 'button',\n        '[attr.disabled]': 'disabled || null',\n    },\n})\nexport class TuiOptionComponent<T = unknown> implements OnDestroy {\n    /** @deprecated use size on {@link TuiDataListComponent} instead */\n    @Input()\n    @HostBinding('attr.data-size')\n    @tuiDefaultProp()\n    size: TuiSizeL | TuiSizeXS | null = null;\n\n    @Input()\n    @HostBinding('attr.role')\n    @tuiDefaultProp()\n    role: TuiOptionRole = 'option';\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    value?: T;\n\n    constructor(\n        @Optional()\n        @Inject(TUI_OPTION_CONTENT)\n        readonly content: PolymorpheusContent<\n            TuiContextWithImplicit<TemplateRef<Record<string, unknown>>>\n        > | null,\n        @Inject(forwardRef(() => TuiDataListComponent))\n        private readonly dataList: TuiDataListComponent<T>,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(TUI_DATA_LIST_HOST)\n        private readonly host: TuiDataListHost<T> | null,\n        @Optional()\n        @Self()\n        @Inject(TuiDropdownDirective)\n        readonly dropdown: TuiDropdownDirective | null,\n    ) {}\n\n    @HostBinding('class._with-dropdown')\n    get active(): boolean {\n        return !!this.dropdown && !!this.dropdown.dropdownBoxRef;\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        if (this.host && this.value !== undefined) {\n            this.host.handleOption(this.value);\n        }\n    }\n\n    // @bad TODO: Consider aria-activedescendant for proper accessibility implementation\n    @shouldCall(shouldFocus)\n    @HostListener('mousemove.silent', ['$event'])\n    onMouseMove({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): void {\n        currentTarget.focus({preventScroll: true});\n    }\n\n    // Preventing focus loss upon focused option removal\n    ngOnDestroy(): void {\n        this.dataList.handleFocusLossIfNecessary(this.el.nativeElement);\n    }\n}\n","<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n    {{ text }}\n</ng-container>\n<ng-template #base>\n    <ng-content></ng-content>\n    <tui-svg\n        *ngIf=\"dropdown\"\n        src=\"tuiIconChevronRight\"\n        class=\"t-arrow\"\n    ></tui-svg>\n</ng-template>\n"]}