@taiga-ui/core 5.0.0-canary.b5906eb → 5.0.0-canary.ba1037a

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 (166) hide show
  1. package/components/calendar/calendar-sheet.component.d.ts +8 -15
  2. package/components/calendar/calendar-spin.component.d.ts +5 -8
  3. package/components/calendar/calendar-year.component.d.ts +11 -19
  4. package/components/calendar/calendar.component.d.ts +7 -9
  5. package/components/checkbox/checkbox.component.d.ts +10 -0
  6. package/components/checkbox/checkbox.options.d.ts +10 -0
  7. package/components/checkbox/index.d.ts +2 -0
  8. package/components/data-list/data-list.component.d.ts +1 -0
  9. package/components/data-list/index.d.ts +1 -0
  10. package/components/data-list/option-content.directive.d.ts +1 -1
  11. package/components/data-list/option-with-content.directive.d.ts +9 -0
  12. package/components/data-list/option-with-value.directive.d.ts +2 -1
  13. package/components/data-list/option.directive.d.ts +0 -4
  14. package/components/index.d.ts +3 -0
  15. package/components/input/input.directive.d.ts +2 -0
  16. package/components/loader/loader.component.d.ts +0 -2
  17. package/components/radio/index.d.ts +4 -0
  18. package/components/radio/radio.component.d.ts +18 -0
  19. package/components/radio/radio.d.ts +3 -0
  20. package/components/radio/radio.directive.d.ts +8 -0
  21. package/components/radio/radio.options.d.ts +7 -0
  22. package/components/slider/helpers/key-steps.d.ts +27 -0
  23. package/components/slider/helpers/slider-key-steps.directive.d.ts +32 -0
  24. package/components/slider/helpers/slider-readonly.directive.d.ts +15 -0
  25. package/components/slider/helpers/slider-thumb-label.component.d.ts +13 -0
  26. package/components/slider/index.d.ts +6 -0
  27. package/components/slider/slider.component.d.ts +22 -0
  28. package/components/slider/slider.d.ts +5 -0
  29. package/components/textfield/index.d.ts +0 -1
  30. package/components/textfield/textfield-multi/textfield-item.component.d.ts +1 -0
  31. package/components/textfield/textfield-multi/textfield-multi.component.d.ts +2 -0
  32. package/components/textfield/textfield.component.d.ts +1 -0
  33. package/directives/items-handlers/items-handlers.validator.d.ts +1 -0
  34. package/fesm2022/taiga-ui-core-classes.mjs +3 -3
  35. package/fesm2022/taiga-ui-core-classes.mjs.map +1 -1
  36. package/fesm2022/taiga-ui-core-components-button.mjs +8 -7
  37. package/fesm2022/taiga-ui-core-components-button.mjs.map +1 -1
  38. package/fesm2022/taiga-ui-core-components-calendar.mjs +100 -200
  39. package/fesm2022/taiga-ui-core-components-calendar.mjs.map +1 -1
  40. package/fesm2022/taiga-ui-core-components-cell.mjs +7 -7
  41. package/fesm2022/taiga-ui-core-components-cell.mjs.map +1 -1
  42. package/fesm2022/taiga-ui-core-components-checkbox.mjs +37 -0
  43. package/fesm2022/taiga-ui-core-components-checkbox.mjs.map +1 -0
  44. package/fesm2022/taiga-ui-core-components-data-list.mjs +50 -35
  45. package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
  46. package/fesm2022/taiga-ui-core-components-error.mjs +11 -13
  47. package/fesm2022/taiga-ui-core-components-error.mjs.map +1 -1
  48. package/fesm2022/taiga-ui-core-components-expand.mjs +3 -3
  49. package/fesm2022/taiga-ui-core-components-expand.mjs.map +1 -1
  50. package/fesm2022/taiga-ui-core-components-icon.mjs +8 -12
  51. package/fesm2022/taiga-ui-core-components-icon.mjs.map +1 -1
  52. package/fesm2022/taiga-ui-core-components-input.mjs +9 -7
  53. package/fesm2022/taiga-ui-core-components-input.mjs.map +1 -1
  54. package/fesm2022/taiga-ui-core-components-label.mjs +9 -7
  55. package/fesm2022/taiga-ui-core-components-label.mjs.map +1 -1
  56. package/fesm2022/taiga-ui-core-components-link.mjs +8 -7
  57. package/fesm2022/taiga-ui-core-components-link.mjs.map +1 -1
  58. package/fesm2022/taiga-ui-core-components-loader.mjs +7 -10
  59. package/fesm2022/taiga-ui-core-components-loader.mjs.map +1 -1
  60. package/fesm2022/taiga-ui-core-components-notification.mjs +19 -20
  61. package/fesm2022/taiga-ui-core-components-notification.mjs.map +1 -1
  62. package/fesm2022/taiga-ui-core-components-radio.mjs +91 -0
  63. package/fesm2022/taiga-ui-core-components-radio.mjs.map +1 -0
  64. package/fesm2022/taiga-ui-core-components-root.mjs +4 -4
  65. package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
  66. package/fesm2022/taiga-ui-core-components-scrollbar.mjs +24 -30
  67. package/fesm2022/taiga-ui-core-components-scrollbar.mjs.map +1 -1
  68. package/fesm2022/taiga-ui-core-components-slider.mjs +337 -0
  69. package/fesm2022/taiga-ui-core-components-slider.mjs.map +1 -0
  70. package/fesm2022/taiga-ui-core-components-spin-button.mjs +4 -4
  71. package/fesm2022/taiga-ui-core-components-spin-button.mjs.map +1 -1
  72. package/fesm2022/taiga-ui-core-components-textfield.mjs +51 -42
  73. package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
  74. package/fesm2022/taiga-ui-core-components-title.mjs +9 -7
  75. package/fesm2022/taiga-ui-core-components-title.mjs.map +1 -1
  76. package/fesm2022/taiga-ui-core-components.mjs +3 -0
  77. package/fesm2022/taiga-ui-core-components.mjs.map +1 -1
  78. package/fesm2022/taiga-ui-core-directives-appearance.mjs +14 -16
  79. package/fesm2022/taiga-ui-core-directives-appearance.mjs.map +1 -1
  80. package/fesm2022/taiga-ui-core-directives-button-x.mjs +3 -3
  81. package/fesm2022/taiga-ui-core-directives-button-x.mjs.map +1 -1
  82. package/fesm2022/taiga-ui-core-directives-date-format.mjs +3 -3
  83. package/fesm2022/taiga-ui-core-directives-date-format.mjs.map +1 -1
  84. package/fesm2022/taiga-ui-core-directives-group.mjs +9 -7
  85. package/fesm2022/taiga-ui-core-directives-group.mjs.map +1 -1
  86. package/fesm2022/taiga-ui-core-directives-icons.mjs +12 -10
  87. package/fesm2022/taiga-ui-core-directives-icons.mjs.map +1 -1
  88. package/fesm2022/taiga-ui-core-directives-items-handlers.mjs +19 -19
  89. package/fesm2022/taiga-ui-core-directives-items-handlers.mjs.map +1 -1
  90. package/fesm2022/taiga-ui-core-directives-number-format.mjs +3 -3
  91. package/fesm2022/taiga-ui-core-directives-number-format.mjs.map +1 -1
  92. package/fesm2022/taiga-ui-core-pipes-format-number.mjs +3 -3
  93. package/fesm2022/taiga-ui-core-pipes-format-number.mjs.map +1 -1
  94. package/fesm2022/taiga-ui-core-portals-alert.mjs +10 -10
  95. package/fesm2022/taiga-ui-core-portals-alert.mjs.map +1 -1
  96. package/fesm2022/taiga-ui-core-portals-dialog.mjs +15 -17
  97. package/fesm2022/taiga-ui-core-portals-dialog.mjs.map +1 -1
  98. package/fesm2022/taiga-ui-core-portals-dropdown.mjs +312 -272
  99. package/fesm2022/taiga-ui-core-portals-dropdown.mjs.map +1 -1
  100. package/fesm2022/taiga-ui-core-portals-hint.mjs +43 -51
  101. package/fesm2022/taiga-ui-core-portals-hint.mjs.map +1 -1
  102. package/fesm2022/taiga-ui-core-portals-modal.mjs +8 -8
  103. package/fesm2022/taiga-ui-core-portals-modal.mjs.map +1 -1
  104. package/fesm2022/taiga-ui-core-portals-popup.mjs +12 -16
  105. package/fesm2022/taiga-ui-core-portals-popup.mjs.map +1 -1
  106. package/fesm2022/taiga-ui-core-services.mjs +7 -9
  107. package/fesm2022/taiga-ui-core-services.mjs.map +1 -1
  108. package/fesm2022/taiga-ui-core-tokens.mjs +17 -33
  109. package/fesm2022/taiga-ui-core-tokens.mjs.map +1 -1
  110. package/fesm2022/taiga-ui-core-utils-dom.mjs.map +1 -1
  111. package/fesm2022/taiga-ui-core-utils-format.mjs.map +1 -1
  112. package/fesm2022/taiga-ui-core-utils-miscellaneous.mjs.map +1 -1
  113. package/package.json +32 -20
  114. package/portals/dropdown/dropdown-a11y.directive.d.ts +10 -0
  115. package/portals/dropdown/dropdown-close.directive.d.ts +3 -3
  116. package/portals/dropdown/dropdown-open.directive.d.ts +4 -3
  117. package/portals/dropdown/dropdown-selection.directive.d.ts +1 -0
  118. package/portals/dropdown/dropdown.d.ts +2 -1
  119. package/portals/dropdown/dropdown.directive.d.ts +5 -5
  120. package/portals/dropdown/index.d.ts +2 -1
  121. package/tokens/i18n.d.ts +4 -0
  122. package/tokens/index.d.ts +0 -1
  123. package/utils/miscellaneous/font-scaling.d.ts +2 -2
  124. package/components/textfield/textfield-icon.d.ts +0 -6
  125. package/styles/components/appearance.less +0 -50
  126. package/styles/components/button.less +0 -134
  127. package/styles/components/group.less +0 -172
  128. package/styles/components/icon.less +0 -83
  129. package/styles/components/icons.less +0 -79
  130. package/styles/components/label.less +0 -51
  131. package/styles/components/link.less +0 -68
  132. package/styles/components/notification.less +0 -184
  133. package/styles/components/textfield.less +0 -358
  134. package/styles/components/title.less +0 -80
  135. package/styles/mixins/appearance.less +0 -56
  136. package/styles/mixins/appearance.scss +0 -57
  137. package/styles/mixins/browsers.less +0 -23
  138. package/styles/mixins/browsers.scss +0 -23
  139. package/styles/mixins/date-picker.less +0 -152
  140. package/styles/mixins/mixins.less +0 -168
  141. package/styles/mixins/mixins.scss +0 -161
  142. package/styles/mixins/picker.less +0 -200
  143. package/styles/mixins/picker.scss +0 -199
  144. package/styles/mixins/slider.less +0 -70
  145. package/styles/mixins/slider.scss +0 -72
  146. package/styles/taiga-ui-fonts.less +0 -4
  147. package/styles/taiga-ui-local.less +0 -7
  148. package/styles/taiga-ui-local.scss +0 -6
  149. package/styles/taiga-ui-theme.less +0 -4
  150. package/styles/theme/appearance/accent.less +0 -14
  151. package/styles/theme/appearance/action.less +0 -52
  152. package/styles/theme/appearance/flat.less +0 -23
  153. package/styles/theme/appearance/floating.less +0 -16
  154. package/styles/theme/appearance/glass.less +0 -30
  155. package/styles/theme/appearance/outline.less +0 -78
  156. package/styles/theme/appearance/primary.less +0 -48
  157. package/styles/theme/appearance/secondary.less +0 -77
  158. package/styles/theme/appearance/status.less +0 -125
  159. package/styles/theme/appearance/table.less +0 -68
  160. package/styles/theme/appearance/textfield.less +0 -80
  161. package/styles/theme/appearance.less +0 -12
  162. package/styles/theme/palette.less +0 -161
  163. package/styles/theme/variables.less +0 -42
  164. package/styles/variables/media.less +0 -23
  165. package/styles/variables/media.scss +0 -23
  166. package/tokens/theme.d.ts +0 -2
@@ -1,4 +1,3 @@
1
- import { EventEmitter } from '@angular/core';
2
1
  import { TuiDay, TuiDayRange, TuiMonth } from '@taiga-ui/cdk/date-time';
3
2
  import { type TuiBooleanHandler, type TuiHandler } from '@taiga-ui/cdk/types';
4
3
  import * as i0 from "@angular/core";
@@ -8,12 +7,13 @@ export declare class TuiCalendarSheet {
8
7
  private readonly today;
9
8
  protected readonly unorderedWeekDays$: import("rxjs").Observable<readonly [Monday: string, Tuesday: string, Wednesday: string, Thursday: string, Friday: string, Saturday: string, Sunday: string]>;
10
9
  protected readonly dayType: TuiHandler<TuiDay, string>;
11
- month: TuiMonth;
12
- disabledItemHandler: TuiBooleanHandler<TuiDay>;
13
- markerHandler: TuiMarkerHandler | null;
14
- value: TuiDay | TuiDayRange | readonly TuiDay[] | null;
15
- hoveredItem: TuiDay | null;
16
- showAdjacent: boolean;
10
+ readonly month: import("@angular/core").InputSignal<TuiMonth>;
11
+ readonly disabledItemHandler: import("@angular/core").InputSignal<TuiBooleanHandler<TuiDay>>;
12
+ readonly markerHandler: import("@angular/core").InputSignal<TuiMarkerHandler | null>;
13
+ readonly value: import("@angular/core").InputSignal<TuiDay | readonly TuiDay[] | TuiDayRange | null>;
14
+ readonly showAdjacent: import("@angular/core").InputSignal<boolean>;
15
+ readonly hoveredItem: import("@angular/core").ModelSignal<TuiDay | null>;
16
+ readonly dayClick: import("@angular/core").OutputEmitterRef<TuiDay>;
17
17
  /**
18
18
  * @deprecated use static DI options instead
19
19
  * ```
@@ -22,12 +22,6 @@ export declare class TuiCalendarSheet {
22
22
  * TODO(v5): delete it
23
23
  */
24
24
  single: boolean;
25
- readonly hoveredItemChange: EventEmitter<TuiDay | null>;
26
- readonly dayClick: EventEmitter<TuiDay>;
27
- /**
28
- * @deprecated TODO(v5): delete it. It is used nowhere except unit tests
29
- */
30
- itemIsInterval(day: TuiDay): boolean;
31
25
  onItemHovered(item: TuiDay | false): void;
32
26
  getItemRange(item: TuiDay): 'active' | 'end' | 'middle' | 'start' | null;
33
27
  protected get computedRangeMode(): boolean;
@@ -35,9 +29,8 @@ export declare class TuiCalendarSheet {
35
29
  protected readonly toMarkers: (day: TuiDay, today: boolean, range: string | null, markerHandler: TuiMarkerHandler | null) => [string, string] | [string] | null;
36
30
  protected itemIsToday(item: TuiDay): boolean;
37
31
  protected itemIsUnavailable(item: TuiDay): boolean;
38
- protected onItemClick(item: TuiDay): void;
39
32
  private getRange;
40
33
  private updateHoveredItem;
41
34
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiCalendarSheet, never>;
42
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarSheet, "tui-calendar-sheet", never, { "month": { "alias": "month"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "markerHandler": { "alias": "markerHandler"; "required": false; }; "value": { "alias": "value"; "required": false; }; "hoveredItem": { "alias": "hoveredItem"; "required": false; }; "showAdjacent": { "alias": "showAdjacent"; "required": false; }; "single": { "alias": "single"; "required": false; }; }, { "hoveredItemChange": "hoveredItemChange"; "dayClick": "dayClick"; }, never, never, true, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarSheet, "tui-calendar-sheet", never, { "month": { "alias": "month"; "required": false; "isSignal": true; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; "isSignal": true; }; "markerHandler": { "alias": "markerHandler"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "showAdjacent": { "alias": "showAdjacent"; "required": false; "isSignal": true; }; "hoveredItem": { "alias": "hoveredItem"; "required": false; "isSignal": true; }; "single": { "alias": "single"; "required": false; }; }, { "hoveredItem": "hoveredItemChange"; "dayClick": "dayClick"; }, never, never, true, never>;
43
36
  }
@@ -1,16 +1,13 @@
1
- import { EventEmitter } from '@angular/core';
2
1
  import { TuiMonth, type TuiMonthLike, type TuiYear } from '@taiga-ui/cdk/date-time';
3
2
  import * as i0 from "@angular/core";
4
3
  export declare class TuiCalendarSpin {
5
4
  protected readonly months: import("@angular/core").Signal<readonly [January: string, February: string, March: string, April: string, May: string, June: string, July: string, August: string, September: string, October: string, November: string, December: string]>;
6
- value: TuiMonth;
7
- min: TuiMonth;
8
- max: TuiMonth;
9
- readonly valueChange: EventEmitter<TuiMonth>;
10
- readonly yearClick: EventEmitter<TuiYear>;
11
- protected onYearClick(): void;
5
+ readonly value: import("@angular/core").ModelSignal<TuiMonth>;
6
+ readonly min: import("@angular/core").InputSignal<TuiMonth>;
7
+ readonly max: import("@angular/core").InputSignal<TuiMonth>;
8
+ readonly yearClick: import("@angular/core").OutputEmitterRef<TuiYear>;
12
9
  protected append(date: TuiMonthLike): void;
13
10
  private updateValue;
14
11
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiCalendarSpin, never>;
15
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarSpin, "tui-calendar-spin", never, { "value": { "alias": "value"; "required": false; }; "min": { "alias": "min"; "required": false; }; "max": { "alias": "max"; "required": false; }; }, { "valueChange": "valueChange"; "yearClick": "yearClick"; }, never, never, true, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarSpin, "tui-calendar-spin", never, { "value": { "alias": "value"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; }, { "value": "valueChange"; "yearClick": "yearClick"; }, never, never, true, never>;
16
13
  }
@@ -1,33 +1,25 @@
1
- import { EventEmitter } from '@angular/core';
2
1
  import { TuiDay, type TuiDayRange, TuiMonthRange, TuiYear } from '@taiga-ui/cdk/date-time';
3
2
  import { type TuiBooleanHandler } from '@taiga-ui/cdk/types';
4
3
  import * as i0 from "@angular/core";
5
4
  export declare class TuiCalendarYear {
6
5
  private readonly hoveredItem;
6
+ private readonly calculatedMin;
7
+ private readonly calculatedMax;
7
8
  protected readonly isRangePicking: import("@angular/core").Signal<boolean>;
8
- rangeMode: boolean;
9
- disabledItemHandler: TuiBooleanHandler<number>;
10
- readonly yearClick: EventEmitter<number>;
11
- readonly initialItem: import("@angular/core").WritableSignal<number>;
12
- readonly min: import("@angular/core").WritableSignal<number>;
13
- readonly max: import("@angular/core").WritableSignal<number>;
14
- readonly value: import("@angular/core").WritableSignal<number | TuiYear | readonly TuiDay[] | TuiDayRange | TuiMonthRange | null>;
15
- set initialItemSetter(x: number | null);
16
- set minSetter(x: number);
17
- set maxSetter(x: number);
18
- set valueSetter(x: TuiDayRange | TuiMonthRange | TuiYear | number | readonly TuiDay[] | null);
9
+ protected readonly rows: import("@angular/core").Signal<number>;
10
+ readonly rangeMode: import("@angular/core").InputSignal<boolean>;
11
+ readonly disabledItemHandler: import("@angular/core").InputSignal<TuiBooleanHandler<number>>;
12
+ readonly value: import("@angular/core").InputSignal<number | TuiYear | readonly TuiDay[] | TuiDayRange | TuiMonthRange | null>;
13
+ readonly min: import("@angular/core").InputSignalWithTransform<number, number | null>;
14
+ readonly max: import("@angular/core").InputSignalWithTransform<number, number | null>;
15
+ readonly initialItem: import("@angular/core").InputSignalWithTransform<number, number | null>;
16
+ readonly yearClick: import("@angular/core").OutputEmitterRef<number>;
19
17
  isDisabled(item: number): boolean;
20
18
  getItemRange(item: number): 'active' | 'end' | 'middle' | 'start' | null;
21
19
  onItemHovered(hovered: boolean, item: number): void;
22
- protected get rows(): number;
23
20
  protected scrollItemIntoView(item: number): boolean;
24
21
  protected getItem(rowIndex: number, colIndex: number): number;
25
22
  protected itemIsToday(item: number): boolean;
26
- private get calculatedMin();
27
- private get calculatedMax();
28
23
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiCalendarYear, never>;
29
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarYear, "tui-calendar-year", never, { "rangeMode": { "alias": "rangeMode"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "initialItemSetter": { "alias": "initialItem"; "required": false; }; "minSetter": { "alias": "min"; "required": false; }; "maxSetter": { "alias": "max"; "required": false; }; "valueSetter": { "alias": "value"; "required": false; }; }, { "yearClick": "yearClick"; }, never, never, true, never>;
30
- static ngAcceptInputType_initialItemSetter: number | null;
31
- static ngAcceptInputType_minSetter: number | null;
32
- static ngAcceptInputType_maxSetter: number | null;
24
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarYear, "tui-calendar-year", never, { "rangeMode": { "alias": "rangeMode"; "required": false; "isSignal": true; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "initialItem": { "alias": "initialItem"; "required": false; "isSignal": true; }; }, { "yearClick": "yearClick"; }, never, never, true, never>;
33
25
  }
@@ -11,10 +11,12 @@ export declare class TuiCalendar {
11
11
  protected readonly options: import("./calendar-sheet.options").TuiCalendarSheetOptions;
12
12
  month: TuiMonth;
13
13
  disabledItemHandler: TuiBooleanHandler<TuiDay>;
14
- min: TuiDay | null;
15
- max: TuiDay | null;
16
- minViewedMonth: TuiMonth | null;
17
- maxViewedMonth: TuiMonth | null;
14
+ readonly min: import("@angular/core").InputSignalWithTransform<TuiDay, TuiDay | null>;
15
+ readonly max: import("@angular/core").InputSignalWithTransform<TuiDay, TuiDay | null>;
16
+ readonly minViewedMonth: import("@angular/core").InputSignal<TuiMonth | null>;
17
+ readonly maxViewedMonth: import("@angular/core").InputSignal<TuiMonth | null>;
18
+ protected readonly computedMinViewedMonth: import("@angular/core").Signal<TuiDay | TuiMonth>;
19
+ protected readonly computedMaxViewedMonth: import("@angular/core").Signal<TuiDay | TuiMonth>;
18
20
  hoveredItem: TuiDay | null;
19
21
  showAdjacent: boolean;
20
22
  markerHandler: TuiMarkerHandler | null;
@@ -29,10 +31,6 @@ export declare class TuiCalendar {
29
31
  onPaginationValueChange(month: TuiMonth): void;
30
32
  onDayClick(day: TuiDay): void;
31
33
  onHoveredItemChange(day: TuiDay | null): void;
32
- protected get computedMin(): TuiDay;
33
- protected get computedMax(): TuiDay;
34
- protected get computedMinViewedMonth(): TuiMonth;
35
- protected get computedMaxViewedMonth(): TuiMonth;
36
34
  protected get isInYearView(): boolean;
37
35
  protected readonly disabledItemHandlerMapper: TuiMapper<[
38
36
  TuiBooleanHandler<TuiDay>,
@@ -44,5 +42,5 @@ export declare class TuiCalendar {
44
42
  private updateViewedMonth;
45
43
  private updateHoveredDay;
46
44
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiCalendar, never>;
47
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendar, "tui-calendar", never, { "month": { "alias": "month"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "min": { "alias": "min"; "required": false; }; "max": { "alias": "max"; "required": false; }; "minViewedMonth": { "alias": "minViewedMonth"; "required": false; }; "maxViewedMonth": { "alias": "maxViewedMonth"; "required": false; }; "hoveredItem": { "alias": "hoveredItem"; "required": false; }; "showAdjacent": { "alias": "showAdjacent"; "required": false; }; "markerHandler": { "alias": "markerHandler"; "required": false; }; "value": { "alias": "value"; "required": false; }; "initialView": { "alias": "initialView"; "required": false; }; }, { "dayClick": "dayClick"; "monthChange": "monthChange"; "hoveredItemChange": "hoveredItemChange"; }, never, never, true, never>;
45
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendar, "tui-calendar", never, { "month": { "alias": "month"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "minViewedMonth": { "alias": "minViewedMonth"; "required": false; "isSignal": true; }; "maxViewedMonth": { "alias": "maxViewedMonth"; "required": false; "isSignal": true; }; "hoveredItem": { "alias": "hoveredItem"; "required": false; }; "showAdjacent": { "alias": "showAdjacent"; "required": false; }; "markerHandler": { "alias": "markerHandler"; "required": false; }; "value": { "alias": "value"; "required": false; }; "initialView": { "alias": "initialView"; "required": false; }; }, { "dayClick": "dayClick"; "monthChange": "monthChange"; "hoveredItemChange": "hoveredItemChange"; }, never, never, true, never>;
48
46
  }
@@ -0,0 +1,10 @@
1
+ import { TuiRadioComponent } from '@taiga-ui/core/components/radio';
2
+ import { type TuiCheckboxOptions } from './checkbox.options';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@taiga-ui/core/directives/icons";
5
+ export declare class TuiCheckbox extends TuiRadioComponent<TuiCheckboxOptions> {
6
+ protected readonly check: import("@angular/core").Signal<string>;
7
+ protected readonly indeterminate: import("@angular/core").Signal<string>;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiCheckbox, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiCheckbox, "input[type=\"checkbox\"][tuiCheckbox]", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiIcons; inputs: {}; outputs: {}; }]>;
10
+ }
@@ -0,0 +1,10 @@
1
+ import { type TuiStringHandler } from '@taiga-ui/cdk/types';
2
+ import { type TuiRadioOptions } from '@taiga-ui/core/components/radio';
3
+ import { type TuiSizeS } from '@taiga-ui/core/types';
4
+ export interface TuiCheckboxOptions extends TuiRadioOptions {
5
+ readonly icons: Readonly<{
6
+ checked: TuiStringHandler<TuiSizeS>;
7
+ indeterminate: TuiStringHandler<TuiSizeS>;
8
+ }>;
9
+ }
10
+ export declare const TUI_CHECKBOX_OPTIONS: import("@angular/core").InjectionToken<TuiCheckboxOptions>, tuiCheckboxOptionsProvider: (item: Partial<TuiCheckboxOptions> | (() => Partial<TuiCheckboxOptions>)) => import("@angular/core").FactoryProvider;
@@ -0,0 +1,2 @@
1
+ export * from './checkbox.component';
2
+ export * from './checkbox.options';
@@ -19,6 +19,7 @@ export declare class TuiDataListComponent<T> implements TuiDataListAccessor<T>,
19
19
  onKeyDownArrow(current: HTMLElement, step: number): void;
20
20
  handleFocusLossIfNecessary(element?: Element): void;
21
21
  ngAfterContentChecked(): void;
22
+ protected get role(): string | null;
22
23
  protected onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void;
23
24
  private get elements();
24
25
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDataListComponent<any>, never>;
@@ -4,4 +4,5 @@ export * from './data-list.tokens';
4
4
  export * from './opt-group.directive';
5
5
  export * from './option.directive';
6
6
  export * from './option-content.directive';
7
+ export * from './option-with-content.directive';
7
8
  export * from './option-with-value.directive';
@@ -8,7 +8,7 @@ export declare function tuiAsOptionContent(useValue: Type<any>): Provider;
8
8
  export declare class TuiWithOptionContent {
9
9
  protected readonly local: Type<any> | null;
10
10
  protected readonly global: Type<any> | null;
11
- get content(): Type<any> | null;
11
+ get content(): Type<any> | null | undefined;
12
12
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiWithOptionContent, never>;
13
13
  static ɵdir: i0.ɵɵDirectiveDeclaration<TuiWithOptionContent, never, never, {}, {}, ["local"], never, true, never>;
14
14
  }
@@ -0,0 +1,9 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class TuiOptionWithContent {
3
+ private readonly vcr;
4
+ private readonly content;
5
+ private readonly ref;
6
+ constructor();
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiOptionWithContent, never>;
8
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiOptionWithContent, never, never, {}, {}, never, never, true, never>;
9
+ }
@@ -1,9 +1,10 @@
1
1
  import * as i0 from "@angular/core";
2
+ import * as i1 from "./option-with-content.directive";
2
3
  export declare class TuiOptionWithValue<T = unknown> {
3
4
  private readonly host;
4
5
  readonly disabled: import("@angular/core").InputSignal<boolean>;
5
6
  readonly value: import("@angular/core").InputSignal<T | undefined>;
6
7
  protected onClick(value?: T | undefined): void;
7
8
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiOptionWithValue<any>, never>;
8
- static ɵdir: i0.ɵɵDirectiveDeclaration<TuiOptionWithValue<any>, "button[tuiOption][value], a[tuiOption][value], label[tuiOption][value]", never, { "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
9
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiOptionWithValue<any>, "button[tuiOption][value], a[tuiOption][value], label[tuiOption][value]", never, { "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; }, {}, never, never, true, [{ directive: typeof i1.TuiOptionWithContent; inputs: {}; outputs: {}; }]>;
9
10
  }
@@ -3,15 +3,11 @@ import * as i0 from "@angular/core";
3
3
  import * as i1 from "@taiga-ui/core/directives/icons";
4
4
  import * as i2 from "@taiga-ui/core/components/cell";
5
5
  export declare class TuiOption<T = unknown> implements OnDestroy {
6
- private readonly vcr;
7
6
  private readonly isMobile;
8
7
  private readonly el;
9
8
  private readonly datalist;
10
- private readonly content;
11
- private readonly ref;
12
9
  protected readonly dropdown: import("@angular/core").WritableSignal<import("@angular/core").ComponentRef<unknown> | null> | undefined;
13
10
  readonly disabled: import("@angular/core").InputSignal<boolean>;
14
- constructor();
15
11
  ngOnDestroy(): void;
16
12
  protected onMouseMove(): void;
17
13
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiOption<any>, never>;
@@ -1,6 +1,7 @@
1
1
  export * from '@taiga-ui/core/components/button';
2
2
  export * from '@taiga-ui/core/components/calendar';
3
3
  export * from '@taiga-ui/core/components/cell';
4
+ export * from '@taiga-ui/core/components/checkbox';
4
5
  export * from '@taiga-ui/core/components/data-list';
5
6
  export * from '@taiga-ui/core/components/error';
6
7
  export * from '@taiga-ui/core/components/expand';
@@ -10,8 +11,10 @@ export * from '@taiga-ui/core/components/label';
10
11
  export * from '@taiga-ui/core/components/link';
11
12
  export * from '@taiga-ui/core/components/loader';
12
13
  export * from '@taiga-ui/core/components/notification';
14
+ export * from '@taiga-ui/core/components/radio';
13
15
  export * from '@taiga-ui/core/components/root';
14
16
  export * from '@taiga-ui/core/components/scrollbar';
17
+ export * from '@taiga-ui/core/components/slider';
15
18
  export * from '@taiga-ui/core/components/spin-button';
16
19
  export * from '@taiga-ui/core/components/textfield';
17
20
  export * from '@taiga-ui/core/components/title';
@@ -1,6 +1,7 @@
1
1
  import { NgControl } from '@angular/forms';
2
2
  import { type TuiTextfieldAccessor, TuiTextfieldComponent } from '@taiga-ui/core/components/textfield';
3
3
  import { type TuiItemsHandlers } from '@taiga-ui/core/directives/items-handlers';
4
+ import { TuiDropdownDirective } from '@taiga-ui/core/portals/dropdown';
4
5
  import { type TuiInteractiveState } from '@taiga-ui/core/types';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@taiga-ui/cdk/directives/native-validator";
@@ -9,6 +10,7 @@ export declare class TuiInputDirective<T> implements TuiTextfieldAccessor<T> {
9
10
  protected readonly control: NgControl | null;
10
11
  protected readonly handlers: TuiItemsHandlers<T>;
11
12
  protected readonly textfield: TuiTextfieldComponent<any>;
13
+ protected readonly dropdown: TuiDropdownDirective;
12
14
  protected readonly a: import("@angular/core").Signal<string>;
13
15
  protected readonly s: import("@angular/core").Signal<TuiInteractiveState | null>;
14
16
  protected readonly m: import("@angular/core").Signal<string | readonly string[] | null>;
@@ -1,10 +1,8 @@
1
1
  import { type PolymorpheusContent } from '@taiga-ui/polymorpheus';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class TuiLoader {
4
- private readonly isIOS;
5
4
  private readonly options;
6
5
  protected readonly isApple: boolean;
7
- protected readonly isHorizontal: import("@angular/core").Signal<boolean>;
8
6
  readonly size: import("@angular/core").InputSignal<"m" | "s" | "xs" | "l" | "xl" | "xxl">;
9
7
  readonly inheritColor: import("@angular/core").InputSignal<boolean>;
10
8
  readonly overlay: import("@angular/core").InputSignal<boolean>;
@@ -0,0 +1,4 @@
1
+ export * from './radio';
2
+ export * from './radio.component';
3
+ export * from './radio.directive';
4
+ export * from './radio.options';
@@ -0,0 +1,18 @@
1
+ import { type DoCheck, type OnInit } from '@angular/core';
2
+ import { NgControl } from '@angular/forms';
3
+ import { type TuiRadioOptions } from './radio.options';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@taiga-ui/core/directives/appearance";
6
+ import * as i2 from "@taiga-ui/cdk/directives/native-validator";
7
+ export declare class TuiRadioComponent<T extends TuiRadioOptions> implements DoCheck, OnInit {
8
+ private readonly destroyRef;
9
+ protected readonly el: HTMLInputElement;
10
+ protected readonly options: T;
11
+ protected readonly appearance: import("@angular/core").WritableSignal<string>;
12
+ protected readonly control: NgControl | null;
13
+ readonly size: import("@angular/core").InputSignal<import("@taiga-ui/core/types").TuiSizeS>;
14
+ ngOnInit(): void;
15
+ ngDoCheck(): void;
16
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiRadioComponent<any>, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiRadioComponent<any>, "input[type=\"radio\"][tuiRadio]", never, { "size": { "alias": "size"; "required": false; "isSignal": true; }; }, {}, never, never, true, [{ directive: typeof i1.TuiAppearance; inputs: { "tuiAppearanceState": "tuiAppearanceState"; "tuiAppearanceFocus": "tuiAppearanceFocus"; "tuiAppearanceMode": "tuiAppearanceMode"; }; outputs: {}; }, { directive: typeof i2.TuiNativeValidator; inputs: {}; outputs: {}; }]>;
18
+ }
@@ -0,0 +1,3 @@
1
+ import { TuiRadioComponent } from './radio.component';
2
+ import { TuiRadioDirective } from './radio.directive';
3
+ export declare const TuiRadio: readonly [typeof TuiRadioComponent, typeof TuiRadioDirective];
@@ -0,0 +1,8 @@
1
+ import { type TuiIdentityMatcher } from '@taiga-ui/cdk/types';
2
+ import * as i0 from "@angular/core";
3
+ export declare class TuiRadioDirective<T> {
4
+ readonly identityMatcher: import("@angular/core").InputSignal<TuiIdentityMatcher<T>>;
5
+ constructor();
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiRadioDirective<any>, never>;
7
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiRadioDirective<any>, "input[type=\"radio\"][tuiRadio][identityMatcher]", never, { "identityMatcher": { "alias": "identityMatcher"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
8
+ }
@@ -0,0 +1,7 @@
1
+ import { type TuiStringHandler } from '@taiga-ui/cdk/types';
2
+ import { type TuiSizeS } from '@taiga-ui/core/types';
3
+ export interface TuiRadioOptions {
4
+ readonly appearance: TuiStringHandler<HTMLInputElement>;
5
+ readonly size: TuiSizeS;
6
+ }
7
+ export declare const TUI_RADIO_OPTIONS: import("@angular/core").InjectionToken<TuiRadioOptions>, tuiRadioOptionsProvider: (item: Partial<TuiRadioOptions> | (() => Partial<TuiRadioOptions>)) => import("@angular/core").FactoryProvider;
@@ -0,0 +1,27 @@
1
+ import { type TuiValueTransformer } from '@taiga-ui/cdk/classes';
2
+ /**
3
+ * Used as a limit for eliminating JS issues with floating point math
4
+ */
5
+ export declare const TUI_FLOATING_PRECISION = 7;
6
+ /**
7
+ * Steps for splitting sliders into different linear dependencies.
8
+ * Each element of the array has the form [percent, value]
9
+ *
10
+ * Thus, to set a field from 50,000 to 30,000,000 in steps:
11
+ * 1) From 50 000 to 200 000 by 5000 per step (30 steps)
12
+ * 2) From 200 000 to 1 000 000 by 50 000 per step (16 steps)
13
+ * 3) From 1 000 000 to 30 000 000 by 500 000 per step (58 steps)
14
+ *
15
+ * You need to pass the following keyStep (where 104 = 30 + 16 + 58 is the total number of steps):
16
+ * [
17
+ * [0, 50_000],
18
+ * [100 / 104 * 30, 200_000],
19
+ * [100 / 104 * (30 + 16), 1_000_000],
20
+ * [100, 30_000_000],
21
+ * ];
22
+ *
23
+ */
24
+ export type TuiKeySteps = [[0, number], ...Array<[number, number]>, [100, number]];
25
+ export declare function tuiPercentageToKeyStepValue(valuePercentage: number, keySteps: TuiKeySteps): number;
26
+ export declare function tuiKeyStepValueToPercentage(value: number, keySteps: TuiKeySteps): number;
27
+ export declare function tuiCreateKeyStepsTransformer(keySteps: TuiKeySteps): TuiValueTransformer<number, number>;
@@ -0,0 +1,32 @@
1
+ import { type OnInit } from '@angular/core';
2
+ import { TuiControl, type TuiValueTransformer } from '@taiga-ui/cdk/classes';
3
+ import { TuiSliderComponent } from '../slider.component';
4
+ import { type TuiKeySteps } from './key-steps';
5
+ import * as i0 from "@angular/core";
6
+ export declare class TuiSliderKeyStepsBase implements OnInit {
7
+ private readonly injector;
8
+ private readonly control;
9
+ protected readonly min: import("@angular/core").WritableSignal<number | undefined>;
10
+ protected readonly max: import("@angular/core").WritableSignal<number | undefined>;
11
+ protected readonly sync: import("@angular/core").EffectRef;
12
+ slider: TuiSliderComponent;
13
+ readonly step: import("@angular/core").InputSignal<number>;
14
+ readonly keySteps: import("@angular/core").InputSignal<[[0, number], ...[number, number][], [100, number]] | undefined>;
15
+ readonly transformer: import("@angular/core").WritableSignal<TuiValueTransformer<number, number> | undefined>;
16
+ controlValue: import("@angular/core").Signal<number | undefined>;
17
+ readonly totalSteps: import("@angular/core").Signal<number>;
18
+ ngOnInit(): void;
19
+ takeStep(coefficient: number): number;
20
+ toSliderValue(fraction: number): number;
21
+ setControlValue(controlValue: number): void;
22
+ getControlValue(): number;
23
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiSliderKeyStepsBase, never>;
24
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiSliderKeyStepsBase, "input[tuiSlider][keySteps]", never, { "step": { "alias": "step"; "required": false; "isSignal": true; }; "keySteps": { "alias": "keySteps"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
25
+ }
26
+ export declare class TuiSliderKeySteps extends TuiControl<number> {
27
+ protected readonly base: TuiSliderKeyStepsBase;
28
+ set keySteps(steps: TuiKeySteps | null | undefined);
29
+ protected setValue(sliderValue: number): void;
30
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiSliderKeySteps, never>;
31
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiSliderKeySteps, "input[tuiSlider][keySteps][ngModel],input[tuiSlider][keySteps][formControl],input[tuiSlider][keySteps][formControlName]", never, { "keySteps": { "alias": "keySteps"; "required": false; }; }, {}, never, never, true, never>;
32
+ }
@@ -0,0 +1,15 @@
1
+ import * as i0 from "@angular/core";
2
+ /**
3
+ * Native <input type='range' readonly> doesn't work.
4
+ * This directive imitates this native behaviour.
5
+ */
6
+ export declare class TuiSliderReadonly {
7
+ private readonly el;
8
+ private readonly doc;
9
+ readonly readonly: import("@angular/core").InputSignalWithTransform<boolean, any>;
10
+ constructor();
11
+ protected preventEvent(event: Event): void;
12
+ protected preventKeyboardInteraction(event: KeyboardEvent): void;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiSliderReadonly, never>;
14
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiSliderReadonly, "input[tuiSlider][readonly]", never, { "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
15
+ }
@@ -0,0 +1,13 @@
1
+ import { type AfterContentInit } from '@angular/core';
2
+ import { NgControl } from '@angular/forms';
3
+ import { TuiSliderComponent } from '../slider.component';
4
+ import * as i0 from "@angular/core";
5
+ export declare class TuiSliderThumbLabel implements AfterContentInit {
6
+ protected readonly slider: import("@angular/core").Signal<TuiSliderComponent | undefined>;
7
+ protected readonly control: import("@angular/core").Signal<NgControl | undefined>;
8
+ ngAfterContentInit(): void;
9
+ protected get ratio(): number;
10
+ protected get ghostStart(): number;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiSliderThumbLabel, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiSliderThumbLabel, "[tuiSliderThumbLabel]", never, {}, {}, ["slider", "control"], ["*", "input[type=range]"], true, never>;
13
+ }
@@ -0,0 +1,6 @@
1
+ export * from './helpers/key-steps';
2
+ export * from './helpers/slider-key-steps.directive';
3
+ export * from './helpers/slider-readonly.directive';
4
+ export * from './helpers/slider-thumb-label.component';
5
+ export * from './slider';
6
+ export * from './slider.component';
@@ -0,0 +1,22 @@
1
+ import { TuiSliderKeyStepsBase } from './helpers/slider-key-steps.directive';
2
+ import * as i0 from "@angular/core";
3
+ export declare class TuiSliderComponent {
4
+ private readonly control;
5
+ protected readonly ticksGradient: import("@angular/core").Signal<string>;
6
+ readonly segments: import("@angular/core").InputSignalWithTransform<readonly number[], number | readonly number[]>;
7
+ readonly el: HTMLInputElement;
8
+ readonly keySteps: TuiSliderKeyStepsBase | null;
9
+ constructor();
10
+ get valueRatio(): number;
11
+ get min(): number;
12
+ set min(x: number);
13
+ get max(): number;
14
+ set max(x: number);
15
+ get step(): number;
16
+ set step(x: number);
17
+ get value(): number;
18
+ set value(newValue: number);
19
+ protected getTicksGradient(segments: readonly number[]): string;
20
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiSliderComponent, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiSliderComponent, "input[type=range][tuiSlider]", never, { "segments": { "alias": "segments"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
22
+ }
@@ -0,0 +1,5 @@
1
+ import { TuiSliderKeySteps, TuiSliderKeyStepsBase } from './helpers/slider-key-steps.directive';
2
+ import { TuiSliderReadonly } from './helpers/slider-readonly.directive';
3
+ import { TuiSliderThumbLabel } from './helpers/slider-thumb-label.component';
4
+ import { TuiSliderComponent } from './slider.component';
5
+ export declare const TuiSlider: readonly [typeof TuiSliderComponent, typeof TuiSliderThumbLabel, typeof TuiSliderKeyStepsBase, typeof TuiSliderKeySteps, typeof TuiSliderReadonly];
@@ -5,7 +5,6 @@ export * from './textfield.options';
5
5
  export * from './textfield-accessor';
6
6
  export * from './textfield-auxiliary';
7
7
  export * from './textfield-content.directive';
8
- export * from './textfield-icon';
9
8
  export * from './textfield-multi/textfield-item.component';
10
9
  export * from './textfield-multi/textfield-multi.component';
11
10
  export * from './with-native-picker.directive';
@@ -12,6 +12,7 @@ export declare class TuiTextfieldItemComponent<T> {
12
12
  protected readonly context: TuiContext<TuiTextfieldItem<T>>;
13
13
  protected readonly textfield: TuiTextfieldMultiComponent<any>;
14
14
  protected readonly content: import("@angular/core").Signal<string | import("@angular/core").TemplateRef<any>>;
15
+ protected prevent(e: Event): void;
15
16
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldItemComponent<any>, never>;
16
17
  static ɵcmp: i0.ɵɵComponentDeclaration<TuiTextfieldItemComponent<any>, "tui-textfield-item", never, {}, {}, never, never, true, never>;
17
18
  }
@@ -4,6 +4,7 @@ import { TuiTextfieldComponent } from '../textfield.component';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class TuiTextfieldMultiComponent<T> extends TuiTextfieldComponent<T> {
6
6
  protected readonly height: import("@angular/core").WritableSignal<number | null>;
7
+ protected readonly win: Window;
7
8
  protected readonly handlers: import("@taiga-ui/core/directives/items-handlers").TuiItemsHandlers<unknown>;
8
9
  protected readonly component: import("@taiga-ui/polymorpheus").PolymorpheusContent<import("@taiga-ui/cdk/types").TuiContext<import("./textfield-item.component").TuiTextfieldItem<any>>>;
9
10
  protected readonly sub: import("rxjs").Subscription;
@@ -14,6 +15,7 @@ export declare class TuiTextfieldMultiComponent<T> extends TuiTextfieldComponent
14
15
  protected get placeholder(): string;
15
16
  protected onItems({ target }: ResizeObserverEntry): void;
16
17
  protected onLeft(event: any): void;
18
+ protected focusInput(): void;
17
19
  protected onClick(target: HTMLElement): void;
18
20
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldMultiComponent<any>, never>;
19
21
  static ɵcmp: i0.ɵɵComponentDeclaration<TuiTextfieldMultiComponent<any>, "tui-textfield[multi]", never, { "rows": { "alias": "rows"; "required": false; "isSignal": true; }; }, {}, ["cva", "item"], ["label", "input", "select", "*", "tui-icon"], true, never>;
@@ -34,6 +34,7 @@ export declare class TuiTextfieldComponent<T> implements TuiDataListHost<T> {
34
34
  readonly filler: import("@angular/core").InputSignal<string>;
35
35
  readonly value: import("@angular/core").WritableSignal<string>;
36
36
  get id(): string;
37
+ get disabled(): boolean;
37
38
  get size(): TuiSizeL | TuiSizeS;
38
39
  handleOption(option: T): void;
39
40
  protected get hasLabel(): boolean;
@@ -4,6 +4,7 @@ import { type TuiBooleanHandler } from '@taiga-ui/cdk/types';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class TuiItemsHandlersValidator extends TuiValidator {
6
6
  private readonly handlers;
7
+ private initialized;
7
8
  protected readonly update: import("@angular/core").EffectRef;
8
9
  disabledItemHandler: TuiBooleanHandler<any>;
9
10
  validate: ValidatorFn;
@@ -59,10 +59,10 @@ class TuiDriverDirective {
59
59
  vehicle?.toggle(value);
60
60
  });
61
61
  }
62
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiDriverDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
63
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.2.17", type: TuiDriverDirective, isStandalone: true, ngImport: i0 }); }
62
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.19", ngImport: i0, type: TuiDriverDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
63
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.2.19", type: TuiDriverDirective, isStandalone: true, ngImport: i0 }); }
64
64
  }
65
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiDriverDirective, decorators: [{
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.19", ngImport: i0, type: TuiDriverDirective, decorators: [{
66
66
  type: Directive
67
67
  }] });
68
68
 
@@ -1 +1 @@
1
- {"version":3,"file":"taiga-ui-core-classes.mjs","sources":["../../../projects/core/classes/accessors.ts","../../../projects/core/classes/vehicle.ts","../../../projects/core/classes/driver.ts","../../../projects/core/classes/taiga-ui-core-classes.ts"],"sourcesContent":["import {\n type AbstractType,\n type ExistingProvider,\n type FactoryProvider,\n Optional,\n SkipSelf,\n type Type,\n} from '@angular/core';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/di';\nimport {type TuiPoint} from '@taiga-ui/core/types';\n\nexport abstract class TuiAccessor {\n public abstract readonly type: string;\n}\n\nexport abstract class TuiPositionAccessor extends TuiAccessor {\n public abstract getPosition(rect: DOMRect): TuiPoint;\n}\n\nexport abstract class TuiRectAccessor extends TuiAccessor {\n public abstract getClientRect(): DOMRect;\n}\n\nexport function tuiProvideAccessor<T extends TuiAccessor>(\n provide: AbstractType<T>,\n type: string,\n fallback: Type<T>,\n): FactoryProvider {\n return {\n provide,\n deps: [[new SkipSelf(), new Optional(), provide], fallback],\n useFactory: tuiFallbackAccessor<T>(type),\n };\n}\n\nexport function tuiFallbackAccessor<T extends TuiAccessor>(\n type: string,\n): (accessors: readonly T[] | null, fallback: Omit<T, 'type'>) => T {\n return (accessors, fallback) =>\n accessors?.find?.(\n (accessor) => accessor !== fallback && accessor.type === type,\n ) || Object.create(fallback, {type: {value: type}});\n}\n\nexport function tuiPositionAccessorFor(\n type: string,\n fallback: Type<TuiPositionAccessor>,\n): FactoryProvider {\n return tuiProvideAccessor(TuiPositionAccessor, type, fallback);\n}\n\nexport function tuiRectAccessorFor(\n type: string,\n fallback: Type<TuiRectAccessor>,\n): FactoryProvider {\n return tuiProvideAccessor(TuiRectAccessor, type, fallback);\n}\n\nexport function tuiAsPositionAccessor(\n accessor: Type<TuiPositionAccessor>,\n): ExistingProvider {\n return tuiProvide(TuiPositionAccessor, accessor, true);\n}\n\nexport function tuiAsRectAccessor(accessor: Type<TuiRectAccessor>): ExistingProvider {\n return tuiProvide(TuiRectAccessor, accessor, true);\n}\n","import {type ExistingProvider, type Type} from '@angular/core';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/di';\n\nexport abstract class TuiVehicle {\n public abstract readonly type: string;\n public abstract toggle(value: boolean): void;\n}\n\nexport function tuiAsVehicle(vehicle: Type<TuiVehicle>): ExistingProvider {\n return tuiProvide(TuiVehicle, vehicle, true);\n}\n","import {coerceArray} from '@angular/cdk/coercion';\nimport {\n type AfterViewInit,\n DestroyRef,\n Directive,\n type ExistingProvider,\n inject,\n type Type,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/di';\nimport {distinctUntilChanged, merge, Observable} from 'rxjs';\n\nimport {TuiVehicle} from './vehicle';\n\nexport abstract class TuiDriver extends Observable<boolean> {\n public abstract readonly type: string;\n}\n\nexport function tuiAsDriver(driver: Type<TuiDriver>): ExistingProvider {\n return tuiProvide(TuiDriver, driver, true);\n}\n\n@Directive()\nexport abstract class TuiDriverDirective implements AfterViewInit {\n public abstract type: string;\n\n private readonly destroyRef = inject(DestroyRef);\n private readonly drivers = coerceArray(\n inject(TuiDriver, {self: true, optional: true}) || [],\n );\n\n private readonly vehicles = coerceArray(\n inject(TuiVehicle, {self: true, optional: true}) || [],\n );\n\n public ngAfterViewInit(): void {\n const vehicle = this.vehicles.find(({type}) => type === this.type);\n\n merge(...this.drivers.filter(({type}) => type === this.type))\n .pipe(distinctUntilChanged(), takeUntilDestroyed(this.destroyRef))\n .subscribe((value) => {\n vehicle?.toggle(value);\n });\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"taiga-ui-core-classes.mjs","sources":["../../../projects/core/classes/accessors.ts","../../../projects/core/classes/vehicle.ts","../../../projects/core/classes/driver.ts","../../../projects/core/classes/taiga-ui-core-classes.ts"],"sourcesContent":["import {\n type AbstractType,\n type ExistingProvider,\n type FactoryProvider,\n Optional,\n SkipSelf,\n type Type,\n} from '@angular/core';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/di';\nimport {type TuiPoint} from '@taiga-ui/core/types';\n\nexport abstract class TuiAccessor {\n public abstract readonly type: string;\n}\n\nexport abstract class TuiPositionAccessor extends TuiAccessor {\n public abstract getPosition(rect: DOMRect): TuiPoint;\n}\n\nexport abstract class TuiRectAccessor extends TuiAccessor {\n public abstract getClientRect(): DOMRect;\n}\n\nexport function tuiProvideAccessor<T extends TuiAccessor>(\n provide: AbstractType<T>,\n type: string,\n fallback: Type<T>,\n): FactoryProvider {\n return {\n provide,\n deps: [[new SkipSelf(), new Optional(), provide], fallback],\n useFactory: tuiFallbackAccessor<T>(type),\n };\n}\n\nexport function tuiFallbackAccessor<T extends TuiAccessor>(\n type: string,\n): (accessors: readonly T[] | null, fallback: Omit<T, 'type'>) => T {\n return (accessors, fallback) =>\n accessors?.find?.(\n (accessor) => accessor !== fallback && accessor.type === type,\n ) || Object.create(fallback, {type: {value: type}});\n}\n\nexport function tuiPositionAccessorFor(\n type: string,\n fallback: Type<TuiPositionAccessor>,\n): FactoryProvider {\n return tuiProvideAccessor(TuiPositionAccessor, type, fallback);\n}\n\nexport function tuiRectAccessorFor(\n type: string,\n fallback: Type<TuiRectAccessor>,\n): FactoryProvider {\n return tuiProvideAccessor(TuiRectAccessor, type, fallback);\n}\n\nexport function tuiAsPositionAccessor(\n accessor: Type<TuiPositionAccessor>,\n): ExistingProvider {\n return tuiProvide(TuiPositionAccessor, accessor, true);\n}\n\nexport function tuiAsRectAccessor(accessor: Type<TuiRectAccessor>): ExistingProvider {\n return tuiProvide(TuiRectAccessor, accessor, true);\n}\n","import {type ExistingProvider, type Type} from '@angular/core';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/di';\n\nexport abstract class TuiVehicle {\n public abstract readonly type: string;\n public abstract toggle(value: boolean): void;\n}\n\nexport function tuiAsVehicle(vehicle: Type<TuiVehicle>): ExistingProvider {\n return tuiProvide(TuiVehicle, vehicle, true);\n}\n","import {coerceArray} from '@angular/cdk/coercion';\nimport {\n type AfterViewInit,\n DestroyRef,\n Directive,\n type ExistingProvider,\n inject,\n type Type,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/di';\nimport {distinctUntilChanged, merge, Observable} from 'rxjs';\n\nimport {TuiVehicle} from './vehicle';\n\nexport abstract class TuiDriver extends Observable<boolean> {\n public abstract readonly type: string;\n}\n\nexport function tuiAsDriver(driver: Type<TuiDriver>): ExistingProvider {\n return tuiProvide(TuiDriver, driver, true);\n}\n\n@Directive()\nexport abstract class TuiDriverDirective implements AfterViewInit {\n public abstract type: string;\n\n private readonly destroyRef = inject(DestroyRef);\n private readonly drivers = coerceArray(\n inject(TuiDriver, {self: true, optional: true}) || [],\n );\n\n private readonly vehicles = coerceArray(\n inject(TuiVehicle, {self: true, optional: true}) || [],\n );\n\n public ngAfterViewInit(): void {\n const vehicle = this.vehicles.find(({type}) => type === this.type);\n\n merge(...this.drivers.filter(({type}) => type === this.type))\n .pipe(distinctUntilChanged(), takeUntilDestroyed(this.destroyRef))\n .subscribe((value) => {\n vehicle?.toggle(value);\n });\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;MAWsB,WAAW,CAAA;AAEhC;AAEK,MAAgB,mBAAoB,SAAQ,WAAW,CAAA;AAE5D;AAEK,MAAgB,eAAgB,SAAQ,WAAW,CAAA;AAExD;SAEe,kBAAkB,CAC9B,OAAwB,EACxB,IAAY,EACZ,QAAiB,EAAA;IAEjB,OAAO;QACH,OAAO;AACP,QAAA,IAAI,EAAE,CAAC,CAAC,IAAI,QAAQ,EAAE,EAAE,IAAI,QAAQ,EAAE,EAAE,OAAO,CAAC,EAAE,QAAQ,CAAC;AAC3D,QAAA,UAAU,EAAE,mBAAmB,CAAI,IAAI,CAAC;KAC3C;AACL;AAEM,SAAU,mBAAmB,CAC/B,IAAY,EAAA;IAEZ,OAAO,CAAC,SAAS,EAAE,QAAQ,KACvB,SAAS,EAAE,IAAI,GACX,CAAC,QAAQ,KAAK,QAAQ,KAAK,QAAQ,IAAI,QAAQ,CAAC,IAAI,KAAK,IAAI,CAChE,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAC,IAAI,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,EAAC,CAAC;AAC3D;AAEM,SAAU,sBAAsB,CAClC,IAAY,EACZ,QAAmC,EAAA;IAEnC,OAAO,kBAAkB,CAAC,mBAAmB,EAAE,IAAI,EAAE,QAAQ,CAAC;AAClE;AAEM,SAAU,kBAAkB,CAC9B,IAAY,EACZ,QAA+B,EAAA;IAE/B,OAAO,kBAAkB,CAAC,eAAe,EAAE,IAAI,EAAE,QAAQ,CAAC;AAC9D;AAEM,SAAU,qBAAqB,CACjC,QAAmC,EAAA;IAEnC,OAAO,UAAU,CAAC,mBAAmB,EAAE,QAAQ,EAAE,IAAI,CAAC;AAC1D;AAEM,SAAU,iBAAiB,CAAC,QAA+B,EAAA;IAC7D,OAAO,UAAU,CAAC,eAAe,EAAE,QAAQ,EAAE,IAAI,CAAC;AACtD;;MC/DsB,UAAU,CAAA;AAG/B;AAEK,SAAU,YAAY,CAAC,OAAyB,EAAA;IAClD,OAAO,UAAU,CAAC,UAAU,EAAE,OAAO,EAAE,IAAI,CAAC;AAChD;;ACKM,MAAgB,SAAU,SAAQ,UAAmB,CAAA;AAE1D;AAEK,SAAU,WAAW,CAAC,MAAuB,EAAA;IAC/C,OAAO,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC;AAC9C;MAGsB,kBAAkB,CAAA;AADxC,IAAA,WAAA,GAAA;AAIqB,QAAA,IAAA,CAAA,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;QAC/B,IAAA,CAAA,OAAO,GAAG,WAAW,CAClC,MAAM,CAAC,SAAS,EAAE,EAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAC,IAAI,EAAE,CACxD;QAEgB,IAAA,CAAA,QAAQ,GAAG,WAAW,CACnC,MAAM,CAAC,UAAU,EAAE,EAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAC,IAAI,EAAE,CACzD;AAWJ,IAAA;IATU,eAAe,GAAA;QAClB,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAC,IAAI,EAAC,KAAK,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC;QAElE,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,EAAC,IAAI,EAAC,KAAK,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC;aACvD,IAAI,CAAC,oBAAoB,EAAE,EAAE,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC;AAChE,aAAA,SAAS,CAAC,CAAC,KAAK,KAAI;AACjB,YAAA,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC;AAC1B,QAAA,CAAC,CAAC;IACV;+GApBkB,kBAAkB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;mGAAlB,kBAAkB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA;;4FAAlB,kBAAkB,EAAA,UAAA,EAAA,CAAA;kBADvC;;;ACvBD;;AAEG;;;;"}