@taiga-ui/kit 3.39.1 → 3.40.0

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 (147) hide show
  1. package/bundles/taiga-ui-kit-components-accordion.umd.js +11 -7
  2. package/bundles/taiga-ui-kit-components-accordion.umd.js.map +1 -1
  3. package/bundles/taiga-ui-kit-components-calendar-month.umd.js +1 -1
  4. package/bundles/taiga-ui-kit-components-calendar-month.umd.js.map +1 -1
  5. package/bundles/taiga-ui-kit-components-calendar-range.umd.js +7 -3
  6. package/bundles/taiga-ui-kit-components-calendar-range.umd.js.map +1 -1
  7. package/bundles/taiga-ui-kit-components-files.umd.js +12 -8
  8. package/bundles/taiga-ui-kit-components-files.umd.js.map +1 -1
  9. package/bundles/taiga-ui-kit-components-input-number.umd.js +42 -22
  10. package/bundles/taiga-ui-kit-components-input-number.umd.js.map +1 -1
  11. package/bundles/taiga-ui-kit-components-input-range.umd.js +5 -23
  12. package/bundles/taiga-ui-kit-components-input-range.umd.js.map +1 -1
  13. package/bundles/taiga-ui-kit-components-input-slider.umd.js +5 -1
  14. package/bundles/taiga-ui-kit-components-input-slider.umd.js.map +1 -1
  15. package/bundles/taiga-ui-kit-components-input-tag.umd.js +7 -3
  16. package/bundles/taiga-ui-kit-components-input-tag.umd.js.map +1 -1
  17. package/bundles/taiga-ui-kit-components-pagination.umd.js +22 -25
  18. package/bundles/taiga-ui-kit-components-pagination.umd.js.map +1 -1
  19. package/bundles/taiga-ui-kit-components-pdf-viewer.umd.js +7 -3
  20. package/bundles/taiga-ui-kit-components-pdf-viewer.umd.js.map +1 -1
  21. package/bundles/taiga-ui-kit-components-progress.umd.js +6 -5
  22. package/bundles/taiga-ui-kit-components-progress.umd.js.map +1 -1
  23. package/bundles/taiga-ui-kit-components-prompt.umd.js +1 -1
  24. package/bundles/taiga-ui-kit-components-prompt.umd.js.map +1 -1
  25. package/bundles/taiga-ui-kit-components-push.umd.js +7 -3
  26. package/bundles/taiga-ui-kit-components-push.umd.js.map +1 -1
  27. package/bundles/taiga-ui-kit-components-select-option.umd.js +7 -3
  28. package/bundles/taiga-ui-kit-components-select-option.umd.js.map +1 -1
  29. package/bundles/taiga-ui-kit-components-stepper.umd.js +7 -3
  30. package/bundles/taiga-ui-kit-components-stepper.umd.js.map +1 -1
  31. package/bundles/taiga-ui-kit-components-tabs.umd.js +11 -7
  32. package/bundles/taiga-ui-kit-components-tabs.umd.js.map +1 -1
  33. package/bundles/taiga-ui-kit-components-tag.umd.js +16 -27
  34. package/bundles/taiga-ui-kit-components-tag.umd.js.map +1 -1
  35. package/bundles/{taiga-ui-kit-components-text-area.umd.js → taiga-ui-kit-components-textarea.umd.js} +81 -64
  36. package/bundles/taiga-ui-kit-components-textarea.umd.js.map +1 -0
  37. package/bundles/taiga-ui-kit-components-tiles.umd.js +5 -0
  38. package/bundles/taiga-ui-kit-components-tiles.umd.js.map +1 -1
  39. package/bundles/taiga-ui-kit-components-tree.umd.js +7 -3
  40. package/bundles/taiga-ui-kit-components-tree.umd.js.map +1 -1
  41. package/bundles/taiga-ui-kit-components.umd.js +6 -6
  42. package/components/accordion/accordion-item/accordion-item.component.d.ts +3 -1
  43. package/components/calendar-range/calendar-range.component.d.ts +4 -3
  44. package/components/files/file/file.component.d.ts +3 -2
  45. package/components/index.d.ts +1 -1
  46. package/components/input-number/input-number.component.d.ts +7 -4
  47. package/components/input-range/input-range.component.d.ts +2 -4
  48. package/components/input-tag/input-tag.component.d.ts +5 -4
  49. package/components/pagination/pagination.component.d.ts +7 -6
  50. package/components/pagination/pagination.module.d.ts +3 -3
  51. package/components/pdf-viewer/pdf-viewer.component.d.ts +3 -1
  52. package/components/progress/progress-circle/progress-circle.component.d.ts +1 -1
  53. package/components/push/push.component.d.ts +3 -1
  54. package/components/select-option/select-option.component.d.ts +4 -3
  55. package/components/stepper/step/step.component.d.ts +3 -1
  56. package/components/tabs/tabs-with-more/tabs-with-more.component.d.ts +3 -1
  57. package/components/tag/tag.component.d.ts +3 -5
  58. package/components/tag/tag.module.d.ts +3 -4
  59. package/components/textarea/deprecated.d.ts +15 -0
  60. package/components/textarea/index.d.ts +4 -0
  61. package/components/textarea/package.json +10 -0
  62. package/components/{text-area/taiga-ui-kit-components-text-area.d.ts → textarea/taiga-ui-kit-components-textarea.d.ts} +1 -1
  63. package/components/{text-area/text-area.component.d.ts → textarea/textarea.component.d.ts} +3 -3
  64. package/components/textarea/textarea.directive.d.ts +8 -0
  65. package/components/{text-area/text-area.module.d.ts → textarea/textarea.module.d.ts} +6 -6
  66. package/components/tiles/tile.component.d.ts +3 -2
  67. package/components/tree/components/tree-item-content/tree-item-content.component.d.ts +3 -1
  68. package/esm2015/components/accordion/accordion-item/accordion-item.component.js +9 -4
  69. package/esm2015/components/calendar-month/calendar-month.component.js +1 -1
  70. package/esm2015/components/calendar-range/calendar-range.component.js +9 -5
  71. package/esm2015/components/files/file/file.component.js +9 -4
  72. package/esm2015/components/index.js +2 -2
  73. package/esm2015/components/input-number/input-number.component.js +29 -10
  74. package/esm2015/components/input-range/input-range.component.js +6 -16
  75. package/esm2015/components/input-slider/input-slider.component.js +6 -2
  76. package/esm2015/components/input-tag/input-tag.component.js +9 -5
  77. package/esm2015/components/pagination/pagination.component.js +18 -12
  78. package/esm2015/components/pagination/pagination.module.js +5 -8
  79. package/esm2015/components/pdf-viewer/pdf-viewer.component.js +9 -5
  80. package/esm2015/components/progress/progress-circle/progress-circle.component.js +7 -6
  81. package/esm2015/components/prompt/prompt.component.js +1 -1
  82. package/esm2015/components/push/push.component.js +9 -5
  83. package/esm2015/components/select-option/select-option.component.js +9 -5
  84. package/esm2015/components/stepper/step/step.component.js +9 -5
  85. package/esm2015/components/tabs/tabs-with-more/tabs-with-more.component.js +9 -4
  86. package/esm2015/components/tag/tag.component.js +12 -16
  87. package/esm2015/components/tag/tag.module.js +1 -5
  88. package/esm2015/components/textarea/deprecated.js +16 -0
  89. package/esm2015/components/textarea/index.js +5 -0
  90. package/esm2015/components/textarea/taiga-ui-kit-components-textarea.js +5 -0
  91. package/esm2015/components/textarea/textarea.component.js +217 -0
  92. package/esm2015/components/textarea/textarea.directive.js +19 -0
  93. package/esm2015/components/textarea/textarea.module.js +51 -0
  94. package/esm2015/components/tiles/tile.component.js +6 -1
  95. package/esm2015/components/tree/components/tree-item-content/tree-item-content.component.js +9 -4
  96. package/fesm2015/taiga-ui-kit-components-accordion.js +8 -3
  97. package/fesm2015/taiga-ui-kit-components-accordion.js.map +1 -1
  98. package/fesm2015/taiga-ui-kit-components-calendar-month.js +1 -1
  99. package/fesm2015/taiga-ui-kit-components-calendar-month.js.map +1 -1
  100. package/fesm2015/taiga-ui-kit-components-calendar-range.js +8 -4
  101. package/fesm2015/taiga-ui-kit-components-calendar-range.js.map +1 -1
  102. package/fesm2015/taiga-ui-kit-components-files.js +9 -5
  103. package/fesm2015/taiga-ui-kit-components-files.js.map +1 -1
  104. package/fesm2015/taiga-ui-kit-components-input-number.js +29 -10
  105. package/fesm2015/taiga-ui-kit-components-input-number.js.map +1 -1
  106. package/fesm2015/taiga-ui-kit-components-input-range.js +5 -15
  107. package/fesm2015/taiga-ui-kit-components-input-range.js.map +1 -1
  108. package/fesm2015/taiga-ui-kit-components-input-slider.js +5 -1
  109. package/fesm2015/taiga-ui-kit-components-input-slider.js.map +1 -1
  110. package/fesm2015/taiga-ui-kit-components-input-tag.js +8 -4
  111. package/fesm2015/taiga-ui-kit-components-input-tag.js.map +1 -1
  112. package/fesm2015/taiga-ui-kit-components-pagination.js +22 -19
  113. package/fesm2015/taiga-ui-kit-components-pagination.js.map +1 -1
  114. package/fesm2015/taiga-ui-kit-components-pdf-viewer.js +8 -4
  115. package/fesm2015/taiga-ui-kit-components-pdf-viewer.js.map +1 -1
  116. package/fesm2015/taiga-ui-kit-components-progress.js +6 -5
  117. package/fesm2015/taiga-ui-kit-components-progress.js.map +1 -1
  118. package/fesm2015/taiga-ui-kit-components-prompt.js +1 -1
  119. package/fesm2015/taiga-ui-kit-components-prompt.js.map +1 -1
  120. package/fesm2015/taiga-ui-kit-components-push.js +8 -4
  121. package/fesm2015/taiga-ui-kit-components-push.js.map +1 -1
  122. package/fesm2015/taiga-ui-kit-components-select-option.js +8 -4
  123. package/fesm2015/taiga-ui-kit-components-select-option.js.map +1 -1
  124. package/fesm2015/taiga-ui-kit-components-stepper.js +8 -4
  125. package/fesm2015/taiga-ui-kit-components-stepper.js.map +1 -1
  126. package/fesm2015/taiga-ui-kit-components-tabs.js +8 -3
  127. package/fesm2015/taiga-ui-kit-components-tabs.js.map +1 -1
  128. package/fesm2015/taiga-ui-kit-components-tag.js +12 -19
  129. package/fesm2015/taiga-ui-kit-components-tag.js.map +1 -1
  130. package/fesm2015/{taiga-ui-kit-components-text-area.js → taiga-ui-kit-components-textarea.js} +41 -27
  131. package/fesm2015/taiga-ui-kit-components-textarea.js.map +1 -0
  132. package/fesm2015/taiga-ui-kit-components-tiles.js +5 -0
  133. package/fesm2015/taiga-ui-kit-components-tiles.js.map +1 -1
  134. package/fesm2015/taiga-ui-kit-components-tree.js +8 -4
  135. package/fesm2015/taiga-ui-kit-components-tree.js.map +1 -1
  136. package/fesm2015/taiga-ui-kit-components.js +1 -1
  137. package/package.json +5 -5
  138. package/bundles/taiga-ui-kit-components-text-area.umd.js.map +0 -1
  139. package/components/text-area/index.d.ts +0 -3
  140. package/components/text-area/package.json +0 -10
  141. package/components/text-area/text-area.directive.d.ts +0 -8
  142. package/esm2015/components/text-area/index.js +0 -4
  143. package/esm2015/components/text-area/taiga-ui-kit-components-text-area.js +0 -5
  144. package/esm2015/components/text-area/text-area.component.js +0 -217
  145. package/esm2015/components/text-area/text-area.directive.js +0 -18
  146. package/esm2015/components/text-area/text-area.module.js +0 -51
  147. package/fesm2015/taiga-ui-kit-components-text-area.js.map +0 -1
@@ -0,0 +1,16 @@
1
+ import { TuiTextareaComponent } from './textarea.component';
2
+ import { TuiTextareaDirective } from './textarea.directive';
3
+ import { TuiTextareaModule } from './textarea.module';
4
+ /**
5
+ * @deprecated: use {@link TuiTextareaComponent}
6
+ */
7
+ export const TuiTextAreaComponent = TuiTextareaComponent;
8
+ /**
9
+ * @deprecated: use {@link TuiTextareaDirective}
10
+ */
11
+ export const TuiTextAreaDirective = TuiTextareaDirective;
12
+ /**
13
+ * @deprecated: use {@link TuiTextareaModule}
14
+ */
15
+ export const TuiTextAreaModule = TuiTextareaModule;
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwcmVjYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3RleHRhcmVhL2RlcHJlY2F0ZWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDMUQsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDMUQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFFcEQ7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxvQkFBb0IsQ0FBQztBQUV6RDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLG9CQUFvQixDQUFDO0FBRXpEOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1R1aVRleHRhcmVhQ29tcG9uZW50fSBmcm9tICcuL3RleHRhcmVhLmNvbXBvbmVudCc7XG5pbXBvcnQge1R1aVRleHRhcmVhRGlyZWN0aXZlfSBmcm9tICcuL3RleHRhcmVhLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aVRleHRhcmVhTW9kdWxlfSBmcm9tICcuL3RleHRhcmVhLm1vZHVsZSc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQ6IHVzZSB7QGxpbmsgVHVpVGV4dGFyZWFDb21wb25lbnR9XG4gKi9cbmV4cG9ydCBjb25zdCBUdWlUZXh0QXJlYUNvbXBvbmVudCA9IFR1aVRleHRhcmVhQ29tcG9uZW50O1xuXG4vKipcbiAqIEBkZXByZWNhdGVkOiB1c2Uge0BsaW5rIFR1aVRleHRhcmVhRGlyZWN0aXZlfVxuICovXG5leHBvcnQgY29uc3QgVHVpVGV4dEFyZWFEaXJlY3RpdmUgPSBUdWlUZXh0YXJlYURpcmVjdGl2ZTtcblxuLyoqXG4gKiBAZGVwcmVjYXRlZDogdXNlIHtAbGluayBUdWlUZXh0YXJlYU1vZHVsZX1cbiAqL1xuZXhwb3J0IGNvbnN0IFR1aVRleHRBcmVhTW9kdWxlID0gVHVpVGV4dGFyZWFNb2R1bGU7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ export * from './deprecated';
2
+ export * from './textarea.component';
3
+ export * from './textarea.directive';
4
+ export * from './textarea.module';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy90ZXh0YXJlYS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGVwcmVjYXRlZCc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRhcmVhLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRhcmVhLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRhcmVhLm1vZHVsZSc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWkta2l0LWNvbXBvbmVudHMtdGV4dGFyZWEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy90ZXh0YXJlYS90YWlnYS11aS1raXQtY29tcG9uZW50cy10ZXh0YXJlYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -0,0 +1,217 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, HostBinding, HostListener, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
2
+ import { NgControl } from '@angular/forms';
3
+ import { AbstractTuiControl, TUI_IS_IOS, tuiAsControl, tuiAsFocusableItemAccessor, tuiIsNativeFocused, } from '@taiga-ui/cdk';
4
+ import { MODE_PROVIDER, TEXTFIELD_CONTROLLER_PROVIDER, TUI_ICON_PADDINGS, TUI_MODE, TUI_TEXTFIELD_WATCHED_CONTROLLER, tuiGetBorder, TuiHintOptionsDirective, TuiTextfieldComponent, } from '@taiga-ui/core';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@taiga-ui/core";
7
+ import * as i2 from "@angular/common";
8
+ import * as i3 from "@angular/forms";
9
+ import * as i4 from "@taiga-ui/cdk";
10
+ import * as i5 from "@tinkoff/ng-polymorpheus";
11
+ import * as i6 from "rxjs";
12
+ export const DEFAULT_ROWS = 20;
13
+ export const LINE_HEIGHT_M = 20;
14
+ export const LINE_HEIGHT_L = 24;
15
+ export class TuiTextareaComponent extends AbstractTuiControl {
16
+ constructor(control, cdr, isIOS, mode$, controller, hintOptions) {
17
+ super(control, cdr);
18
+ this.isIOS = isIOS;
19
+ this.mode$ = mode$;
20
+ this.controller = controller;
21
+ this.hintOptions = hintOptions;
22
+ this.rows = DEFAULT_ROWS;
23
+ this.maxLength = null;
24
+ this.expandable = false;
25
+ }
26
+ get labelOutside() {
27
+ return this.controller.labelOutside;
28
+ }
29
+ get nativeFocusableElement() {
30
+ var _a, _b;
31
+ if (this.computedDisabled) {
32
+ return null;
33
+ }
34
+ return (((_a = this.textfield) === null || _a === void 0 ? void 0 : _a.nativeElement) || ((_b = this.focusableElement) === null || _b === void 0 ? void 0 : _b.nativeElement) || null);
35
+ }
36
+ get focused() {
37
+ return tuiIsNativeFocused(this.nativeFocusableElement);
38
+ }
39
+ get appearance() {
40
+ return this.controller.appearance;
41
+ }
42
+ get size() {
43
+ return this.controller.size;
44
+ }
45
+ get borderStart() {
46
+ return this.iconLeftContent ? TUI_ICON_PADDINGS[this.size] : 0;
47
+ }
48
+ get borderEnd() {
49
+ return tuiGetBorder(!!this.iconContent, this.hasCleaner, this.hasTooltip, this.hasCustomContent, this.size);
50
+ }
51
+ get hasCleaner() {
52
+ return this.controller.cleaner && this.hasValue && this.interactive;
53
+ }
54
+ get hasTooltip() {
55
+ var _a;
56
+ return (!!((_a = this.hintOptions) === null || _a === void 0 ? void 0 : _a.content) &&
57
+ (this.controller.options.hintOnDisabled || !this.computedDisabled));
58
+ }
59
+ get hasValue() {
60
+ return this.value !== '';
61
+ }
62
+ get hasCounter() {
63
+ return !!this.maxLength && this.interactive;
64
+ }
65
+ get hasPlaceholder() {
66
+ return this.placeholderRaisable || (!this.hasValue && !this.hasExampleText);
67
+ }
68
+ get hasCustomContent() {
69
+ return !!this.controller.customContent;
70
+ }
71
+ get iconLeftContent() {
72
+ return this.controller.iconLeft;
73
+ }
74
+ get iconContent() {
75
+ return this.controller.icon;
76
+ }
77
+ get iconCleaner() {
78
+ return this.controller.options.iconCleaner;
79
+ }
80
+ get hasExampleText() {
81
+ var _a;
82
+ return (!!((_a = this.textfield) === null || _a === void 0 ? void 0 : _a.nativeElement.placeholder) &&
83
+ this.focused &&
84
+ !this.hasValue &&
85
+ !this.readOnly);
86
+ }
87
+ get computeMaxHeight() {
88
+ return this.expandable ? this.rows * this.lineHeight : null;
89
+ }
90
+ get placeholderRaised() {
91
+ return (this.placeholderRaisable &&
92
+ ((this.computedFocused && !this.readOnly) || this.hasValue));
93
+ }
94
+ get fittedContent() {
95
+ return this.value.slice(0, this.maxLength || Infinity);
96
+ }
97
+ get extraContent() {
98
+ return this.value.slice(this.maxLength || Infinity);
99
+ }
100
+ onFocused(focused) {
101
+ this.updateFocused(focused);
102
+ }
103
+ onValueChange(value) {
104
+ this.value = value;
105
+ }
106
+ onMouseDown(event) {
107
+ if (event.target === this.nativeFocusableElement) {
108
+ return;
109
+ }
110
+ event.preventDefault();
111
+ if (this.nativeFocusableElement) {
112
+ this.nativeFocusableElement.focus();
113
+ }
114
+ }
115
+ getFallbackValue() {
116
+ return '';
117
+ }
118
+ get lineHeight() {
119
+ return this.controller.size === 'm' ? LINE_HEIGHT_M : LINE_HEIGHT_L;
120
+ }
121
+ get placeholderRaisable() {
122
+ return this.size !== 's' && !this.controller.labelOutside;
123
+ }
124
+ }
125
+ TuiTextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_IS_IOS }, { token: TUI_MODE }, { token: TUI_TEXTFIELD_WATCHED_CONTROLLER }, { token: TuiHintOptionsDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component });
126
+ TuiTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiTextareaComponent, selector: "tui-textarea, tui-text-area", inputs: { rows: "rows", maxLength: "maxLength", expandable: "expandable" }, host: { listeners: { "$.data-mode.attr": "mode$", "focusin": "onFocused(true)", "focusout": "onFocused(false)" }, properties: { "class._ios": "isIOS", "class._expandable": "this.expandable", "class._label-outside": "this.labelOutside", "attr.data-size": "this.size", "style.--border-start.rem": "this.borderStart", "style.--border-end.rem": "this.borderEnd", "class._has-tooltip": "this.hasTooltip", "class._has-value": "this.hasValue", "class._has-counter": "this.hasCounter" } }, providers: [
127
+ tuiAsFocusableItemAccessor(TuiTextareaComponent),
128
+ tuiAsControl(TuiTextareaComponent),
129
+ TEXTFIELD_CONTROLLER_PROVIDER,
130
+ MODE_PROVIDER,
131
+ ], queries: [{ propertyName: "textfield", first: true, predicate: TuiTextfieldComponent, descendants: true, read: ElementRef }], viewQueries: [{ propertyName: "focusableElement", first: true, predicate: ["focusableElement"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"hintOptions?.change$ | async\"></ng-container>\n<div\n tuiWrapper\n automation-id=\"tui-text-area__wrapper\"\n class=\"t-outline\"\n [appearance]=\"appearance\"\n [disabled]=\"disabled\"\n [focus]=\"computedFocused\"\n [hover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [invalid]=\"computedInvalid\"\n>\n <div\n *ngIf=\"hasCounter\"\n automation-id=\"tui-text-area__counter\"\n class=\"t-counter\"\n >\n {{ value.length }}/{{ maxLength }}\n </div>\n\n <label\n class=\"t-content\"\n (mousedown)=\"onMouseDown($event)\"\n >\n <div class=\"t-wrapper\">\n <div\n *ngIf=\"hasPlaceholder\"\n automation-id=\"tui-text-area__placeholder\"\n class=\"t-placeholder\"\n [class.t-placeholder_raised]=\"placeholderRaised\"\n >\n <ng-content></ng-content>\n </div>\n <tui-scrollbar\n automation-id=\"tui-text-area__scrollbar\"\n class=\"t-box\"\n [style.maxHeight.px]=\"computeMaxHeight\"\n >\n <div class=\"t-input-wrapper\">\n <div class=\"t-relative\">\n <div\n aria-hidden=\"true\"\n class=\"t-pseudo-content\"\n >\n <span [textContent]=\"fittedContent || nativeFocusableElement?.placeholder\"></span>\n <span\n class=\"t-pseudo-content__extra\"\n [textContent]=\"extraContent\"\n ></span>\n &nbsp;\n </div>\n <textarea\n #focusableElement\n automation-id=\"tui-text-area__native\"\n class=\"t-input\"\n [id]=\"id\"\n [tuiFocusable]=\"computedFocusable\"\n [disabled]=\"computedDisabled\"\n [readOnly]=\"readOnly\"\n [(ngModel)]=\"value\"\n ></textarea>\n <ng-content select=\"textarea\"></ng-content>\n </div>\n </div>\n </tui-scrollbar>\n </div>\n <div class=\"t-icons\">\n <div\n *ngIf=\"iconLeftContent\"\n class=\"t-icon t-icon_left t-textfield-icon\"\n >\n <tui-svg\n *polymorpheusOutlet=\"iconLeftContent as src; context: {$implicit: size}\"\n tuiWrapper\n appearance=\"icon\"\n [src]=\"src\"\n ></tui-svg>\n </div>\n <ng-container *ngIf=\"hasCustomContent\">\n <tui-svg\n *polymorpheusOutlet=\"controller.customContent as src\"\n [src]=\"src\"\n ></tui-svg>\n </ng-container>\n <ng-container *ngIf=\"hasCleaner\">\n <tui-svg\n *polymorpheusOutlet=\"iconCleaner as src; context: {$implicit: size}\"\n tuiWrapper\n appearance=\"icon\"\n class=\"t-cleaner\"\n [src]=\"src\"\n (click.stop)=\"onValueChange('')\"\n ></tui-svg>\n </ng-container>\n <tui-tooltip\n *ngIf=\"hasTooltip\"\n automation-id=\"tui-text-area__tooltip\"\n [describeId]=\"id\"\n [content]=\"hintOptions?.content\"\n ></tui-tooltip>\n <div\n *ngIf=\"iconContent\"\n class=\"t-icon t-textfield-icon\"\n >\n <tui-svg\n *polymorpheusOutlet=\"iconContent as src; context: {$implicit: size}\"\n tuiWrapper\n appearance=\"icon\"\n [src]=\"src\"\n ></tui-svg>\n </div>\n </div>\n </label>\n</div>\n", styles: [":host{position:relative;z-index:0;display:flex;flex-direction:column;min-height:var(--tui-textarea-height);border-radius:var(--tui-radius-m);color:var(--tui-text-01)}:host[data-mode=onDark]{color:var(--tui-text-01-night)}:host[data-size=s]{--tui-height: var(--tui-height-s);--tui-textarea-height: 4.5625rem;font:var(--tui-font-text-s)}:host[data-size=m]{--tui-height: var(--tui-height-m);--tui-textarea-height: 5.5rem;font:var(--tui-font-text-s)}:host[data-size=l]{--tui-height: var(--tui-height-l);--tui-textarea-height: 6.75rem;font:var(--tui-font-text-m)}:host[data-size=m]._has-counter{--tui-textarea-height: 6.625rem}:host[data-size=l]._has-counter{--tui-textarea-height: 7.875rem}.t-outline{min-height:inherit}.t-content{display:block;margin-top:0;margin-bottom:0;min-height:inherit;box-sizing:border-box;overflow:hidden;cursor:text}:host._disabled .t-content{cursor:auto;opacity:var(--tui-disabled-opacity)}:host:not(._expandable) .t-content{position:absolute;top:0;left:0;bottom:1px;right:0;min-height:auto}:host._has-counter:not(._expandable) .t-content{bottom:1.6875rem}.t-wrapper{position:relative;width:100%;height:100%;min-height:inherit;box-sizing:border-box;padding:calc((var(--tui-height) - 1.25rem) / 2) 0}:host[data-size=l]._label-outside .t-wrapper{padding:calc((var(--tui-height) - 1.5rem) / 2) 0}:host[data-size=m]:not(._label-outside) .t-wrapper{padding:calc((var(--tui-height) - 2.25rem) / 2) 0}:host[data-size=l]:not(._label-outside) .t-wrapper{padding:calc((var(--tui-height) - 2.625rem) / 2) 0}:host-context(table)[data-size=m]._label-outside .t-wrapper{padding-bottom:.75rem}:host-context(table)[data-size=l]._label-outside .t-wrapper{padding-bottom:1rem}.t-input-wrapper{min-height:inherit;width:100%;flex:1}.t-relative{position:relative;min-height:inherit}.t-box{display:flex;min-height:calc(100% - 1rem);width:100%}:host:not(._expandable) .t-box{height:calc(100% - 1rem)}:host._has-counter._expandable .t-box{margin-bottom:1.25rem}:host[data-size=m]:not(._label-outside) .t-box{border-top:1rem solid transparent}:host[data-size=l]:not(._label-outside) .t-box{border-top:1.25rem solid transparent}.t-pseudo-content{white-space:pre-wrap;word-wrap:break-word;pointer-events:none;color:transparent;overflow:hidden;border:solid transparent;border-inline-start-width:var(--border-start, 0);border-inline-end-width:var(--border-end, 0)}:host[data-size=s] .t-pseudo-content,:host[data-size=m] .t-pseudo-content{padding:0 .75rem}:host[data-size=l] .t-pseudo-content{padding:0 1rem}.t-pseudo-content__extra{background-color:var(--tui-error-bg-night)}.t-input{padding:0;margin:0;border:0;border-radius:inherit;background:none;font-size:inherit;line-height:inherit;font-weight:inherit;color:inherit;caret-color:currentColor;-webkit-appearance:none;-moz-appearance:none;appearance:none;word-break:keep-all;-webkit-text-fill-color:currentColor;position:absolute;top:0;left:0;width:100%;height:100%;box-sizing:border-box;resize:none;overflow:hidden;outline:none;border:solid transparent;border-inline-start-width:var(--border-start, 0);border-inline-end-width:var(--border-end, 0)}.t-input:-webkit-autofill,.t-input:-webkit-autofill:hover,.t-input:-webkit-autofill:focus{caret-color:var(--tui-base-09);border-radius:inherit;color:inherit!important;background-color:transparent!important;-webkit-text-fill-color:var(--tui-text-01)!important;border-color:var(--tui-autofill);-webkit-box-shadow:0 0 0 100rem var(--tui-autofill) inset!important}.t-input:not(:last-of-type){display:none}.t-input::placeholder{color:var(--tui-text-03);opacity:0}:host[data-mode=onDark] .t-input::placeholder{color:var(--tui-text-03-night)}:host._focused .t-input:not(:-moz-read-only)::placeholder{opacity:1}:host._focused .t-input:not(:read-only)::placeholder{opacity:1}:host[data-size=s] .t-input,:host[data-size=m] .t-input{padding:0 .75rem}:host[data-size=l] .t-input{padding:0 1rem}:host[data-mode=onDark]._disabled .t-input{color:var(--tui-text-03-night)}@supports (-webkit-marquee-repetition: infinite) and (object-fit: fill){:host._ios .t-input{padding-left:.8125rem}}.t-placeholder{transition-property:transform,font-size,color,letter-spacing;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;width:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none;font:var(--tui-font-text-s);color:var(--tui-text-02);pointer-events:none;will-change:transform;transform:translateY(0);position:absolute;top:calc(var(--tui-height) / 2 - .625rem);left:0;max-width:100%;border:solid transparent;border-inline-start-width:var(--border-start, 0);border-inline-end-width:var(--border-end, 0);box-sizing:border-box}.t-placeholder_raised{transform:translateY(-.625rem)}:host[data-size=m] .t-placeholder_raised{font:var(--tui-font-text-xs);line-height:1.25rem;transform:translateY(-.5rem);letter-spacing:.025rem}:host._invalid:not(._focused) .t-placeholder_raised,:host._invalid:not(._focused):hover .t-placeholder_raised{color:var(--tui-error-fill)}:host._invalid:not(._focused) [tuiWrapper][data-mode=onDark] .t-placeholder_raised,:host._invalid:not(._focused):hover [tuiWrapper][data-mode=onDark] .t-placeholder_raised{color:var(--tui-error-fill-night)}:host._focused .t-placeholder,:host[data-size=m]._focused._label-outside .t-placeholder,:host[data-size=l]._focused._label-outside .t-placeholder{color:var(--tui-text-03)}:host[data-size=l] .t-placeholder{font:var(--tui-font-text-m);line-height:1.25rem}:host[data-size=l] .t-placeholder_raised{font-size:.8156rem}:host[data-size=m]._focused:not(._label-outside) .t-placeholder,:host[data-size=l]._focused:not(._label-outside) .t-placeholder{color:var(--tui-text-01)}[tuiWrapper][data-mode=onDark] .t-placeholder{color:var(--tui-text-02-night)}:host[data-size=m]._focused:not(._label-outside) [tuiWrapper][data-mode=onDark] .t-placeholder,:host[data-size=l]._focused:not(._label-outside) [tuiWrapper][data-mode=onDark] .t-placeholder{color:var(--tui-text-01-night)}:host._focused [tuiWrapper][data-mode=onDark] .t-placeholder,:host[data-size=m]._focused._label-outside [tuiWrapper][data-mode=onDark] .t-placeholder,:host[data-size=l]._focused._label-outside [tuiWrapper][data-mode=onDark] .t-placeholder{color:var(--tui-text-02-night)}@supports (-webkit-hyphens: none){.t-placeholder{will-change:unset;transition-property:transform,color,letter-spacing}}:host[data-size=s] .t-placeholder{padding:0 .75rem}:host[data-size=m] .t-placeholder{padding:0 .75rem}:host[data-size=l] .t-placeholder{padding:0 1rem}:host._label-outside .t-placeholder{overflow:initial;height:auto;white-space:initial}.t-icons{position:absolute;top:0;left:0;bottom:0;right:0;display:flex;justify-content:flex-end;pointer-events:none;padding:calc((var(--tui-height) - 1.5rem) / 2) 1rem}:host[data-size=m] .t-icons{padding:calc((var(--tui-height) - 1.5rem) / 2) .625rem}.t-icons>:not(:first-child){-webkit-margin-start:.25rem;margin-inline-start:.25rem}.t-icon{position:relative;display:flex;width:1.5rem;height:1.5rem;align-items:center;justify-content:center;box-sizing:border-box;cursor:pointer;pointer-events:none}.t-icon_left{-webkit-margin-end:auto;margin-inline-end:auto}.t-cleaner{position:relative;display:flex;width:1.5rem;height:1.5rem;align-items:center;justify-content:center;box-sizing:border-box;cursor:pointer;pointer-events:none;pointer-events:auto}:host._readonly .t-cleaner,:host._disabled .t-cleaner{pointer-events:none}.t-counter{position:absolute;right:.75rem;bottom:.5rem;font:var(--tui-font-text-s);pointer-events:none;margin-top:auto;text-align:right;color:var(--tui-text-03)}:host[data-mode=onDark] .t-counter{color:var(--tui-text-03-night)}\n"], components: [{ type: i1.TuiScrollbarComponent, selector: "tui-scrollbar", inputs: ["hidden"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiTooltipComponent, selector: "tui-tooltip", inputs: ["content", "direction", "appearance", "showDelay", "hideDelay", "describeId"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.TuiWrapperDirective, selector: "[tuiWrapper]", inputs: ["disabled", "readOnly", "hover", "active", "focus", "invalid", "appearance"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.TuiFocusableDirective, selector: "[tuiFocusable]", inputs: ["tuiFocusable"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i2.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
132
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaComponent, decorators: [{
133
+ type: Component,
134
+ args: [{
135
+ selector: 'tui-textarea, tui-text-area',
136
+ templateUrl: './textarea.template.html',
137
+ styleUrls: ['./textarea.style.less'],
138
+ changeDetection: ChangeDetectionStrategy.OnPush,
139
+ providers: [
140
+ tuiAsFocusableItemAccessor(TuiTextareaComponent),
141
+ tuiAsControl(TuiTextareaComponent),
142
+ TEXTFIELD_CONTROLLER_PROVIDER,
143
+ MODE_PROVIDER,
144
+ ],
145
+ host: {
146
+ '($.data-mode.attr)': 'mode$',
147
+ '[class._ios]': 'isIOS',
148
+ },
149
+ }]
150
+ }], ctorParameters: function () { return [{ type: i3.NgControl, decorators: [{
151
+ type: Optional
152
+ }, {
153
+ type: Self
154
+ }, {
155
+ type: Inject,
156
+ args: [NgControl]
157
+ }] }, { type: i0.ChangeDetectorRef, decorators: [{
158
+ type: Inject,
159
+ args: [ChangeDetectorRef]
160
+ }] }, { type: undefined, decorators: [{
161
+ type: Inject,
162
+ args: [TUI_IS_IOS]
163
+ }] }, { type: i6.Observable, decorators: [{
164
+ type: Inject,
165
+ args: [TUI_MODE]
166
+ }] }, { type: i1.TuiTextfieldController, decorators: [{
167
+ type: Inject,
168
+ args: [TUI_TEXTFIELD_WATCHED_CONTROLLER]
169
+ }] }, { type: i1.TuiHintOptionsDirective, decorators: [{
170
+ type: Optional
171
+ }, {
172
+ type: Inject,
173
+ args: [TuiHintOptionsDirective]
174
+ }] }]; }, propDecorators: { focusableElement: [{
175
+ type: ViewChild,
176
+ args: ['focusableElement']
177
+ }], textfield: [{
178
+ type: ContentChild,
179
+ args: [TuiTextfieldComponent, { read: ElementRef }]
180
+ }], rows: [{
181
+ type: Input
182
+ }], maxLength: [{
183
+ type: Input
184
+ }], expandable: [{
185
+ type: Input
186
+ }, {
187
+ type: HostBinding,
188
+ args: ['class._expandable']
189
+ }], labelOutside: [{
190
+ type: HostBinding,
191
+ args: ['class._label-outside']
192
+ }], size: [{
193
+ type: HostBinding,
194
+ args: ['attr.data-size']
195
+ }], borderStart: [{
196
+ type: HostBinding,
197
+ args: ['style.--border-start.rem']
198
+ }], borderEnd: [{
199
+ type: HostBinding,
200
+ args: ['style.--border-end.rem']
201
+ }], hasTooltip: [{
202
+ type: HostBinding,
203
+ args: ['class._has-tooltip']
204
+ }], hasValue: [{
205
+ type: HostBinding,
206
+ args: ['class._has-value']
207
+ }], hasCounter: [{
208
+ type: HostBinding,
209
+ args: ['class._has-counter']
210
+ }], onFocused: [{
211
+ type: HostListener,
212
+ args: ['focusin', ['true']]
213
+ }, {
214
+ type: HostListener,
215
+ args: ['focusout', ['false']]
216
+ }] } });
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/textarea/textarea.component.ts","../../../../../projects/kit/components/textarea/textarea.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    TUI_IS_IOS,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    TuiFocusableElementAccessor,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {\n    MODE_PROVIDER,\n    TEXTFIELD_CONTROLLER_PROVIDER,\n    TUI_ICON_PADDINGS,\n    TUI_MODE,\n    TUI_TEXTFIELD_WATCHED_CONTROLLER,\n    TuiBrightness,\n    tuiGetBorder,\n    TuiHintOptionsDirective,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldComponent,\n    TuiTextfieldController,\n} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\n\nexport const DEFAULT_ROWS = 20;\nexport const LINE_HEIGHT_M = 20;\nexport const LINE_HEIGHT_L = 24;\n\n@Component({\n    selector: 'tui-textarea, tui-text-area',\n    templateUrl: './textarea.template.html',\n    styleUrls: ['./textarea.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiTextareaComponent),\n        tuiAsControl(TuiTextareaComponent),\n        TEXTFIELD_CONTROLLER_PROVIDER,\n        MODE_PROVIDER,\n    ],\n    host: {\n        '($.data-mode.attr)': 'mode$',\n        '[class._ios]': 'isIOS',\n    },\n})\nexport class TuiTextareaComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild('focusableElement')\n    private readonly focusableElement?: ElementRef<HTMLTextAreaElement>;\n\n    @ContentChild(TuiTextfieldComponent, {read: ElementRef})\n    private readonly textfield?: ElementRef<HTMLTextAreaElement>;\n\n    @Input()\n    rows = DEFAULT_ROWS;\n\n    @Input()\n    maxLength: number | null = null;\n\n    @Input()\n    @HostBinding('class._expandable')\n    expandable = false;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_IS_IOS) readonly isIOS: boolean,\n        @Inject(TUI_MODE) readonly mode$: Observable<TuiBrightness | null>,\n        @Inject(TUI_TEXTFIELD_WATCHED_CONTROLLER)\n        readonly controller: TuiTextfieldController,\n        @Optional()\n        @Inject(TuiHintOptionsDirective)\n        readonly hintOptions: TuiHintOptionsDirective | null,\n    ) {\n        super(control, cdr);\n    }\n\n    @HostBinding('class._label-outside')\n    get labelOutside(): boolean {\n        return this.controller.labelOutside;\n    }\n\n    get nativeFocusableElement(): HTMLTextAreaElement | null {\n        if (this.computedDisabled) {\n            return null;\n        }\n\n        return (\n            this.textfield?.nativeElement || this.focusableElement?.nativeElement || null\n        );\n    }\n\n    get focused(): boolean {\n        return tuiIsNativeFocused(this.nativeFocusableElement);\n    }\n\n    get appearance(): string {\n        return this.controller.appearance;\n    }\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.controller.size;\n    }\n\n    @HostBinding('style.--border-start.rem')\n    get borderStart(): number {\n        return this.iconLeftContent ? TUI_ICON_PADDINGS[this.size] : 0;\n    }\n\n    @HostBinding('style.--border-end.rem')\n    get borderEnd(): number {\n        return tuiGetBorder(\n            !!this.iconContent,\n            this.hasCleaner,\n            this.hasTooltip,\n            this.hasCustomContent,\n            this.size,\n        );\n    }\n\n    get hasCleaner(): boolean {\n        return this.controller.cleaner && this.hasValue && this.interactive;\n    }\n\n    @HostBinding('class._has-tooltip')\n    get hasTooltip(): boolean {\n        return (\n            !!this.hintOptions?.content &&\n            (this.controller.options.hintOnDisabled || !this.computedDisabled)\n        );\n    }\n\n    @HostBinding('class._has-value')\n    get hasValue(): boolean {\n        return this.value !== '';\n    }\n\n    @HostBinding('class._has-counter')\n    get hasCounter(): boolean {\n        return !!this.maxLength && this.interactive;\n    }\n\n    get hasPlaceholder(): boolean {\n        return this.placeholderRaisable || (!this.hasValue && !this.hasExampleText);\n    }\n\n    get hasCustomContent(): boolean {\n        return !!this.controller.customContent;\n    }\n\n    get iconLeftContent(): PolymorpheusContent<\n        TuiContextWithImplicit<TuiSizeL | TuiSizeS>\n    > {\n        return this.controller.iconLeft;\n    }\n\n    get iconContent(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>> {\n        return this.controller.icon;\n    }\n\n    get iconCleaner(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>> {\n        return this.controller.options.iconCleaner;\n    }\n\n    get hasExampleText(): boolean {\n        return (\n            !!this.textfield?.nativeElement.placeholder &&\n            this.focused &&\n            !this.hasValue &&\n            !this.readOnly\n        );\n    }\n\n    get computeMaxHeight(): number | null {\n        return this.expandable ? this.rows * this.lineHeight : null;\n    }\n\n    get placeholderRaised(): boolean {\n        return (\n            this.placeholderRaisable &&\n            ((this.computedFocused && !this.readOnly) || this.hasValue)\n        );\n    }\n\n    get fittedContent(): string {\n        return this.value.slice(0, this.maxLength || Infinity);\n    }\n\n    get extraContent(): string {\n        return this.value.slice(this.maxLength || Infinity);\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    onValueChange(value: string): void {\n        this.value = value;\n    }\n\n    onMouseDown(event: MouseEvent): void {\n        if (event.target === this.nativeFocusableElement) {\n            return;\n        }\n\n        event.preventDefault();\n\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.focus();\n        }\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n\n    private get lineHeight(): number {\n        return this.controller.size === 'm' ? LINE_HEIGHT_M : LINE_HEIGHT_L;\n    }\n\n    private get placeholderRaisable(): boolean {\n        return this.size !== 's' && !this.controller.labelOutside;\n    }\n}\n","<ng-container *ngIf=\"hintOptions?.change$ | async\"></ng-container>\n<div\n    tuiWrapper\n    automation-id=\"tui-text-area__wrapper\"\n    class=\"t-outline\"\n    [appearance]=\"appearance\"\n    [disabled]=\"disabled\"\n    [focus]=\"computedFocused\"\n    [hover]=\"pseudoHover\"\n    [readOnly]=\"readOnly\"\n    [invalid]=\"computedInvalid\"\n>\n    <div\n        *ngIf=\"hasCounter\"\n        automation-id=\"tui-text-area__counter\"\n        class=\"t-counter\"\n    >\n        {{ value.length }}/{{ maxLength }}\n    </div>\n\n    <label\n        class=\"t-content\"\n        (mousedown)=\"onMouseDown($event)\"\n    >\n        <div class=\"t-wrapper\">\n            <div\n                *ngIf=\"hasPlaceholder\"\n                automation-id=\"tui-text-area__placeholder\"\n                class=\"t-placeholder\"\n                [class.t-placeholder_raised]=\"placeholderRaised\"\n            >\n                <ng-content></ng-content>\n            </div>\n            <tui-scrollbar\n                automation-id=\"tui-text-area__scrollbar\"\n                class=\"t-box\"\n                [style.maxHeight.px]=\"computeMaxHeight\"\n            >\n                <div class=\"t-input-wrapper\">\n                    <div class=\"t-relative\">\n                        <div\n                            aria-hidden=\"true\"\n                            class=\"t-pseudo-content\"\n                        >\n                            <span [textContent]=\"fittedContent || nativeFocusableElement?.placeholder\"></span>\n                            <span\n                                class=\"t-pseudo-content__extra\"\n                                [textContent]=\"extraContent\"\n                            ></span>\n                            &nbsp;\n                        </div>\n                        <textarea\n                            #focusableElement\n                            automation-id=\"tui-text-area__native\"\n                            class=\"t-input\"\n                            [id]=\"id\"\n                            [tuiFocusable]=\"computedFocusable\"\n                            [disabled]=\"computedDisabled\"\n                            [readOnly]=\"readOnly\"\n                            [(ngModel)]=\"value\"\n                        ></textarea>\n                        <ng-content select=\"textarea\"></ng-content>\n                    </div>\n                </div>\n            </tui-scrollbar>\n        </div>\n        <div class=\"t-icons\">\n            <div\n                *ngIf=\"iconLeftContent\"\n                class=\"t-icon t-icon_left t-textfield-icon\"\n            >\n                <tui-svg\n                    *polymorpheusOutlet=\"iconLeftContent as src; context: {$implicit: size}\"\n                    tuiWrapper\n                    appearance=\"icon\"\n                    [src]=\"src\"\n                ></tui-svg>\n            </div>\n            <ng-container *ngIf=\"hasCustomContent\">\n                <tui-svg\n                    *polymorpheusOutlet=\"controller.customContent as src\"\n                    [src]=\"src\"\n                ></tui-svg>\n            </ng-container>\n            <ng-container *ngIf=\"hasCleaner\">\n                <tui-svg\n                    *polymorpheusOutlet=\"iconCleaner as src; context: {$implicit: size}\"\n                    tuiWrapper\n                    appearance=\"icon\"\n                    class=\"t-cleaner\"\n                    [src]=\"src\"\n                    (click.stop)=\"onValueChange('')\"\n                ></tui-svg>\n            </ng-container>\n            <tui-tooltip\n                *ngIf=\"hasTooltip\"\n                automation-id=\"tui-text-area__tooltip\"\n                [describeId]=\"id\"\n                [content]=\"hintOptions?.content\"\n            ></tui-tooltip>\n            <div\n                *ngIf=\"iconContent\"\n                class=\"t-icon t-textfield-icon\"\n            >\n                <tui-svg\n                    *polymorpheusOutlet=\"iconContent as src; context: {$implicit: size}\"\n                    tuiWrapper\n                    appearance=\"icon\"\n                    [src]=\"src\"\n                ></tui-svg>\n            </div>\n        </div>\n    </label>\n</div>\n"]}
@@ -0,0 +1,19 @@
1
+ import { Directive } from '@angular/core';
2
+ import { AbstractTuiTextfieldHost, tuiAsTextfieldHost } from '@taiga-ui/core';
3
+ import * as i0 from "@angular/core";
4
+ // TODO: delete `tui-text-area` in v4.0
5
+ export class TuiTextareaDirective extends AbstractTuiTextfieldHost {
6
+ onValueChange(value) {
7
+ this.host.onValueChange(value);
8
+ }
9
+ }
10
+ TuiTextareaDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
11
+ TuiTextareaDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiTextareaDirective, selector: "tui-textarea, tui-text-area", providers: [tuiAsTextfieldHost(TuiTextareaDirective)], usesInheritance: true, ngImport: i0 });
12
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaDirective, decorators: [{
13
+ type: Directive,
14
+ args: [{
15
+ selector: 'tui-textarea, tui-text-area',
16
+ providers: [tuiAsTextfieldHost(TuiTextareaDirective)],
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvdGV4dGFyZWEvdGV4dGFyZWEuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEMsT0FBTyxFQUFDLHdCQUF3QixFQUFFLGtCQUFrQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7O0FBSTVFLHVDQUF1QztBQUt2QyxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsd0JBQThDO0lBQ3BGLGFBQWEsQ0FBQyxLQUFhO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25DLENBQUM7O2tIQUhRLG9CQUFvQjtzR0FBcEIsb0JBQW9CLHNEQUZsQixDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixDQUFDLENBQUM7NEZBRTVDLG9CQUFvQjtrQkFKaEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsNkJBQTZCO29CQUN2QyxTQUFTLEVBQUUsQ0FBQyxrQkFBa0Isc0JBQXNCLENBQUM7aUJBQ3hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBYnN0cmFjdFR1aVRleHRmaWVsZEhvc3QsIHR1aUFzVGV4dGZpZWxkSG9zdH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5pbXBvcnQge1R1aVRleHRhcmVhQ29tcG9uZW50fSBmcm9tICcuL3RleHRhcmVhLmNvbXBvbmVudCc7XG5cbi8vIFRPRE86IGRlbGV0ZSBgdHVpLXRleHQtYXJlYWAgaW4gdjQuMFxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICd0dWktdGV4dGFyZWEsIHR1aS10ZXh0LWFyZWEnLFxuICAgIHByb3ZpZGVyczogW3R1aUFzVGV4dGZpZWxkSG9zdChUdWlUZXh0YXJlYURpcmVjdGl2ZSldLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlUZXh0YXJlYURpcmVjdGl2ZSBleHRlbmRzIEFic3RyYWN0VHVpVGV4dGZpZWxkSG9zdDxUdWlUZXh0YXJlYUNvbXBvbmVudD4ge1xuICAgIG9uVmFsdWVDaGFuZ2UodmFsdWU6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLmhvc3Qub25WYWx1ZUNoYW5nZSh2YWx1ZSk7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,51 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { TuiFocusableModule } from '@taiga-ui/cdk';
5
+ import { TuiPrimitiveTextfieldModule, TuiScrollbarModule, TuiSvgModule, TuiTextfieldComponent, TuiTooltipModule, TuiWrapperModule, } from '@taiga-ui/core';
6
+ import { PolymorpheusModule } from '@tinkoff/ng-polymorpheus';
7
+ import { TuiTextareaComponent } from './textarea.component';
8
+ import { TuiTextareaDirective } from './textarea.directive';
9
+ import * as i0 from "@angular/core";
10
+ export class TuiTextareaModule {
11
+ }
12
+ TuiTextareaModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
13
+ TuiTextareaModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaModule, declarations: [TuiTextareaComponent, TuiTextareaDirective], imports: [CommonModule,
14
+ FormsModule,
15
+ TuiFocusableModule,
16
+ TuiScrollbarModule,
17
+ TuiTooltipModule,
18
+ TuiWrapperModule,
19
+ TuiSvgModule,
20
+ TuiPrimitiveTextfieldModule,
21
+ PolymorpheusModule], exports: [TuiTextareaComponent, TuiTextareaDirective, TuiTextfieldComponent] });
22
+ TuiTextareaModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaModule, imports: [[
23
+ CommonModule,
24
+ FormsModule,
25
+ TuiFocusableModule,
26
+ TuiScrollbarModule,
27
+ TuiTooltipModule,
28
+ TuiWrapperModule,
29
+ TuiSvgModule,
30
+ TuiPrimitiveTextfieldModule,
31
+ PolymorpheusModule,
32
+ ]] });
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextareaModule, decorators: [{
34
+ type: NgModule,
35
+ args: [{
36
+ imports: [
37
+ CommonModule,
38
+ FormsModule,
39
+ TuiFocusableModule,
40
+ TuiScrollbarModule,
41
+ TuiTooltipModule,
42
+ TuiWrapperModule,
43
+ TuiSvgModule,
44
+ TuiPrimitiveTextfieldModule,
45
+ PolymorpheusModule,
46
+ ],
47
+ declarations: [TuiTextareaComponent, TuiTextareaDirective],
48
+ exports: [TuiTextareaComponent, TuiTextareaDirective, TuiTextfieldComponent],
49
+ }]
50
+ }] });
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvdGV4dGFyZWEvdGV4dGFyZWEubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUNILDJCQUEyQixFQUMzQixrQkFBa0IsRUFDbEIsWUFBWSxFQUNaLHFCQUFxQixFQUNyQixnQkFBZ0IsRUFDaEIsZ0JBQWdCLEdBQ25CLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFFNUQsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDMUQsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7O0FBaUIxRCxNQUFNLE9BQU8saUJBQWlCOzsrR0FBakIsaUJBQWlCO2dIQUFqQixpQkFBaUIsaUJBSFgsb0JBQW9CLEVBQUUsb0JBQW9CLGFBVnJELFlBQVk7UUFDWixXQUFXO1FBQ1gsa0JBQWtCO1FBQ2xCLGtCQUFrQjtRQUNsQixnQkFBZ0I7UUFDaEIsZ0JBQWdCO1FBQ2hCLFlBQVk7UUFDWiwyQkFBMkI7UUFDM0Isa0JBQWtCLGFBR1osb0JBQW9CLEVBQUUsb0JBQW9CLEVBQUUscUJBQXFCO2dIQUVsRSxpQkFBaUIsWUFkakI7WUFDTCxZQUFZO1lBQ1osV0FBVztZQUNYLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osMkJBQTJCO1lBQzNCLGtCQUFrQjtTQUNyQjs0RkFJUSxpQkFBaUI7a0JBZjdCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxrQkFBa0I7d0JBQ2xCLGtCQUFrQjt3QkFDbEIsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLFlBQVk7d0JBQ1osMkJBQTJCO3dCQUMzQixrQkFBa0I7cUJBQ3JCO29CQUNELFlBQVksRUFBRSxDQUFDLG9CQUFvQixFQUFFLG9CQUFvQixDQUFDO29CQUMxRCxPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUIsQ0FBQztpQkFDL0UiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtUdWlGb2N1c2FibGVNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtcbiAgICBUdWlQcmltaXRpdmVUZXh0ZmllbGRNb2R1bGUsXG4gICAgVHVpU2Nyb2xsYmFyTW9kdWxlLFxuICAgIFR1aVN2Z01vZHVsZSxcbiAgICBUdWlUZXh0ZmllbGRDb21wb25lbnQsXG4gICAgVHVpVG9vbHRpcE1vZHVsZSxcbiAgICBUdWlXcmFwcGVyTW9kdWxlLFxufSBmcm9tICdAdGFpZ2EtdWkvY29yZSc7XG5pbXBvcnQge1BvbHltb3JwaGV1c01vZHVsZX0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxuaW1wb3J0IHtUdWlUZXh0YXJlYUNvbXBvbmVudH0gZnJvbSAnLi90ZXh0YXJlYS5jb21wb25lbnQnO1xuaW1wb3J0IHtUdWlUZXh0YXJlYURpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0YXJlYS5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBGb3Jtc01vZHVsZSxcbiAgICAgICAgVHVpRm9jdXNhYmxlTW9kdWxlLFxuICAgICAgICBUdWlTY3JvbGxiYXJNb2R1bGUsXG4gICAgICAgIFR1aVRvb2x0aXBNb2R1bGUsXG4gICAgICAgIFR1aVdyYXBwZXJNb2R1bGUsXG4gICAgICAgIFR1aVN2Z01vZHVsZSxcbiAgICAgICAgVHVpUHJpbWl0aXZlVGV4dGZpZWxkTW9kdWxlLFxuICAgICAgICBQb2x5bW9ycGhldXNNb2R1bGUsXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtUdWlUZXh0YXJlYUNvbXBvbmVudCwgVHVpVGV4dGFyZWFEaXJlY3RpdmVdLFxuICAgIGV4cG9ydHM6IFtUdWlUZXh0YXJlYUNvbXBvbmVudCwgVHVpVGV4dGFyZWFEaXJlY3RpdmUsIFR1aVRleHRmaWVsZENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aVRleHRhcmVhTW9kdWxlIHt9XG4iXX0=
@@ -50,6 +50,11 @@ export class TuiTileComponent {
50
50
  onTransitionEnd() {
51
51
  this.dragged = false;
52
52
  }
53
+ ngOnDestroy() {
54
+ if (this.tiles.element === this.element) {
55
+ this.tiles.element = null;
56
+ }
57
+ }
53
58
  }
54
59
  TuiTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTileComponent, deps: [{ token: NgZone }, { token: ElementRef }, { token: TuiTilesComponent }, { token: TuiResizeService }, { token: MutationObserverService }], target: i0.ɵɵFactoryTarget.Component });
55
60
  TuiTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiTileComponent, selector: "tui-tile", inputs: { width: "width", height: "height" }, host: { listeners: { "pointerenter": "onEnter()" }, properties: { "class._dragged": "this.dragged", "style.gridColumn": "this.column", "style.gridRow": "this.row" } }, ngImport: i0, template: "<div\n *ngIf=\"position$ | async as position\"\n class=\"t-wrapper\"\n [style.top.px]=\"position.top\"\n [style.left.px]=\"position.left\"\n [style.width.px]=\"position.width\"\n [style.height.px]=\"position.height\"\n (transitionend.self)=\"onTransitionEnd()\"\n>\n <ng-content></ng-content>\n</div>\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
@@ -92,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
92
97
  type: HostListener,
93
98
  args: ['pointerenter']
94
99
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy90aWxlcy90aWxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3RpbGVzL3RpbGUudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsV0FBVyxFQUNYLFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUNMLE1BQU0sR0FDVCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RSxPQUFPLEVBQUMscUJBQXFCLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBQyxlQUFlLEVBQUUsYUFBYSxFQUFhLE1BQU0sTUFBTSxDQUFDO0FBQ2hFLE9BQU8sRUFBQyxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRWxGLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLG1CQUFtQixDQUFDOzs7OztBQU9wRCxNQUFNLE9BQU8sZ0JBQWdCO0lBMkJ6QixZQUNxQyxNQUFjLEVBQ1YsRUFBMkIsRUFDcEIsS0FBd0IsRUFDekIsT0FBNEIsRUFDckIsU0FBOEI7UUFKL0MsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNWLE9BQUUsR0FBRixFQUFFLENBQXlCO1FBQ3BCLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBQ3pCLFlBQU8sR0FBUCxPQUFPLENBQXFCO1FBQ3JCLGNBQVMsR0FBVCxTQUFTLENBQXFCO1FBOUJwRixVQUFLLEdBQUcsQ0FBQyxDQUFDO1FBR1YsV0FBTSxHQUFHLENBQUMsQ0FBQztRQUdYLFlB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dCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEVsZW1lbnRSZWYsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgSG9zdExpc3RlbmVyLFxuICAgIEluamVjdCxcbiAgICBJbnB1dCxcbiAgICBOZ1pvbmUsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtNdXRhdGlvbk9ic2VydmVyU2VydmljZX0gZnJvbSAnQG5nLXdlYi1hcGlzL211dGF0aW9uLW9ic2VydmVyJztcbmltcG9ydCB7dHVpQXJyYXlTaGFsbG93RXF1YWxzLCBUdWlSZXNpemVTZXJ2aWNlLCB0dWlab25lZnVsbH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgY29tYmluZUxhdGVzdCwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge2RlYm91bmNlVGltZSwgZGlzdGluY3RVbnRpbENoYW5nZWQsIG1hcCwgc3RhcnRXaXRofSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7VHVpVGlsZXNDb21wb25lbnR9IGZyb20gJy4vdGlsZXMuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd0dWktdGlsZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RpbGUudGVtcGxhdGUuaHRtbCcsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aVRpbGVDb21wb25lbnQge1xuICAgIEBJbnB1dCgpXG4gICAgd2lkdGggPSAxO1xuXG4gICAgQElucHV0KClcbiAgICBoZWlnaHQgPSAxO1xuXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy5fZHJhZ2dlZCcpXG4gICAgZHJhZ2dlZCA9IGZhbHNlO1xuXG4gICAgcmVhZG9ubHkgb2Zmc2V0JCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8W251bWJlciwgbnVtYmVyXT4oWzAsIDBdKTtcblxuICAgIHJlYWRvbmx5IHBvc2l0aW9uJCA9IGNvbWJpbmVMYXRlc3QoW1xuICAgICAgICB0aGlzLm9mZnNldCQucGlwZShkaXN0aW5jdFVudGlsQ2hhbmdlZCh0dWlBcnJheVNoYWxsb3dFcXVhbHMpKSxcbiAgICAgICAgdGhpcy5yZXNpemUkLnBpcGUoc3RhcnRXaXRoKG51bGwpKSxcbiAgICAgICAgdGhpcy5tdXRhdGlvbiQucGlwZShzdGFydFdpdGgobnVsbCkpLFxuICAgICAgICB0aGlzLnRpbGVzLm9yZGVyJC5waXBlKGRlYm91bmNlVGltZSgwKSksXG4gICAgXSkucGlwZShcbiAgICAgICAgbWFwKChbW2xlZnQsIHRvcF1dKSA9PiAoe1xuICAgICAgICAgICAgdG9wOiB0b3AgfHwgdGhpcy5lbGVtZW50Lm9mZnNldFRvcCxcbiAgICAgICAgICAgIGxlZnQ6IGxlZnQgfHwgdGhpcy5lbGVtZW50Lm9mZnNldExlZnQsXG4gICAgICAgICAgICB3aWR0aDogdGhpcy5lbGVtZW50LmNsaWVudFdpZHRoLFxuICAgICAgICAgICAgaGVpZ2h0OiB0aGlzLmVsZW1lbnQuY2xpZW50SGVpZ2h0LFxuICAgICAgICB9KSksXG4gICAgICAgIHR1aVpvbmVmdWxsKHRoaXMubmdab25lKSxcbiAgICApO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIEBJbmplY3QoTmdab25lKSBwcml2YXRlIHJlYWRvbmx5IG5nWm9uZTogTmdab25lLFxuICAgICAgICBASW5qZWN0KEVsZW1lbnRSZWYpIHByaXZhdGUgcmVhZG9ubHkgZWw6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxuICAgICAgICBASW5qZWN0KFR1aVRpbGVzQ29tcG9uZW50KSBwcml2YXRlIHJlYWRvbmx5IHRpbGVzOiBUdWlUaWxlc0NvbXBvbmVudCxcbiAgICAgICAgQEluamVjdChUdWlSZXNpemVTZXJ2aWNlKSBwcml2YXRlIHJlYWRvbmx5IHJlc2l6ZSQ6IE9ic2VydmFibGU8dW5rbm93bj4sXG4gICAgICAgIEBJbmplY3QoTXV0YXRpb25PYnNlcnZlclNlcnZpY2UpIHByaXZhdGUgcmVhZG9ubHkgbXV0YXRpb24kOiBPYnNlcnZhYmxlPHVua25vd24+LFxuICAgICkge31cblxuICAgIEBIb3N0QmluZGluZygnc3R5bGUuZ3JpZENvbHVtbicpXG4gICAgZ2V0IGNvbHVtbigpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gYHNwYW4gdmFyKC0tdHVpLXdpZHRoLCAke3RoaXMud2lkdGh9KWA7XG4gICAgfVxuXG4gICAgQEhvc3RCaW5kaW5nKCdzdHlsZS5ncmlkUm93JylcbiAgICBnZXQgcm93KCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiBgc3BhbiB2YXIoLS10dWktaGVpZ2h0LCAke3RoaXMuaGVpZ2h0fSlgO1xuICAgIH1cblxuICAgIGdldCBlbGVtZW50KCk6IEhUTUxFbGVtZW50IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWwubmF0aXZlRWxlbWVudDtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdwb2ludGVyZW50ZXInKVxuICAgIG9uRW50ZXIoKTogdm9pZCB7XG4gICAgICAgIHRoaXMudGlsZXMucmVhcnJhbmdlKHRoaXMuZWxlbWVudCk7XG4gICAgfVxuXG4gICAgb25EcmFnKGRyYWdnZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5kcmFnZ2VkID0gdGhpcy5kcmFnZ2VkIHx8IGRyYWdnZWQ7XG4gICAgICAgIHRoaXMudGlsZXMuZWxlbWVudCA9IGRyYWdnZWQgPyB0aGlzLmVsZW1lbnQgOiBudWxsO1xuICAgIH1cblxuICAgIG9uVHJhbnNpdGlvbkVuZCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5kcmFnZ2VkID0gZmFsc2U7XG4gICAgfVxufVxuIiwiPGRpdlxuICAgICpuZ0lmPVwicG9zaXRpb24kIHwgYXN5bmMgYXMgcG9zaXRpb25cIlxuICAgIGNsYXNzPVwidC13cmFwcGVyXCJcbiAgICBbc3R5bGUudG9wLnB4XT1cInBvc2l0aW9uLnRvcFwiXG4gICAgW3N0eWxlLmxlZnQucHhdPVwicG9zaXRpb24ubGVmdFwiXG4gICAgW3N0eWxlLndpZHRoLnB4XT1cInBvc2l0aW9uLndpZHRoXCJcbiAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cInBvc2l0aW9uLmhlaWdodFwiXG4gICAgKHRyYW5zaXRpb25lbmQuc2VsZik9XCJvblRyYW5zaXRpb25FbmQoKVwiXG4+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9kaXY+XG4iXX0=
100
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy90aWxlcy90aWxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3RpbGVzL3RpbGUudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsV0FBVyxFQUNYLFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUNMLE1BQU0sR0FFVCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RSxPQUFPLEVBQUMscUJBQXFCLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBQyxlQUFlLEVBQUUsYUFBYSxFQUFhLE1BQU0sTUFBTSxDQUFDO0FBQ2hFLE9BQU8sRUFBQyxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRWxGLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLG1CQUFtQixDQUFDOzs7OztBQU9wRCxNQUFNLE9BQU8sZ0JBQWdCO0lBMkJ6QixZQUNxQyxNQUFjLEVBQ1YsRUFBMkIsRUFDcEIsS0FBd0IsRUFDekIsT0FBNEIsRUFDckIsU0FBOEI7UUFKL0MsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNWLE9BQUUsR0FBRixFQUFFLENBQXlCO1FBQ3BCLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBQ3pCLFlBQU8sR0FBUCxPQUFPLENBQXFCO1FBQ3JCLGNBQVMsR0FBVCxTQUFTLENBQXFCO1FBOUJwRixVQUFLLEdBQUcsQ0FBQyxDQUFDO1FBR1YsV0FBTSxHQUFHLENBQUMsQ0FBQztRQUdYLFlB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QjtnQkE2QnpCLE1BQU07c0JBRFQsV0FBVzt1QkFBQyxrQkFBa0I7Z0JBTTNCLEdBQUc7c0JBRE4sV0FBVzt1QkFBQyxlQUFlO2dCQVU1QixPQUFPO3NCQUROLFlBQVk7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEVsZW1lbnRSZWYsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgSG9zdExpc3RlbmVyLFxuICAgIEluamVjdCxcbiAgICBJbnB1dCxcbiAgICBOZ1pvbmUsXG4gICAgT25EZXN0cm95LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TXV0YXRpb25PYnNlcnZlclNlcnZpY2V9IGZyb20gJ0BuZy13ZWItYXBpcy9tdXRhdGlvbi1vYnNlcnZlcic7XG5pbXBvcnQge3R1aUFycmF5U2hhbGxvd0VxdWFscywgVHVpUmVzaXplU2VydmljZSwgdHVpWm9uZWZ1bGx9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIGNvbWJpbmVMYXRlc3QsIE9ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtkZWJvdW5jZVRpbWUsIGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBtYXAsIHN0YXJ0V2l0aH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge1R1aVRpbGVzQ29tcG9uZW50fSBmcm9tICcuL3RpbGVzLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAndHVpLXRpbGUnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi90aWxlLnRlbXBsYXRlLmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlUaWxlQ29tcG9uZW50IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgICBASW5wdXQoKVxuICAgIHdpZHRoID0gMTtcblxuICAgIEBJbnB1dCgpXG4gICAgaGVpZ2h0ID0gMTtcblxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuX2RyYWdnZWQnKVxuICAgIGRyYWdnZWQgPSBmYWxzZTtcblxuICAgIHJlYWRvbmx5IG9mZnNldCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFtudW1iZXIsIG51bWJlcl0+KFswLCAwXSk7XG5cbiAgICByZWFkb25seSBwb3NpdGlvbiQgPSBjb21iaW5lTGF0ZXN0KFtcbiAgICAgICAgdGhpcy5vZmZzZXQkLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQodHVpQXJyYXlTaGFsbG93RXF1YWxzKSksXG4gICAgICAgIHRoaXMucmVzaXplJC5waXBlKHN0YXJ0V2l0aChudWxsKSksXG4gICAgICAgIHRoaXMubXV0YXRpb24kLnBpcGUoc3RhcnRXaXRoKG51bGwpKSxcbiAgICAgICAgdGhpcy50aWxlcy5vcmRlciQucGlwZShkZWJvdW5jZVRpbWUoMCkpLFxuICAgIF0pLnBpcGUoXG4gICAgICAgIG1hcCgoW1tsZWZ0LCB0b3BdXSkgPT4gKHtcbiAgICAgICAgICAgIHRvcDogdG9wIHx8IHRoaXMuZWxlbWVudC5vZmZzZXRUb3AsXG4gICAgICAgICAgICBsZWZ0OiBsZWZ0IHx8IHRoaXMuZWxlbWVudC5vZmZzZXRMZWZ0LFxuICAgICAgICAgICAgd2lkdGg6IHRoaXMuZWxlbWVudC5jbGllbnRXaWR0aCxcbiAgICAgICAgICAgIGhlaWdodDogdGhpcy5lbGVtZW50LmNsaWVudEhlaWdodCxcbiAgICAgICAgfSkpLFxuICAgICAgICB0dWlab25lZnVsbCh0aGlzLm5nWm9uZSksXG4gICAgKTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KE5nWm9uZSkgcHJpdmF0ZSByZWFkb25seSBuZ1pvbmU6IE5nWm9uZSxcbiAgICAgICAgQEluamVjdChFbGVtZW50UmVmKSBwcml2YXRlIHJlYWRvbmx5IGVsOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcbiAgICAgICAgQEluamVjdChUdWlUaWxlc0NvbXBvbmVudCkgcHJpdmF0ZSByZWFkb25seSB0aWxlczogVHVpVGlsZXNDb21wb25lbnQsXG4gICAgICAgIEBJbmplY3QoVHVpUmVzaXplU2VydmljZSkgcHJpdmF0ZSByZWFkb25seSByZXNpemUkOiBPYnNlcnZhYmxlPHVua25vd24+LFxuICAgICAgICBASW5qZWN0KE11dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlKSBwcml2YXRlIHJlYWRvbmx5IG11dGF0aW9uJDogT2JzZXJ2YWJsZTx1bmtub3duPixcbiAgICApIHt9XG5cbiAgICBASG9zdEJpbmRpbmcoJ3N0eWxlLmdyaWRDb2x1bW4nKVxuICAgIGdldCBjb2x1bW4oKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIGBzcGFuIHZhcigtLXR1aS13aWR0aCwgJHt0aGlzLndpZHRofSlgO1xuICAgIH1cblxuICAgIEBIb3N0QmluZGluZygnc3R5bGUuZ3JpZFJvdycpXG4gICAgZ2V0IHJvdygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gYHNwYW4gdmFyKC0tdHVpLWhlaWdodCwgJHt0aGlzLmhlaWdodH0pYDtcbiAgICB9XG5cbiAgICBnZXQgZWxlbWVudCgpOiBIVE1MRWxlbWVudCB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQ7XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcigncG9pbnRlcmVudGVyJylcbiAgICBvbkVudGVyKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnRpbGVzLnJlYXJyYW5nZSh0aGlzLmVsZW1lbnQpO1xuICAgIH1cblxuICAgIG9uRHJhZyhkcmFnZ2VkOiBib29sZWFuKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZHJhZ2dlZCA9IHRoaXMuZHJhZ2dlZCB8fCBkcmFnZ2VkO1xuICAgICAgICB0aGlzLnRpbGVzLmVsZW1lbnQgPSBkcmFnZ2VkID8gdGhpcy5lbGVtZW50IDogbnVsbDtcbiAgICB9XG5cbiAgICBvblRyYW5zaXRpb25FbmQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZHJhZ2dlZCA9IGZhbHNlO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy50aWxlcy5lbGVtZW50ID09PSB0aGlzLmVsZW1lbnQpIHtcbiAgICAgICAgICAgIHRoaXMudGlsZXMuZWxlbWVudCA9IG51bGw7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8ZGl2XG4gICAgKm5nSWY9XCJwb3NpdGlvbiQgfCBhc3luYyBhcyBwb3NpdGlvblwiXG4gICAgY2xhc3M9XCJ0LXdyYXBwZXJcIlxuICAgIFtzdHlsZS50b3AucHhdPVwicG9zaXRpb24udG9wXCJcbiAgICBbc3R5bGUubGVmdC5weF09XCJwb3NpdGlvbi5sZWZ0XCJcbiAgICBbc3R5bGUud2lkdGgucHhdPVwicG9zaXRpb24ud2lkdGhcIlxuICAgIFtzdHlsZS5oZWlnaHQucHhdPVwicG9zaXRpb24uaGVpZ2h0XCJcbiAgICAodHJhbnNpdGlvbmVuZC5zZWxmKT1cIm9uVHJhbnNpdGlvbkVuZCgpXCJcbj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L2Rpdj5cbiJdfQ==
@@ -1,4 +1,5 @@
1
1
  import { ChangeDetectionStrategy, Component, forwardRef, HostBinding, Inject, } from '@angular/core';
2
+ import { TUI_COMMON_ICONS } from '@taiga-ui/core';
2
3
  import { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';
3
4
  import { TUI_DEFAULT_TREE_CONTROLLER } from '../../misc/tree.constants';
4
5
  // eslint-disable-next-line import/no-cycle
@@ -7,7 +8,8 @@ import * as i0 from "@angular/core";
7
8
  import * as i1 from "@taiga-ui/core";
8
9
  import * as i2 from "@angular/common";
9
10
  export class TuiTreeItemContentComponent {
10
- constructor(context, controller) {
11
+ constructor(icons, context, controller) {
12
+ this.icons = icons;
11
13
  this.context = context;
12
14
  this.controller = controller;
13
15
  }
@@ -22,8 +24,8 @@ export class TuiTreeItemContentComponent {
22
24
  this.controller.toggle(this.context.$implicit);
23
25
  }
24
26
  }
25
- TuiTreeItemContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTreeItemContentComponent, deps: [{ token: POLYMORPHEUS_CONTEXT }, { token: forwardRef(() => TUI_TREE_CONTROLLER) }], target: i0.ɵɵFactoryTarget.Component });
26
- TuiTreeItemContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiTreeItemContentComponent, selector: "tui-tree-item-content", host: { properties: { "class._expandable": "this.isExpandable" } }, ngImport: i0, template: "<button\n *ngIf=\"isExpandable\"\n tuiIconButton\n size=\"xs\"\n appearance=\"flat\"\n icon=\"tuiIconChevronRight\"\n shape=\"rounded\"\n type=\"button\"\n class=\"t-button\"\n [class.t-button_expanded]=\"isExpanded\"\n (click)=\"onClick()\"\n></button>\n<ng-container [ngTemplateOutlet]=\"context.template\"></ng-container>\n", styles: [":host{display:flex;align-items:center}:host :host-context(tui-tree-item._expandable):not(._expandable){padding-left:2rem}.t-button{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;margin-right:.5rem}.t-button_expanded{transform:rotate(90deg)}\n"], components: [{ type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
27
+ TuiTreeItemContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTreeItemContentComponent, deps: [{ token: TUI_COMMON_ICONS }, { token: POLYMORPHEUS_CONTEXT }, { token: forwardRef(() => TUI_TREE_CONTROLLER) }], target: i0.ɵɵFactoryTarget.Component });
28
+ TuiTreeItemContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiTreeItemContentComponent, selector: "tui-tree-item-content", host: { properties: { "class._expandable": "this.isExpandable" } }, ngImport: i0, template: "<button\n *ngIf=\"isExpandable\"\n tuiIconButton\n size=\"xs\"\n appearance=\"flat\"\n shape=\"rounded\"\n type=\"button\"\n class=\"t-button\"\n [class.t-button_expanded]=\"isExpanded\"\n [icon]=\"icons.more\"\n (click)=\"onClick()\"\n></button>\n<ng-container [ngTemplateOutlet]=\"context.template\"></ng-container>\n", styles: [":host{display:flex;align-items:center}:host :host-context(tui-tree-item._expandable):not(._expandable){padding-left:2rem}.t-button{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;margin-right:.5rem}.t-button_expanded{transform:rotate(90deg)}\n"], components: [{ type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
27
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTreeItemContentComponent, decorators: [{
28
30
  type: Component,
29
31
  args: [{
@@ -33,6 +35,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
33
35
  changeDetection: ChangeDetectionStrategy.OnPush,
34
36
  }]
35
37
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
38
+ type: Inject,
39
+ args: [TUI_COMMON_ICONS]
40
+ }] }, { type: undefined, decorators: [{
36
41
  type: Inject,
37
42
  args: [POLYMORPHEUS_CONTEXT]
38
43
  }] }, { type: undefined, decorators: [{
@@ -42,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
42
47
  type: HostBinding,
43
48
  args: ['class._expandable']
44
49
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1pdGVtLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvdHJlZS9jb21wb25lbnRzL3RyZWUtaXRlbS1jb250ZW50L3RyZWUtaXRlbS1jb250ZW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3RyZWUvY29tcG9uZW50cy90cmVlLWl0ZW0tY29udGVudC90cmVlLWl0ZW0tY29udGVudC50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixXQUFXLEVBQ1gsTUFBTSxHQUNULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBRTlELE9BQU8sRUFBQywyQkFBMkIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBRXRFLDJDQUEyQztBQUMzQyxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQzs7OztBQVEzRCxNQUFNLE9BQU8sMkJBQTJCO0lBQ3BDLFlBQzJDLE9BQTJCLEVBRWpELFVBQTZCO1FBRlAsWUFBTyxHQUFQLE9BQU8sQ0FBb0I7UUFFakQsZUFBVSxHQUFWLFVBQVUsQ0FBbUI7SUFDL0MsQ0FBQztJQUVKLElBQUksVUFBVTtRQUNWLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDO0lBQzdDLENBQUM7SUFFRCxJQUNJLFlBQVk7UUFDWixPQUFPLENBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsWUFBWTtZQUNuQyxJQUFJLENBQUMsVUFBVSxLQUFLLDJCQUEyQixDQUNsRCxDQUFDO0lBQ04sQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7O3lIQXJCUSwyQkFBMkIsa0JBRXhCLG9CQUFvQixhQUNwQixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsbUJBQW1CLENBQUM7NkdBSHhDLDJCQUEyQixpSUNwQnhDLHNXQWFBOzRGRE9hLDJCQUEyQjtrQkFOdkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxXQUFXLEVBQUUsbUNBQW1DO29CQUNoRCxTQUFTLEVBQUUsQ0FBQyxnQ0FBZ0MsQ0FBQztvQkFDN0MsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEOzswQkFHUSxNQUFNOzJCQUFDLG9CQUFvQjs7MEJBQzNCLE1BQU07MkJBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLG1CQUFtQixDQUFDOzRDQVM3QyxZQUFZO3NCQURmLFdBQVc7dUJBQUMsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgZm9yd2FyZFJlZixcbiAgICBIb3N0QmluZGluZyxcbiAgICBJbmplY3QsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtQT0xZTU9SUEhFVVNfQ09OVEVYVH0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxuaW1wb3J0IHtUVUlfREVGQVVMVF9UUkVFX0NPTlRST0xMRVJ9IGZyb20gJy4uLy4uL21pc2MvdHJlZS5jb25zdGFudHMnO1xuaW1wb3J0IHR5cGUge1R1aVRyZWVDb250cm9sbGVyLCBUdWlUcmVlSXRlbUNvbnRleHR9IGZyb20gJy4uLy4uL21pc2MvdHJlZS5pbnRlcmZhY2VzJztcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQvbm8tY3ljbGVcbmltcG9ydCB7VFVJX1RSRUVfQ09OVFJPTExFUn0gZnJvbSAnLi4vLi4vbWlzYy90cmVlLnRva2Vucyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAndHVpLXRyZWUtaXRlbS1jb250ZW50JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vdHJlZS1pdGVtLWNvbnRlbnQudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdHJlZS1pdGVtLWNvbnRlbnQuc3R5bGUubGVzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlUcmVlSXRlbUNvbnRlbnRDb21wb25lbnQge1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KFBPTFlNT1JQSEVVU19DT05URVhUKSByZWFkb25seSBjb250ZXh0OiBUdWlUcmVlSXRlbUNvbnRleHQsXG4gICAgICAgIEBJbmplY3QoZm9yd2FyZFJlZigoKSA9PiBUVUlfVFJFRV9DT05UUk9MTEVSKSlcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBjb250cm9sbGVyOiBUdWlUcmVlQ29udHJvbGxlcixcbiAgICApIHt9XG5cbiAgICBnZXQgaXNFeHBhbmRlZCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29udGV4dC4kaW1wbGljaXQuaXNFeHBhbmRlZDtcbiAgICB9XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLl9leHBhbmRhYmxlJylcbiAgICBnZXQgaXNFeHBhbmRhYmxlKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgdGhpcy5jb250ZXh0LiRpbXBsaWNpdC5pc0V4cGFuZGFibGUgJiZcbiAgICAgICAgICAgIHRoaXMuY29udHJvbGxlciAhPT0gVFVJX0RFRkFVTFRfVFJFRV9DT05UUk9MTEVSXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgb25DbGljaygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jb250cm9sbGVyLnRvZ2dsZSh0aGlzLmNvbnRleHQuJGltcGxpY2l0KTtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgKm5nSWY9XCJpc0V4cGFuZGFibGVcIlxuICAgIHR1aUljb25CdXR0b25cbiAgICBzaXplPVwieHNcIlxuICAgIGFwcGVhcmFuY2U9XCJmbGF0XCJcbiAgICBpY29uPVwidHVpSWNvbkNoZXZyb25SaWdodFwiXG4gICAgc2hhcGU9XCJyb3VuZGVkXCJcbiAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICBjbGFzcz1cInQtYnV0dG9uXCJcbiAgICBbY2xhc3MudC1idXR0b25fZXhwYW5kZWRdPVwiaXNFeHBhbmRlZFwiXG4gICAgKGNsaWNrKT1cIm9uQ2xpY2soKVwiXG4+PC9idXR0b24+XG48bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImNvbnRleHQudGVtcGxhdGVcIj48L25nLWNvbnRhaW5lcj5cbiJdfQ==
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1pdGVtLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvdHJlZS9jb21wb25lbnRzL3RyZWUtaXRlbS1jb250ZW50L3RyZWUtaXRlbS1jb250ZW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3RyZWUvY29tcG9uZW50cy90cmVlLWl0ZW0tY29udGVudC90cmVlLWl0ZW0tY29udGVudC50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixXQUFXLEVBQ1gsTUFBTSxHQUNULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBQyxnQkFBZ0IsRUFBaUIsTUFBTSxnQkFBZ0IsQ0FBQztBQUNoRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUU5RCxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUV0RSwyQ0FBMkM7QUFDM0MsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7Ozs7QUFRM0QsTUFBTSxPQUFPLDJCQUEyQjtJQUNwQyxZQUN1QyxLQUFxQixFQUNqQixPQUEyQixFQUVqRCxVQUE2QjtRQUhYLFVBQUssR0FBTCxLQUFLLENBQWdCO1FBQ2pCLFlBQU8sR0FBUCxPQUFPLENBQW9CO1FBRWpELGVBQVUsR0FBVixVQUFVLENBQW1CO0lBQy9DLENBQUM7SUFFSixJQUFJLFVBQVU7UUFDVixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQztJQUM3QyxDQUFDO0lBRUQsSUFDSSxZQUFZO1FBQ1osT0FBTyxDQUNILElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLFlBQVk7WUFDbkMsSUFBSSxDQUFDLFVBQVUsS0FBSywyQkFBMkIsQ0FDbEQsQ0FBQztJQUNOLENBQUM7SUFFRCxPQUFPO1FBQ0gsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNuRCxDQUFDOzt5SEF0QlEsMkJBQTJCLGtCQUV4QixnQkFBZ0IsYUFDaEIsb0JBQW9CLGFBQ3BCLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQzs2R0FKeEMsMkJBQTJCLGlJQ3JCeEMsK1ZBYUE7NEZEUWEsMkJBQTJCO2tCQU52QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFdBQVcsRUFBRSxtQ0FBbUM7b0JBQ2hELFNBQVMsRUFBRSxDQUFDLGdDQUFnQyxDQUFDO29CQUM3QyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQ7OzBCQUdRLE1BQU07MkJBQUMsZ0JBQWdCOzswQkFDdkIsTUFBTTsyQkFBQyxvQkFBb0I7OzBCQUMzQixNQUFNOzJCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQzs0Q0FTN0MsWUFBWTtzQkFEZixXQUFXO3VCQUFDLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIGZvcndhcmRSZWYsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgSW5qZWN0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VFVJX0NPTU1PTl9JQ09OUywgVHVpQ29tbW9uSWNvbnN9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcbmltcG9ydCB7UE9MWU1PUlBIRVVTX0NPTlRFWFR9IGZyb20gJ0B0aW5rb2ZmL25nLXBvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VFVJX0RFRkFVTFRfVFJFRV9DT05UUk9MTEVSfSBmcm9tICcuLi8uLi9taXNjL3RyZWUuY29uc3RhbnRzJztcbmltcG9ydCB0eXBlIHtUdWlUcmVlQ29udHJvbGxlciwgVHVpVHJlZUl0ZW1Db250ZXh0fSBmcm9tICcuLi8uLi9taXNjL3RyZWUuaW50ZXJmYWNlcyc7XG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLWN5Y2xlXG5pbXBvcnQge1RVSV9UUkVFX0NPTlRST0xMRVJ9IGZyb20gJy4uLy4uL21pc2MvdHJlZS50b2tlbnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3R1aS10cmVlLWl0ZW0tY29udGVudCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RyZWUtaXRlbS1jb250ZW50LnRlbXBsYXRlLmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3RyZWUtaXRlbS1jb250ZW50LnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpVHJlZUl0ZW1Db250ZW50Q29tcG9uZW50IHtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChUVUlfQ09NTU9OX0lDT05TKSByZWFkb25seSBpY29uczogVHVpQ29tbW9uSWNvbnMsXG4gICAgICAgIEBJbmplY3QoUE9MWU1PUlBIRVVTX0NPTlRFWFQpIHJlYWRvbmx5IGNvbnRleHQ6IFR1aVRyZWVJdGVtQ29udGV4dCxcbiAgICAgICAgQEluamVjdChmb3J3YXJkUmVmKCgpID0+IFRVSV9UUkVFX0NPTlRST0xMRVIpKVxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGNvbnRyb2xsZXI6IFR1aVRyZWVDb250cm9sbGVyLFxuICAgICkge31cblxuICAgIGdldCBpc0V4cGFuZGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5jb250ZXh0LiRpbXBsaWNpdC5pc0V4cGFuZGVkO1xuICAgIH1cblxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuX2V4cGFuZGFibGUnKVxuICAgIGdldCBpc0V4cGFuZGFibGUoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICB0aGlzLmNvbnRleHQuJGltcGxpY2l0LmlzRXhwYW5kYWJsZSAmJlxuICAgICAgICAgICAgdGhpcy5jb250cm9sbGVyICE9PSBUVUlfREVGQVVMVF9UUkVFX0NPTlRST0xMRVJcbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICBvbkNsaWNrKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmNvbnRyb2xsZXIudG9nZ2xlKHRoaXMuY29udGV4dC4kaW1wbGljaXQpO1xuICAgIH1cbn1cbiIsIjxidXR0b25cbiAgICAqbmdJZj1cImlzRXhwYW5kYWJsZVwiXG4gICAgdHVpSWNvbkJ1dHRvblxuICAgIHNpemU9XCJ4c1wiXG4gICAgYXBwZWFyYW5jZT1cImZsYXRcIlxuICAgIHNoYXBlPVwicm91bmRlZFwiXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgY2xhc3M9XCJ0LWJ1dHRvblwiXG4gICAgW2NsYXNzLnQtYnV0dG9uX2V4cGFuZGVkXT1cImlzRXhwYW5kZWRcIlxuICAgIFtpY29uXT1cImljb25zLm1vcmVcIlxuICAgIChjbGljayk9XCJvbkNsaWNrKClcIlxuPjwvYnV0dG9uPlxuPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJjb250ZXh0LnRlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XG4iXX0=
@@ -7,6 +7,7 @@ import { merge, identity } from 'rxjs';
7
7
  import { pairwise, map, filter, switchMap, takeUntil } from 'rxjs/operators';
8
8
  import * as i1 from '@taiga-ui/core';
9
9
  import { TUI_MODE, MODE_PROVIDER, TuiSvgModule, TuiGroupModule, TuiExpandModule } from '@taiga-ui/core';
10
+ import { TUI_ARROW_OPTIONS } from '@taiga-ui/kit/components/arrow';
10
11
  import * as i4 from '@tinkoff/ng-polymorpheus';
11
12
  import { PolymorpheusTemplate, PolymorpheusModule } from '@tinkoff/ng-polymorpheus';
12
13
  import * as i3 from '@angular/common';
@@ -46,10 +47,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
46
47
  }] });
47
48
 
48
49
  class TuiAccordionItemComponent extends AbstractTuiInteractive {
49
- constructor(cdr, mode$) {
50
+ constructor(cdr, mode$, options) {
50
51
  super();
51
52
  this.cdr = cdr;
52
53
  this.mode$ = mode$;
54
+ this.options = options;
53
55
  this.noPadding = false;
54
56
  this.showArrow = true;
55
57
  this.borders = 'all';
@@ -98,8 +100,8 @@ class TuiAccordionItemComponent extends AbstractTuiInteractive {
98
100
  this.openChange.emit(open);
99
101
  }
100
102
  }
101
- TuiAccordionItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiAccordionItemComponent, deps: [{ token: ChangeDetectorRef }, { token: TUI_MODE }], target: i0.ɵɵFactoryTarget.Component });
102
- TuiAccordionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiAccordionItemComponent, selector: "tui-accordion-item", inputs: { noPadding: "noPadding", showArrow: "showArrow", borders: "borders", size: "size", disabled: "disabled", disableHover: "disableHover", open: "open", async: "async" }, outputs: { openChange: "openChange" }, host: { listeners: { "$.data-mode.attr": "mode$" }, properties: { "class._no-padding": "this.noPadding", "class._has-arrow": "this.showArrow", "attr.data-borders": "this.borders", "attr.data-size": "this.size", "class._disabled": "this.disabled" } }, providers: [tuiAsFocusableItemAccessor(TuiAccordionItemComponent), MODE_PROVIDER], queries: [{ propertyName: "eagerContent", first: true, predicate: TuiAccordionItemEagerContentDirective, descendants: true }, { propertyName: "lazyContent", first: true, predicate: TuiAccordionItemContentDirective, descendants: true }], viewQueries: [{ propertyName: "focusableElement", first: true, predicate: ["focusableElement"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n automation-id=\"tui-accordion__item-wrapper\"\n class=\"t-wrapper\"\n>\n <button\n #focusableElement\n automation-id=\"tui-accordion__item-header\"\n type=\"button\"\n class=\"t-header\"\n [disabled]=\"computedDisabled\"\n [class.t-header_open]=\"open\"\n [class.t-header_hoverable]=\"!disableHover\"\n [tuiFocusable]=\"computedFocusable\"\n (tuiFocusVisibleChange)=\"onFocusVisible($event)\"\n (tuiFocusedChange)=\"onFocused($event)\"\n (keydown.esc)=\"onItemKeyDownEsc($event)\"\n (click)=\"onRowToggle()\"\n >\n <span\n automation-id=\"tui-accordion__item-title\"\n class=\"t-title\"\n >\n <ng-content></ng-content>\n </span>\n <tui-svg\n *ngIf=\"showArrow\"\n automation-id=\"tui-accordion__item-arrow\"\n src=\"tuiIconChevronDownLarge\"\n class=\"t-icon\"\n [class.t-icon_open]=\"open\"\n ></tui-svg>\n </button>\n <tui-expand\n [async]=\"async\"\n [expanded]=\"open\"\n >\n <ng-template tuiExpandContent>\n <div\n *ngIf=\"lazyContent\"\n automation-id=\"tui-accordion__item-content\"\n class=\"t-content\"\n >\n <ng-container *polymorpheusOutlet=\"lazyContent as text\">\n {{ text }}\n </ng-container>\n </div>\n </ng-template>\n <div\n *ngIf=\"eagerContent\"\n class=\"t-content\"\n >\n <ng-content select=\"[tuiAccordionItemContent]\"></ng-content>\n </div>\n </tui-expand>\n</div>\n", styles: [":host{position:relative;display:block;overflow:hidden;border-radius:var(--tui-radius-l)}:host[data-borders=top-bottom]{border-radius:0!important}.t-wrapper{position:relative;border-radius:inherit}.t-wrapper:after{position:absolute;top:0;left:0;width:100%;height:100%;content:\"\";box-sizing:border-box;border-radius:inherit;border:1px solid var(--tui-base-04);pointer-events:none}:host:not([data-borders]) .t-wrapper:after{border-width:0}:host[data-borders=all] .t-wrapper:after{border-width:1px}:host[data-borders=top-bottom] .t-wrapper:after{border-left-width:0;border-right-width:0}:host[data-borders=top] .t-wrapper:after{border-left-width:0;border-right-width:0;border-bottom-width:0}:host[data-borders=bottom] .t-wrapper:after{border-left-width:0;border-right-width:0;border-top-width:0}:host[data-mode=onDark] .t-wrapper:after{border-color:var(--tui-base-03)}:host[data-mode=onLight] .t-wrapper:after{border-color:var(--tui-text-01)}:host._focus-visible .t-wrapper:after{border:2px solid var(--tui-focus)}:host:not([data-mode]) .t-wrapper{background:var(--tui-base-01)}.t-header{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;font-size:inherit;line-height:inherit;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;width:100%;font:var(--tui-font-text-l);align-items:center;box-sizing:border-box;border-bottom:1px solid var(--tui-base-04);min-height:var(--tui-height-l);padding:.75rem 1.25rem;color:var(--tui-text-01);cursor:pointer;text-align:left;outline:none}:host[data-mode=onDark] .t-header{color:var(--tui-text-01-night);border-color:var(--tui-base-03)}:host[data-mode=onLight] .t-header{border-color:var(--tui-text-01)}:host:not([data-borders]) .t-header{border-bottom-width:0;box-shadow:none}:host._has-arrow .t-header{padding-right:.75rem}:host[data-mode=onDark] .t-header_open{background:var(--tui-clear-inverse)}:host[data-mode=onLight] .t-header_open{background:var(--tui-clear)}:host[data-size=s] .t-header{font:var(--tui-font-text-m);min-height:var(--tui-height-m);padding:.625rem .75rem .625rem 1rem}:host._no-padding .t-header{padding-left:0;padding-right:0}:host._disabled .t-header{cursor:default}:host:hover:not([data-mode]) .t-header_hoverable{background:var(--tui-base-02)}:host:hover[data-mode=onDark] .t-header_hoverable{background:var(--tui-clear-inverse)}:host:hover[data-mode=onLight] .t-header_hoverable{background:var(--tui-clear)}.t-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:0;flex-grow:1}:host._has-arrow .t-title{margin-right:.5rem}.t-icon{transition-property:transform,color;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;width:1.5rem;height:1.5rem;margin-left:auto;color:var(--tui-base-06)}.t-icon_open{transform:rotate(180deg)}:host[data-mode] .t-icon{opacity:var(--tui-disabled-opacity)}:host:hover[data-mode] .t-icon{opacity:.8}:host[data-mode=onDark] .t-icon{color:var(--tui-text-01-night)}:host[data-mode=onLight] .t-icon{color:var(--tui-text-01)}:host:hover:not([data-mode]) .t-icon{color:var(--tui-base-07)}.t-content{font:var(--tui-font-text-m);padding:1.25rem;word-wrap:break-word}:host[data-size=s] .t-content{font:var(--tui-font-text-s);padding:1rem}\n"], components: [{ type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }], directives: [{ type: i2.TuiFocusableDirective, selector: "[tuiFocusable]", inputs: ["tuiFocusable"] }, { type: i2.TuiFocusVisibleDirective, selector: "[tuiFocusVisibleChange]", outputs: ["tuiFocusVisibleChange"] }, { type: i2.TuiFocusedDirective, selector: "[tuiFocusedChange]", outputs: ["tuiFocusedChange"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.TuiExpandContentDirective, selector: "[tuiExpandContent]" }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
103
+ TuiAccordionItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiAccordionItemComponent, deps: [{ token: ChangeDetectorRef }, { token: TUI_MODE }, { token: TUI_ARROW_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
104
+ TuiAccordionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiAccordionItemComponent, selector: "tui-accordion-item", inputs: { noPadding: "noPadding", showArrow: "showArrow", borders: "borders", size: "size", disabled: "disabled", disableHover: "disableHover", open: "open", async: "async" }, outputs: { openChange: "openChange" }, host: { listeners: { "$.data-mode.attr": "mode$" }, properties: { "class._no-padding": "this.noPadding", "class._has-arrow": "this.showArrow", "attr.data-borders": "this.borders", "attr.data-size": "this.size", "class._disabled": "this.disabled" } }, providers: [tuiAsFocusableItemAccessor(TuiAccordionItemComponent), MODE_PROVIDER], queries: [{ propertyName: "eagerContent", first: true, predicate: TuiAccordionItemEagerContentDirective, descendants: true }, { propertyName: "lazyContent", first: true, predicate: TuiAccordionItemContentDirective, descendants: true }], viewQueries: [{ propertyName: "focusableElement", first: true, predicate: ["focusableElement"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n automation-id=\"tui-accordion__item-wrapper\"\n class=\"t-wrapper\"\n>\n <button\n #focusableElement\n automation-id=\"tui-accordion__item-header\"\n type=\"button\"\n class=\"t-header\"\n [disabled]=\"computedDisabled\"\n [class.t-header_open]=\"open\"\n [class.t-header_hoverable]=\"!disableHover\"\n [tuiFocusable]=\"computedFocusable\"\n (tuiFocusVisibleChange)=\"onFocusVisible($event)\"\n (tuiFocusedChange)=\"onFocused($event)\"\n (keydown.esc)=\"onItemKeyDownEsc($event)\"\n (click)=\"onRowToggle()\"\n >\n <span\n automation-id=\"tui-accordion__item-title\"\n class=\"t-title\"\n >\n <ng-content></ng-content>\n </span>\n <ng-container *ngIf=\"showArrow\">\n <tui-svg\n *polymorpheusOutlet=\"options.iconLarge as src\"\n automation-id=\"tui-accordion__item-arrow\"\n class=\"t-icon\"\n [class.t-icon_open]=\"open\"\n [src]=\"src\"\n ></tui-svg>\n </ng-container>\n </button>\n <tui-expand\n [async]=\"async\"\n [expanded]=\"open\"\n >\n <ng-template tuiExpandContent>\n <div\n *ngIf=\"lazyContent\"\n automation-id=\"tui-accordion__item-content\"\n class=\"t-content\"\n >\n <ng-container *polymorpheusOutlet=\"lazyContent as text\">\n {{ text }}\n </ng-container>\n </div>\n </ng-template>\n <div\n *ngIf=\"eagerContent\"\n class=\"t-content\"\n >\n <ng-content select=\"[tuiAccordionItemContent]\"></ng-content>\n </div>\n </tui-expand>\n</div>\n", styles: [":host{position:relative;display:block;overflow:hidden;border-radius:var(--tui-radius-l)}:host[data-borders=top-bottom]{border-radius:0!important}.t-wrapper{position:relative;border-radius:inherit}.t-wrapper:after{position:absolute;top:0;left:0;width:100%;height:100%;content:\"\";box-sizing:border-box;border-radius:inherit;border:1px solid var(--tui-base-04);pointer-events:none}:host:not([data-borders]) .t-wrapper:after{border-width:0}:host[data-borders=all] .t-wrapper:after{border-width:1px}:host[data-borders=top-bottom] .t-wrapper:after{border-left-width:0;border-right-width:0}:host[data-borders=top] .t-wrapper:after{border-left-width:0;border-right-width:0;border-bottom-width:0}:host[data-borders=bottom] .t-wrapper:after{border-left-width:0;border-right-width:0;border-top-width:0}:host[data-mode=onDark] .t-wrapper:after{border-color:var(--tui-base-03)}:host[data-mode=onLight] .t-wrapper:after{border-color:var(--tui-text-01)}:host._focus-visible .t-wrapper:after{border:2px solid var(--tui-focus)}:host:not([data-mode]) .t-wrapper{background:var(--tui-base-01)}.t-header{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;font-size:inherit;line-height:inherit;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;width:100%;font:var(--tui-font-text-l);align-items:center;box-sizing:border-box;border-bottom:1px solid var(--tui-base-04);min-height:var(--tui-height-l);padding:.75rem 1.25rem;color:var(--tui-text-01);cursor:pointer;text-align:left;outline:none}:host[data-mode=onDark] .t-header{color:var(--tui-text-01-night);border-color:var(--tui-base-03)}:host[data-mode=onLight] .t-header{border-color:var(--tui-text-01)}:host:not([data-borders]) .t-header{border-bottom-width:0;box-shadow:none}:host._has-arrow .t-header{padding-right:.75rem}:host[data-mode=onDark] .t-header_open{background:var(--tui-clear-inverse)}:host[data-mode=onLight] .t-header_open{background:var(--tui-clear)}:host[data-size=s] .t-header{font:var(--tui-font-text-m);min-height:var(--tui-height-m);padding:.625rem .75rem .625rem 1rem}:host._no-padding .t-header{padding-left:0;padding-right:0}:host._disabled .t-header{cursor:default}:host:hover:not([data-mode]) .t-header_hoverable{background:var(--tui-base-02)}:host:hover[data-mode=onDark] .t-header_hoverable{background:var(--tui-clear-inverse)}:host:hover[data-mode=onLight] .t-header_hoverable{background:var(--tui-clear)}.t-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:0;flex-grow:1}:host._has-arrow .t-title{margin-right:.5rem}.t-icon{transition-property:transform,color;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;width:1.5rem;height:1.5rem;margin-left:auto;color:var(--tui-base-06)}.t-icon_open{transform:rotate(180deg)}:host[data-mode] .t-icon{opacity:var(--tui-disabled-opacity)}:host:hover[data-mode] .t-icon{opacity:.8}:host[data-mode=onDark] .t-icon{color:var(--tui-text-01-night)}:host[data-mode=onLight] .t-icon{color:var(--tui-text-01)}:host:hover:not([data-mode]) .t-icon{color:var(--tui-base-07)}.t-content{font:var(--tui-font-text-m);padding:1.25rem;word-wrap:break-word}:host[data-size=s] .t-content{font:var(--tui-font-text-s);padding:1rem}\n"], components: [{ type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }], directives: [{ type: i2.TuiFocusableDirective, selector: "[tuiFocusable]", inputs: ["tuiFocusable"] }, { type: i2.TuiFocusVisibleDirective, selector: "[tuiFocusVisibleChange]", outputs: ["tuiFocusVisibleChange"] }, { type: i2.TuiFocusedDirective, selector: "[tuiFocusedChange]", outputs: ["tuiFocusedChange"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i1.TuiExpandContentDirective, selector: "[tuiExpandContent]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
103
105
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiAccordionItemComponent, decorators: [{
104
106
  type: Component,
105
107
  args: [{
@@ -118,6 +120,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
118
120
  }] }, { type: i5.Observable, decorators: [{
119
121
  type: Inject,
120
122
  args: [TUI_MODE]
123
+ }] }, { type: undefined, decorators: [{
124
+ type: Inject,
125
+ args: [TUI_ARROW_OPTIONS]
121
126
  }] }]; }, propDecorators: { focusableElement: [{
122
127
  type: ViewChild,
123
128
  args: ['focusableElement']