@taiga-ui/kit 4.52.0-canary.763e67d → 4.52.0-canary.7c53ccc

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 (204) hide show
  1. package/components/avatar/avatar-labeled.component.d.ts +1 -1
  2. package/components/badged-content/badged-content.directive.d.ts +1 -2
  3. package/components/breadcrumbs/breadcrumbs.component.d.ts +2 -2
  4. package/components/calendar-range/calendar-range.component.d.ts +0 -1
  5. package/components/carousel/carousel-autoscroll.directive.d.ts +1 -2
  6. package/components/carousel/carousel-scroll.directive.d.ts +1 -1
  7. package/components/carousel/carousel.component.d.ts +5 -8
  8. package/components/carousel/carousel.directive.d.ts +2 -1
  9. package/components/copy/copy.component.d.ts +0 -1
  10. package/components/files/file/file.component.d.ts +4 -16
  11. package/components/files/files/files.component.d.ts +1 -3
  12. package/components/files/input-files/input-files.component.d.ts +2 -2
  13. package/components/files/input-files/input-files.content.d.ts +7 -8
  14. package/components/files/input-files/input-files.directive.d.ts +1 -2
  15. package/components/filter/filter.component.d.ts +6 -7
  16. package/components/fullscreen/fullscreen.component.d.ts +2 -2
  17. package/components/input-color/input-color.component.d.ts +5 -9
  18. package/components/input-date/input-date.component.d.ts +2 -2
  19. package/components/input-date/input-date.directive.d.ts +12 -11
  20. package/components/input-date-multi/input-date-multi.directive.d.ts +1 -1
  21. package/components/input-date-range/input-date-range.directive.d.ts +5 -3
  22. package/components/input-date-time/input-date-time.directive.d.ts +9 -9
  23. package/components/input-inline/input-inline.component.d.ts +3 -2
  24. package/components/input-month/input-month.component.d.ts +3 -5
  25. package/components/input-number/input-number.directive.d.ts +4 -6
  26. package/components/input-number/input-number.options.d.ts +2 -3
  27. package/components/input-number/step/input-number-step.component.d.ts +3 -3
  28. package/components/input-phone/input-phone.directive.d.ts +6 -8
  29. package/components/input-phone-international/input-phone-international.component.d.ts +8 -10
  30. package/components/input-phone-international/input-phone-international.options.d.ts +1 -0
  31. package/components/input-pin/input-pin.component.d.ts +3 -4
  32. package/components/input-range/input-range.component.d.ts +21 -51
  33. package/components/input-time/input-time.directive.d.ts +1 -1
  34. package/components/input-year/input-year.directive.d.ts +4 -6
  35. package/components/items-with-more/items-with-more.component.d.ts +6 -6
  36. package/components/items-with-more/items-with-more.directive.d.ts +6 -6
  37. package/components/multi-select/multi-select-native/multi-select-native.component.d.ts +5 -4
  38. package/components/pager/pager.component.d.ts +12 -12
  39. package/components/preview/pagination/preview-pagination.component.d.ts +4 -9
  40. package/components/preview/preview.component.d.ts +5 -5
  41. package/components/preview/zoom/preview-zoom.component.d.ts +8 -16
  42. package/components/progress/progress-circle/progress-circle.component.d.ts +7 -11
  43. package/components/push/push.component.d.ts +6 -7
  44. package/components/radio-list/radio-list.component.d.ts +9 -9
  45. package/components/range/range.component.d.ts +3 -4
  46. package/components/slider/helpers/slider-key-steps.directive.d.ts +6 -5
  47. package/components/slider/helpers/slider-readonly.directive.d.ts +2 -4
  48. package/components/slider/helpers/slider-thumb-label.component.d.ts +2 -4
  49. package/components/slider/slider.component.d.ts +4 -7
  50. package/components/stepper/step.component.d.ts +9 -2
  51. package/components/stepper/stepper.component.d.ts +1 -3
  52. package/components/tabs/tabs-horizontal.directive.d.ts +3 -4
  53. package/components/tabs/tabs-vertical.directive.d.ts +2 -2
  54. package/components/tabs/tabs-with-more.component.d.ts +12 -16
  55. package/components/tabs/tabs.directive.d.ts +5 -7
  56. package/components/textarea/textarea.component.d.ts +7 -8
  57. package/components/tiles/tile.component.d.ts +7 -10
  58. package/components/tiles/tile.service.d.ts +1 -1
  59. package/components/tiles/tiles.component.d.ts +4 -7
  60. package/components/tree/components/tree/tree.component.d.ts +7 -7
  61. package/components/tree/components/tree-item/tree-item.component.d.ts +1 -1
  62. package/components/tree/directives/tree-children.directive.d.ts +2 -2
  63. package/components/tree/directives/tree-controller.directive.d.ts +4 -5
  64. package/components/tree/directives/tree-item-controller.directive.d.ts +2 -2
  65. package/components/tree/directives/tree-node.directive.d.ts +5 -4
  66. package/directives/appearance-proxy/appearance-proxy.directive.d.ts +10 -0
  67. package/directives/appearance-proxy/index.d.ts +1 -0
  68. package/directives/highlight/highlight.directive.d.ts +6 -5
  69. package/directives/index.d.ts +1 -0
  70. package/directives/present/present.directive.d.ts +2 -3
  71. package/fesm2022/taiga-ui-kit-components-accordion.mjs +2 -2
  72. package/fesm2022/taiga-ui-kit-components-action-bar.mjs +2 -2
  73. package/fesm2022/taiga-ui-kit-components-avatar.mjs +9 -19
  74. package/fesm2022/taiga-ui-kit-components-avatar.mjs.map +1 -1
  75. package/fesm2022/taiga-ui-kit-components-badge-notification.mjs +2 -2
  76. package/fesm2022/taiga-ui-kit-components-badge.mjs +2 -2
  77. package/fesm2022/taiga-ui-kit-components-badged-content.mjs.map +1 -1
  78. package/fesm2022/taiga-ui-kit-components-block.mjs +2 -2
  79. package/fesm2022/taiga-ui-kit-components-block.mjs.map +1 -1
  80. package/fesm2022/taiga-ui-kit-components-breadcrumbs.mjs +6 -11
  81. package/fesm2022/taiga-ui-kit-components-breadcrumbs.mjs.map +1 -1
  82. package/fesm2022/taiga-ui-kit-components-button-loading.mjs.map +1 -1
  83. package/fesm2022/taiga-ui-kit-components-calendar-month.mjs +2 -2
  84. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs +2 -10
  85. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs.map +1 -1
  86. package/fesm2022/taiga-ui-kit-components-carousel.mjs +31 -52
  87. package/fesm2022/taiga-ui-kit-components-carousel.mjs.map +1 -1
  88. package/fesm2022/taiga-ui-kit-components-chip.mjs +2 -2
  89. package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
  90. package/fesm2022/taiga-ui-kit-components-comment.mjs +2 -2
  91. package/fesm2022/taiga-ui-kit-components-confirm.mjs +2 -2
  92. package/fesm2022/taiga-ui-kit-components-confirm.mjs.map +1 -1
  93. package/fesm2022/taiga-ui-kit-components-copy.mjs +3 -8
  94. package/fesm2022/taiga-ui-kit-components-copy.mjs.map +1 -1
  95. package/fesm2022/taiga-ui-kit-components-data-list-wrapper.mjs.map +1 -1
  96. package/fesm2022/taiga-ui-kit-components-drawer.mjs +3 -13
  97. package/fesm2022/taiga-ui-kit-components-drawer.mjs.map +1 -1
  98. package/fesm2022/taiga-ui-kit-components-files.mjs +72 -154
  99. package/fesm2022/taiga-ui-kit-components-files.mjs.map +1 -1
  100. package/fesm2022/taiga-ui-kit-components-filter.mjs +13 -12
  101. package/fesm2022/taiga-ui-kit-components-filter.mjs.map +1 -1
  102. package/fesm2022/taiga-ui-kit-components-fullscreen.mjs +5 -6
  103. package/fesm2022/taiga-ui-kit-components-fullscreen.mjs.map +1 -1
  104. package/fesm2022/taiga-ui-kit-components-input-chip.mjs +1 -10
  105. package/fesm2022/taiga-ui-kit-components-input-chip.mjs.map +1 -1
  106. package/fesm2022/taiga-ui-kit-components-input-color.mjs +5 -17
  107. package/fesm2022/taiga-ui-kit-components-input-color.mjs.map +1 -1
  108. package/fesm2022/taiga-ui-kit-components-input-date-range.mjs +9 -3
  109. package/fesm2022/taiga-ui-kit-components-input-date-range.mjs.map +1 -1
  110. package/fesm2022/taiga-ui-kit-components-input-date-time.mjs +10 -29
  111. package/fesm2022/taiga-ui-kit-components-input-date-time.mjs.map +1 -1
  112. package/fesm2022/taiga-ui-kit-components-input-date.mjs +14 -24
  113. package/fesm2022/taiga-ui-kit-components-input-date.mjs.map +1 -1
  114. package/fesm2022/taiga-ui-kit-components-input-inline.mjs +8 -10
  115. package/fesm2022/taiga-ui-kit-components-input-inline.mjs.map +1 -1
  116. package/fesm2022/taiga-ui-kit-components-input-month.mjs +8 -24
  117. package/fesm2022/taiga-ui-kit-components-input-month.mjs.map +1 -1
  118. package/fesm2022/taiga-ui-kit-components-input-number.mjs +21 -27
  119. package/fesm2022/taiga-ui-kit-components-input-number.mjs.map +1 -1
  120. package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs +28 -44
  121. package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs.map +1 -1
  122. package/fesm2022/taiga-ui-kit-components-input-phone.mjs +10 -25
  123. package/fesm2022/taiga-ui-kit-components-input-phone.mjs.map +1 -1
  124. package/fesm2022/taiga-ui-kit-components-input-pin.mjs +7 -14
  125. package/fesm2022/taiga-ui-kit-components-input-pin.mjs.map +1 -1
  126. package/fesm2022/taiga-ui-kit-components-input-range.mjs +34 -59
  127. package/fesm2022/taiga-ui-kit-components-input-range.mjs.map +1 -1
  128. package/fesm2022/taiga-ui-kit-components-input-year.mjs +5 -19
  129. package/fesm2022/taiga-ui-kit-components-input-year.mjs.map +1 -1
  130. package/fesm2022/taiga-ui-kit-components-items-with-more.mjs +39 -59
  131. package/fesm2022/taiga-ui-kit-components-items-with-more.mjs.map +1 -1
  132. package/fesm2022/taiga-ui-kit-components-message.mjs +2 -2
  133. package/fesm2022/taiga-ui-kit-components-message.mjs.map +1 -1
  134. package/fesm2022/taiga-ui-kit-components-multi-select.mjs +14 -19
  135. package/fesm2022/taiga-ui-kit-components-multi-select.mjs.map +1 -1
  136. package/fesm2022/taiga-ui-kit-components-notification-middle.mjs +2 -2
  137. package/fesm2022/taiga-ui-kit-components-pager.mjs +27 -39
  138. package/fesm2022/taiga-ui-kit-components-pager.mjs.map +1 -1
  139. package/fesm2022/taiga-ui-kit-components-pagination.mjs +10 -14
  140. package/fesm2022/taiga-ui-kit-components-pagination.mjs.map +1 -1
  141. package/fesm2022/taiga-ui-kit-components-pin.mjs +2 -2
  142. package/fesm2022/taiga-ui-kit-components-preview.mjs +39 -119
  143. package/fesm2022/taiga-ui-kit-components-preview.mjs.map +1 -1
  144. package/fesm2022/taiga-ui-kit-components-progress.mjs +17 -32
  145. package/fesm2022/taiga-ui-kit-components-progress.mjs.map +1 -1
  146. package/fesm2022/taiga-ui-kit-components-pulse.mjs +1 -3
  147. package/fesm2022/taiga-ui-kit-components-pulse.mjs.map +1 -1
  148. package/fesm2022/taiga-ui-kit-components-push.mjs +9 -21
  149. package/fesm2022/taiga-ui-kit-components-push.mjs.map +1 -1
  150. package/fesm2022/taiga-ui-kit-components-radio-list.mjs +19 -31
  151. package/fesm2022/taiga-ui-kit-components-radio-list.mjs.map +1 -1
  152. package/fesm2022/taiga-ui-kit-components-range.mjs +14 -24
  153. package/fesm2022/taiga-ui-kit-components-range.mjs.map +1 -1
  154. package/fesm2022/taiga-ui-kit-components-segmented.mjs +2 -2
  155. package/fesm2022/taiga-ui-kit-components-slider.mjs +37 -55
  156. package/fesm2022/taiga-ui-kit-components-slider.mjs.map +1 -1
  157. package/fesm2022/taiga-ui-kit-components-stepper.mjs +32 -25
  158. package/fesm2022/taiga-ui-kit-components-stepper.mjs.map +1 -1
  159. package/fesm2022/taiga-ui-kit-components-switch.mjs +2 -2
  160. package/fesm2022/taiga-ui-kit-components-switch.mjs.map +1 -1
  161. package/fesm2022/taiga-ui-kit-components-tabs.mjs +56 -111
  162. package/fesm2022/taiga-ui-kit-components-tabs.mjs.map +1 -1
  163. package/fesm2022/taiga-ui-kit-components-textarea.mjs +13 -25
  164. package/fesm2022/taiga-ui-kit-components-textarea.mjs.map +1 -1
  165. package/fesm2022/taiga-ui-kit-components-tiles.mjs +26 -58
  166. package/fesm2022/taiga-ui-kit-components-tiles.mjs.map +1 -1
  167. package/fesm2022/taiga-ui-kit-components-toast.mjs +2 -2
  168. package/fesm2022/taiga-ui-kit-components-toast.mjs.map +1 -1
  169. package/fesm2022/taiga-ui-kit-components-tree.mjs +41 -72
  170. package/fesm2022/taiga-ui-kit-components-tree.mjs.map +1 -1
  171. package/fesm2022/taiga-ui-kit-directives-appearance-proxy.mjs +27 -0
  172. package/fesm2022/taiga-ui-kit-directives-appearance-proxy.mjs.map +1 -0
  173. package/fesm2022/taiga-ui-kit-directives-button-group.mjs +2 -2
  174. package/fesm2022/taiga-ui-kit-directives-button-group.mjs.map +1 -1
  175. package/fesm2022/taiga-ui-kit-directives-chevron.mjs +2 -2
  176. package/fesm2022/taiga-ui-kit-directives-chevron.mjs.map +1 -1
  177. package/fesm2022/taiga-ui-kit-directives-connected.mjs +2 -2
  178. package/fesm2022/taiga-ui-kit-directives-connected.mjs.map +1 -1
  179. package/fesm2022/taiga-ui-kit-directives-fade.mjs.map +1 -1
  180. package/fesm2022/taiga-ui-kit-directives-highlight.mjs +17 -13
  181. package/fesm2022/taiga-ui-kit-directives-highlight.mjs.map +1 -1
  182. package/fesm2022/taiga-ui-kit-directives-present.mjs +7 -10
  183. package/fesm2022/taiga-ui-kit-directives-present.mjs.map +1 -1
  184. package/fesm2022/taiga-ui-kit-directives-unmask-handler.mjs.map +1 -1
  185. package/fesm2022/taiga-ui-kit-directives.mjs +1 -0
  186. package/fesm2022/taiga-ui-kit-directives.mjs.map +1 -1
  187. package/fesm2022/taiga-ui-kit-pipes-flag.mjs.map +1 -1
  188. package/fesm2022/taiga-ui-kit-tokens.mjs +2 -26
  189. package/fesm2022/taiga-ui-kit-tokens.mjs.map +1 -1
  190. package/fesm2022/taiga-ui-kit-utils.mjs.map +1 -1
  191. package/package.json +26 -22
  192. package/pipes/flag/flag.pipe.d.ts +1 -2
  193. package/styles/components/avatar.less +14 -14
  194. package/styles/components/badge.less +3 -3
  195. package/styles/components/block.less +4 -4
  196. package/styles/components/chip.less +3 -3
  197. package/styles/components/comment.less +1 -1
  198. package/styles/components/message.less +1 -1
  199. package/styles/components/pin.less +3 -3
  200. package/styles/components/switch.less +1 -0
  201. package/styles/components/toast.less +1 -1
  202. package/tokens/index.d.ts +0 -1
  203. package/utils/maskito.binding.d.ts +1 -1
  204. package/tokens/calendar-date-stream.d.ts +0 -10
@@ -1,36 +1,32 @@
1
- import { __decorate } from 'tslib';
2
1
  import * as i0 from '@angular/core';
3
- import { inject, LOCALE_ID, signal, computed, input, output, ChangeDetectionStrategy, Component, contentChildren, TemplateRef, model, ViewEncapsulation, Directive, forwardRef, ContentChild, Pipe } from '@angular/core';
4
- import { DomSanitizer } from '@angular/platform-browser';
2
+ import { inject, LOCALE_ID, computed, input, output, ChangeDetectionStrategy, Component, contentChildren, TemplateRef, model, ViewEncapsulation, Directive, forwardRef, contentChild, Pipe } from '@angular/core';
5
3
  import { WA_WINDOW } from '@ng-web-apis/common';
6
- import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
7
4
  import { TuiButton } from '@taiga-ui/core/components/button';
8
5
  import { TuiIcon } from '@taiga-ui/core/components/icon';
9
6
  import { TuiLoader } from '@taiga-ui/core/components/loader';
10
7
  import * as i1 from '@taiga-ui/core/directives/appearance';
11
8
  import { tuiAppearanceOptionsProvider, TuiAppearance, tuiAppearanceMode, TuiWithAppearance } from '@taiga-ui/core/directives/appearance';
12
9
  import { TuiHintOverflow } from '@taiga-ui/core/portals/hint';
13
- import { TUI_COMMON_ICONS } from '@taiga-ui/core/tokens';
10
+ import { TUI_COMMON_ICONS, TUI_BREAKPOINT } from '@taiga-ui/core/tokens';
14
11
  import { TUI_DIGITAL_INFORMATION_UNITS, TUI_FILE_TEXTS, TUI_HIDE_TEXT, TUI_SHOW_ALL_TEXT, TUI_INPUT_FILE_TEXTS } from '@taiga-ui/kit/tokens';
15
12
  import { PolymorpheusOutlet, injectContext, PolymorpheusComponent } from '@taiga-ui/polymorpheus';
16
13
  import { tuiCreateOptions, tuiProvide } from '@taiga-ui/cdk/utils/di';
17
14
  import { coerceArray } from '@angular/cdk/coercion';
18
15
  import { tuiRound } from '@taiga-ui/cdk/utils/math';
19
16
  import { TuiItem } from '@taiga-ui/cdk/directives/item';
20
- import { NgTemplateOutlet, AsyncPipe } from '@angular/common';
17
+ import { NgTemplateOutlet } from '@angular/common';
21
18
  import { TuiExpand } from '@taiga-ui/core/components/expand';
22
19
  import * as i1$1 from '@taiga-ui/core/directives/group';
23
20
  import { TuiGroup, tuiGroupOptionsProvider } from '@taiga-ui/core/directives/group';
24
- import { toObservable, outputFromObservable } from '@angular/core/rxjs-interop';
25
21
  import { TuiLink } from '@taiga-ui/core/components/link';
26
- import { TuiBreakpointService } from '@taiga-ui/core/services';
27
- import { of, map, combineLatest, timer, switchMap, filter } from 'rxjs';
22
+ import { outputFromObservable, toObservable } from '@angular/core/rxjs-interop';
28
23
  import { TuiControl, tuiAsControl } from '@taiga-ui/cdk/classes';
29
24
  import { EMPTY_ARRAY, CHAR_NO_BREAK_SPACE } from '@taiga-ui/cdk/constants';
30
25
  import * as i1$2 from '@taiga-ui/cdk/directives/native-validator';
31
26
  import { TuiNativeValidator } from '@taiga-ui/cdk/directives/native-validator';
32
27
  import { tuiZonefreeScheduler, tuiControlValue } from '@taiga-ui/cdk/observables';
33
28
  import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
29
+ import { timer, switchMap, map, filter, combineLatest } from 'rxjs';
34
30
  import { Validators, NG_VALIDATORS, FormControl } from '@angular/forms';
35
31
  import { TuiValidator } from '@taiga-ui/cdk/directives/validator';
36
32
 
@@ -108,16 +104,28 @@ const [TUI_FILE_OPTIONS, tuiFileOptionsProvider] = tuiCreateOptions(TUI_FILE_DEF
108
104
 
109
105
  class TuiFile {
110
106
  constructor() {
111
- this.sanitizer = inject(DomSanitizer);
112
107
  this.options = inject(TUI_FILE_OPTIONS);
113
108
  this.locale = inject(LOCALE_ID);
114
109
  this.units = inject(TUI_DIGITAL_INFORMATION_UNITS);
115
110
  this.win = inject(WA_WINDOW);
116
- this.removeObserved = signal(false);
117
111
  this.icons = inject(TUI_COMMON_ICONS);
118
112
  this.fileTexts = inject(TUI_FILE_TEXTS);
119
- this.content = computed(() => this.calculateContent(this.state(), this.file(), this.fileTexts()));
113
+ this.content = computed(() => this.state() === 'error' && !this.file().content
114
+ ? this.fileTexts().loadingError
115
+ : this.file().content || '');
120
116
  this.fileSize = computed(() => this.options.formatSize(this.units(), this.file().size, this.locale));
117
+ this.preview = computed(() => this.size() === 'l' ? this.createPreview(this.file()) : '');
118
+ this.name = computed(() => {
119
+ const dot = this.file().name.lastIndexOf('.');
120
+ // a dot at position 0 means a “hidden” file, not an extension
121
+ return dot > 0 ? this.file().name.slice(0, dot) : this.file().name;
122
+ });
123
+ this.type = computed(() => {
124
+ const dot = this.file().name.lastIndexOf('.');
125
+ // only return an extension when there is one
126
+ return dot > 0 ? this.file().name.slice(dot) : '';
127
+ });
128
+ this.icon = computed((state = this.state()) => state === 'loading' ? '' : this.options.icons[state]);
121
129
  this.file = input({ name: '' });
122
130
  this.state = input('normal');
123
131
  this.size = input('m');
@@ -125,170 +133,85 @@ class TuiFile {
125
133
  this.showSize = input(true);
126
134
  this.leftContent = input();
127
135
  this.remove = output();
128
- this.remove.subscribe(() => this.removeObserved.set(true));
129
- }
130
- get preview() {
131
- return this.isBig ? this.createPreview(this.file()) : '';
132
- }
133
- get isBig() {
134
- return this.size() === 'l';
135
- }
136
- get isLoading() {
137
- return this.state() === 'loading';
138
- }
139
- get isError() {
140
- return this.state() === 'error';
141
- }
142
- get isDeleted() {
143
- return this.state() === 'deleted';
144
136
  }
145
137
  get allowDelete() {
146
- return this.showDelete() && this.removeObserved();
147
- }
148
- get icon() {
149
- return this.state() === 'loading'
150
- ? ''
151
- : this.options.icons[this.state()];
152
- }
153
- get name() {
154
- return this.getName(this.file());
155
- }
156
- get type() {
157
- return this.getType(this.file());
158
- }
159
- calculateContent(state, file, fileTexts) {
160
- return state === 'error' && !file.content
161
- ? fileTexts.loadingError
162
- : file.content || '';
138
+ return this.showDelete() && !!this.remove['listeners']?.length;
163
139
  }
164
140
  createPreview(file) {
165
141
  if (file.src) {
166
142
  return file.src;
167
143
  }
168
- if (this.win.File &&
144
+ return this.win.File &&
169
145
  file instanceof this.win.File &&
170
- file.type?.startsWith('image/')) {
171
- return this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file));
172
- }
173
- return '';
174
- }
175
- getName(file) {
176
- const dot = file.name.lastIndexOf('.');
177
- // a dot at position 0 means a “hidden” file, not an extension
178
- return dot > 0 ? file.name.slice(0, dot) : file.name;
179
- }
180
- getType(file) {
181
- const dot = file.name.lastIndexOf('.');
182
- // only return an extension when there is one
183
- return dot > 0 ? file.name.slice(dot) : '';
146
+ file.type?.startsWith('image/')
147
+ ? URL.createObjectURL(file)
148
+ : '';
184
149
  }
185
150
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiFile, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
186
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiFile, isStandalone: true, selector: "tui-file,a[tuiFile],button[tuiFile]", inputs: { file: { classPropertyName: "file", publicName: "file", isSignal: true, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, showDelete: { classPropertyName: "showDelete", publicName: "showDelete", isSignal: true, isRequired: false, transformFunction: null }, showSize: { classPropertyName: "showSize", publicName: "showSize", isSignal: true, isRequired: false, transformFunction: null }, leftContent: { classPropertyName: "leftContent", publicName: "leftContent", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { remove: "remove" }, host: { properties: { "attr.data-delete": "showDelete()" } }, providers: [tuiAppearanceOptionsProvider(TUI_FILE_OPTIONS)], hostDirectives: [{ directive: i1.TuiAppearance }], ngImport: i0, template: "<div\n class=\"t-preview\"\n [class.t-preview_big]=\"isBig\"\n>\n <ng-container *polymorpheusOutlet=\"leftContent() || defaultLeftContent as text\">\n {{ text }}\n </ng-container>\n</div>\n<div class=\"t-wrapper\">\n <div class=\"t-text\">\n <div\n tuiHintOverflow\n class=\"t-name\"\n >\n {{ name }}\n </div>\n <div class=\"t-type\">{{ type }}</div>\n @if (showSize() && fileSize()) {\n <div class=\"t-size\">\n {{ fileSize() }}\n </div>\n }\n </div>\n @if (content(); as text) {\n <div class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"text\">\n {{ text }}\n </ng-container>\n </div>\n }\n <ng-content />\n</div>\n@if (allowDelete) {\n @if (fileTexts(); as texts) {\n <button\n appearance=\"icon\"\n size=\"xs\"\n tuiIconButton\n type=\"button\"\n class=\"t-remove\"\n [iconStart]=\"icons.close\"\n (click.prevent)=\"remove.emit()\"\n (mousedown.prevent.zoneless)=\"(0)\"\n >\n {{ texts.remove }}\n </button>\n }\n}\n\n<ng-template #defaultLeftContent>\n @if (preview) {\n <img\n alt=\"file preview\"\n class=\"t-image\"\n [src]=\"preview\"\n />\n } @else {\n @if (isLoading) {\n <tui-loader\n class=\"t-loader\"\n [inheritColor]=\"isBig\"\n />\n } @else {\n <tui-icon\n *polymorpheusOutlet=\"icon as src; context: {$implicit: size()}\"\n class=\"t-icon\"\n [class.t-icon_blank]=\"isBig || isDeleted\"\n [class.t-icon_error]=\"isError\"\n [icon]=\"src.toString()\"\n />\n }\n }\n</ng-template>\n", styles: [":host{position:relative;display:flex;align-items:center;font:var(--tui-font-text-m);padding:.625rem;padding-inline-end:2.25rem;text-decoration:none;border-radius:var(--tui-radius-m)}:host:hover .t-remove,:host[data-delete=always] .t-remove{opacity:1}.t-preview{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;inline-size:1.5rem;block-size:1.5rem;margin-inline-end:.75rem;border-radius:var(--tui-radius-m);overflow:hidden;color:var(--tui-text-tertiary)}.t-preview_big{inline-size:4rem;block-size:4rem;margin-inline-end:1rem}.t-preview_big:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";background:var(--tui-background-neutral-1)}.t-image{max-inline-size:100%;max-block-size:100%}.t-loader{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}.t-icon{position:absolute;inset:0;color:var(--tui-status-positive);margin:auto}.t-icon_blank{color:var(--tui-text-tertiary)}.t-icon_error{color:var(--tui-text-negative)}.t-remove{transition-property:opacity;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:absolute;top:.625rem;right:.625rem}@supports (inset-inline-end: 0){.t-remove{right:unset;inset-inline-end:.625rem}}.t-remove:focus{opacity:1}.t-remove:focus-visible{box-shadow:inset 0 0 0 2px var(--tui-border-focus)}@media (hover: hover) and (pointer: fine){.t-remove{opacity:0}}.t-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;overflow:hidden;color:var(--tui-text-primary)}.t-text{display:flex;inline-size:100%}.t-size{flex-shrink:0;opacity:var(--tui-disabled-opacity);margin-inline-start:.5rem}.t-type{flex-shrink:0}.t-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-content{font:var(--tui-font-text-s);color:var(--tui-text-negative)}\n"], dependencies: [{ kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: TuiHintOverflow, selector: "[tuiHintOverflow]", inputs: ["tuiHintOverflow"] }, { kind: "component", type: TuiIcon, selector: "tui-icon:not([tuiBadge])", inputs: ["background"] }, { kind: "component", type: TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "loading"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
151
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiFile, isStandalone: true, selector: "tui-file,a[tuiFile],button[tuiFile]", inputs: { file: { classPropertyName: "file", publicName: "file", isSignal: true, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, showDelete: { classPropertyName: "showDelete", publicName: "showDelete", isSignal: true, isRequired: false, transformFunction: null }, showSize: { classPropertyName: "showSize", publicName: "showSize", isSignal: true, isRequired: false, transformFunction: null }, leftContent: { classPropertyName: "leftContent", publicName: "leftContent", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { remove: "remove" }, host: { properties: { "attr.data-delete": "showDelete()" } }, providers: [tuiAppearanceOptionsProvider(TUI_FILE_OPTIONS)], hostDirectives: [{ directive: i1.TuiAppearance }], ngImport: i0, template: "<div\n class=\"t-preview\"\n [class.t-preview_big]=\"size() === 'l'\"\n>\n <ng-container *polymorpheusOutlet=\"leftContent() || defaultLeftContent as text\">\n {{ text }}\n </ng-container>\n</div>\n<div class=\"t-wrapper\">\n <div class=\"t-text\">\n <div\n tuiHintOverflow\n class=\"t-name\"\n >\n {{ name() }}\n </div>\n <div class=\"t-type\">{{ type() }}</div>\n @if (showSize() && fileSize()) {\n <div class=\"t-size\">\n {{ fileSize() }}\n </div>\n }\n </div>\n @if (content(); as text) {\n <div class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"text\">\n {{ text }}\n </ng-container>\n </div>\n }\n <ng-content />\n</div>\n@if (allowDelete) {\n @if (fileTexts(); as texts) {\n <button\n appearance=\"icon\"\n size=\"xs\"\n tuiIconButton\n type=\"button\"\n class=\"t-remove\"\n [iconStart]=\"icons.close\"\n (click.prevent)=\"remove.emit()\"\n (mousedown.prevent.zoneless)=\"(0)\"\n >\n {{ texts.remove }}\n </button>\n }\n}\n\n<ng-template #defaultLeftContent>\n @if (preview()) {\n <img\n alt=\"file preview\"\n class=\"t-image\"\n [src]=\"preview()\"\n />\n } @else {\n @if (state() === 'loading') {\n <tui-loader\n class=\"t-loader\"\n [inheritColor]=\"size() === 'l'\"\n />\n } @else {\n <tui-icon\n *polymorpheusOutlet=\"icon() as src; context: {$implicit: size()}\"\n class=\"t-icon\"\n [class.t-icon_blank]=\"size() === 'l' || state() === 'deleted'\"\n [class.t-icon_error]=\"state() === 'error'\"\n [icon]=\"src.toString()\"\n />\n }\n }\n</ng-template>\n", styles: [":host{position:relative;display:flex;align-items:center;font:var(--tui-font-body-m);padding:.625rem;padding-inline-end:2.25rem;text-decoration:none;border-radius:var(--tui-radius-m)}:host:hover .t-remove,:host[data-delete=always] .t-remove{opacity:1}.t-preview{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;inline-size:1.5rem;block-size:1.5rem;margin-inline-end:.75rem;border-radius:var(--tui-radius-m);overflow:hidden;color:var(--tui-text-tertiary)}.t-preview_big{inline-size:4rem;block-size:4rem;margin-inline-end:1rem}.t-preview_big:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";background:var(--tui-background-neutral-1)}.t-image{max-inline-size:100%;max-block-size:100%}.t-loader{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}.t-icon{position:absolute;inset:0;color:var(--tui-status-positive);margin:auto}.t-icon_blank{color:var(--tui-text-tertiary)}.t-icon_error{color:var(--tui-text-negative)}.t-remove{transition-property:opacity;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:absolute;inset-block-start:.625rem;inset-inline-end:.625rem}.t-remove:focus{opacity:1}.t-remove:focus-visible{box-shadow:inset 0 0 0 2px var(--tui-border-focus)}@media (hover: hover) and (pointer: fine){.t-remove{opacity:0}}.t-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;overflow:hidden;color:var(--tui-text-primary)}.t-text{display:flex;inline-size:100%}.t-size{flex-shrink:0;opacity:var(--tui-disabled-opacity);margin-inline-start:.5rem}.t-type{flex-shrink:0}.t-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-content{font:var(--tui-font-body-s);color:var(--tui-text-negative)}\n"], dependencies: [{ kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: TuiHintOverflow, selector: "[tuiHintOverflow]", inputs: ["tuiHintOverflow"] }, { kind: "component", type: TuiIcon, selector: "tui-icon:not([tuiBadge])", inputs: ["background"] }, { kind: "component", type: TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "loading"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
187
152
  }
188
- __decorate([
189
- tuiPure
190
- ], TuiFile.prototype, "calculateContent", null);
191
- __decorate([
192
- tuiPure
193
- ], TuiFile.prototype, "createPreview", null);
194
- __decorate([
195
- tuiPure
196
- ], TuiFile.prototype, "getName", null);
197
- __decorate([
198
- tuiPure
199
- ], TuiFile.prototype, "getType", null);
200
153
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiFile, decorators: [{
201
154
  type: Component,
202
- args: [{ selector: 'tui-file,a[tuiFile],button[tuiFile]', imports: [PolymorpheusOutlet, TuiButton, TuiHintOverflow, TuiIcon, TuiLoader], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAppearanceOptionsProvider(TUI_FILE_OPTIONS)], hostDirectives: [TuiAppearance], host: {
203
- '[attr.data-delete]': 'showDelete()',
204
- }, template: "<div\n class=\"t-preview\"\n [class.t-preview_big]=\"isBig\"\n>\n <ng-container *polymorpheusOutlet=\"leftContent() || defaultLeftContent as text\">\n {{ text }}\n </ng-container>\n</div>\n<div class=\"t-wrapper\">\n <div class=\"t-text\">\n <div\n tuiHintOverflow\n class=\"t-name\"\n >\n {{ name }}\n </div>\n <div class=\"t-type\">{{ type }}</div>\n @if (showSize() && fileSize()) {\n <div class=\"t-size\">\n {{ fileSize() }}\n </div>\n }\n </div>\n @if (content(); as text) {\n <div class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"text\">\n {{ text }}\n </ng-container>\n </div>\n }\n <ng-content />\n</div>\n@if (allowDelete) {\n @if (fileTexts(); as texts) {\n <button\n appearance=\"icon\"\n size=\"xs\"\n tuiIconButton\n type=\"button\"\n class=\"t-remove\"\n [iconStart]=\"icons.close\"\n (click.prevent)=\"remove.emit()\"\n (mousedown.prevent.zoneless)=\"(0)\"\n >\n {{ texts.remove }}\n </button>\n }\n}\n\n<ng-template #defaultLeftContent>\n @if (preview) {\n <img\n alt=\"file preview\"\n class=\"t-image\"\n [src]=\"preview\"\n />\n } @else {\n @if (isLoading) {\n <tui-loader\n class=\"t-loader\"\n [inheritColor]=\"isBig\"\n />\n } @else {\n <tui-icon\n *polymorpheusOutlet=\"icon as src; context: {$implicit: size()}\"\n class=\"t-icon\"\n [class.t-icon_blank]=\"isBig || isDeleted\"\n [class.t-icon_error]=\"isError\"\n [icon]=\"src.toString()\"\n />\n }\n }\n</ng-template>\n", styles: [":host{position:relative;display:flex;align-items:center;font:var(--tui-font-text-m);padding:.625rem;padding-inline-end:2.25rem;text-decoration:none;border-radius:var(--tui-radius-m)}:host:hover .t-remove,:host[data-delete=always] .t-remove{opacity:1}.t-preview{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;inline-size:1.5rem;block-size:1.5rem;margin-inline-end:.75rem;border-radius:var(--tui-radius-m);overflow:hidden;color:var(--tui-text-tertiary)}.t-preview_big{inline-size:4rem;block-size:4rem;margin-inline-end:1rem}.t-preview_big:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";background:var(--tui-background-neutral-1)}.t-image{max-inline-size:100%;max-block-size:100%}.t-loader{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}.t-icon{position:absolute;inset:0;color:var(--tui-status-positive);margin:auto}.t-icon_blank{color:var(--tui-text-tertiary)}.t-icon_error{color:var(--tui-text-negative)}.t-remove{transition-property:opacity;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:absolute;top:.625rem;right:.625rem}@supports (inset-inline-end: 0){.t-remove{right:unset;inset-inline-end:.625rem}}.t-remove:focus{opacity:1}.t-remove:focus-visible{box-shadow:inset 0 0 0 2px var(--tui-border-focus)}@media (hover: hover) and (pointer: fine){.t-remove{opacity:0}}.t-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;overflow:hidden;color:var(--tui-text-primary)}.t-text{display:flex;inline-size:100%}.t-size{flex-shrink:0;opacity:var(--tui-disabled-opacity);margin-inline-start:.5rem}.t-type{flex-shrink:0}.t-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-content{font:var(--tui-font-text-s);color:var(--tui-text-negative)}\n"] }]
205
- }], ctorParameters: () => [], propDecorators: { calculateContent: [], createPreview: [], getName: [], getType: [] } });
155
+ args: [{ selector: 'tui-file,a[tuiFile],button[tuiFile]', imports: [PolymorpheusOutlet, TuiButton, TuiHintOverflow, TuiIcon, TuiLoader], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAppearanceOptionsProvider(TUI_FILE_OPTIONS)], hostDirectives: [TuiAppearance], host: { '[attr.data-delete]': 'showDelete()' }, template: "<div\n class=\"t-preview\"\n [class.t-preview_big]=\"size() === 'l'\"\n>\n <ng-container *polymorpheusOutlet=\"leftContent() || defaultLeftContent as text\">\n {{ text }}\n </ng-container>\n</div>\n<div class=\"t-wrapper\">\n <div class=\"t-text\">\n <div\n tuiHintOverflow\n class=\"t-name\"\n >\n {{ name() }}\n </div>\n <div class=\"t-type\">{{ type() }}</div>\n @if (showSize() && fileSize()) {\n <div class=\"t-size\">\n {{ fileSize() }}\n </div>\n }\n </div>\n @if (content(); as text) {\n <div class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"text\">\n {{ text }}\n </ng-container>\n </div>\n }\n <ng-content />\n</div>\n@if (allowDelete) {\n @if (fileTexts(); as texts) {\n <button\n appearance=\"icon\"\n size=\"xs\"\n tuiIconButton\n type=\"button\"\n class=\"t-remove\"\n [iconStart]=\"icons.close\"\n (click.prevent)=\"remove.emit()\"\n (mousedown.prevent.zoneless)=\"(0)\"\n >\n {{ texts.remove }}\n </button>\n }\n}\n\n<ng-template #defaultLeftContent>\n @if (preview()) {\n <img\n alt=\"file preview\"\n class=\"t-image\"\n [src]=\"preview()\"\n />\n } @else {\n @if (state() === 'loading') {\n <tui-loader\n class=\"t-loader\"\n [inheritColor]=\"size() === 'l'\"\n />\n } @else {\n <tui-icon\n *polymorpheusOutlet=\"icon() as src; context: {$implicit: size()}\"\n class=\"t-icon\"\n [class.t-icon_blank]=\"size() === 'l' || state() === 'deleted'\"\n [class.t-icon_error]=\"state() === 'error'\"\n [icon]=\"src.toString()\"\n />\n }\n }\n</ng-template>\n", styles: [":host{position:relative;display:flex;align-items:center;font:var(--tui-font-body-m);padding:.625rem;padding-inline-end:2.25rem;text-decoration:none;border-radius:var(--tui-radius-m)}:host:hover .t-remove,:host[data-delete=always] .t-remove{opacity:1}.t-preview{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;inline-size:1.5rem;block-size:1.5rem;margin-inline-end:.75rem;border-radius:var(--tui-radius-m);overflow:hidden;color:var(--tui-text-tertiary)}.t-preview_big{inline-size:4rem;block-size:4rem;margin-inline-end:1rem}.t-preview_big:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";background:var(--tui-background-neutral-1)}.t-image{max-inline-size:100%;max-block-size:100%}.t-loader{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}.t-icon{position:absolute;inset:0;color:var(--tui-status-positive);margin:auto}.t-icon_blank{color:var(--tui-text-tertiary)}.t-icon_error{color:var(--tui-text-negative)}.t-remove{transition-property:opacity;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:absolute;inset-block-start:.625rem;inset-inline-end:.625rem}.t-remove:focus{opacity:1}.t-remove:focus-visible{box-shadow:inset 0 0 0 2px var(--tui-border-focus)}@media (hover: hover) and (pointer: fine){.t-remove{opacity:0}}.t-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;overflow:hidden;color:var(--tui-text-primary)}.t-text{display:flex;inline-size:100%}.t-size{flex-shrink:0;opacity:var(--tui-disabled-opacity);margin-inline-start:.5rem}.t-type{flex-shrink:0}.t-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-content{font:var(--tui-font-body-s);color:var(--tui-text-negative)}\n"] }]
156
+ }] });
206
157
 
207
158
  class TuiFilesComponent {
208
159
  constructor() {
209
- this.items = contentChildren(TuiItem, {
210
- read: (TemplateRef),
211
- });
212
160
  this.hideText = inject(TUI_HIDE_TEXT);
213
161
  this.showAllText = inject(TUI_SHOW_ALL_TEXT);
162
+ this.items = contentChildren(TuiItem, { read: TemplateRef });
214
163
  this.max = input(0);
215
164
  this.expanded = model(false);
216
- this.hasExtraItems = computed(() => !!this.max() && this.items().length > this.max());
217
- }
218
- toggle() {
219
- this.expanded.set(!this.expanded());
220
165
  }
221
166
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiFilesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
222
167
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiFilesComponent, isStandalone: true, selector: "tui-files", inputs: { max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, expanded: { classPropertyName: "expanded", publicName: "expanded", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { expanded: "expandedChange" }, providers: [
223
168
  tuiGroupOptionsProvider({ size: 'm', collapsed: true, orientation: 'vertical' }),
224
- ], queries: [{ propertyName: "items", predicate: TuiItem, read: TemplateRef, isSignal: true }], hostDirectives: [{ directive: i1$1.TuiGroup }], ngImport: i0, template: "<ng-content />\n@for (item of items(); track item) {\n @if (!max() || $index < max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n}\n@if (hasExtraItems()) {\n <tui-expand [expanded]=\"expanded()\">\n <div\n tuiGroup\n class=\"t-extra-items\"\n >\n @for (item of items(); track item) {\n @if (max() && $index >= max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n }\n </div>\n </tui-expand>\n}\n@if (hasExtraItems()) {\n <div\n class=\"t-bottom\"\n [class.t-bottom_collapsed]=\"!expanded()\"\n >\n <button\n appearance=\"outline\"\n size=\"m\"\n tuiButton\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ expanded() ? hideText() : showAllText() }}\n </button>\n </div>\n}\n", styles: ["tui-files{inline-size:100%;overflow:hidden;border-radius:var(--tui-radius-m)}tui-files:empty:empty{display:none}tui-files .t-files{position:relative;display:block;inline-size:100%;block-size:100%;border-radius:var(--tui-radius-m);overflow:hidden}tui-files .t-button{inline-size:100%;border-radius:inherit}tui-files .t-bottom{z-index:3;inline-size:100%;background:var(--tui-background-base);mask:none!important}tui-files .t-bottom_collapsed{box-shadow:var(--tui-shadow-popup);margin-block-start:-1.5rem}tui-files .t-extra-items{inline-size:100%}tui-files .t-extra-items>*{border-radius:0!important}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "component", type: TuiExpand, selector: "tui-expand", inputs: ["expanded"] }, { kind: "directive", type: TuiGroup, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "collapsed", "rounded", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
169
+ ], queries: [{ propertyName: "items", predicate: TuiItem, read: TemplateRef, isSignal: true }], hostDirectives: [{ directive: i1$1.TuiGroup }], ngImport: i0, template: "<ng-content />\n@for (item of items(); track $index) {\n @if (!max() || $index < max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n}\n@if (max() && items().length > max()) {\n <tui-expand [expanded]=\"expanded()\">\n <div\n tuiGroup\n class=\"t-extra-items\"\n >\n @for (item of items(); track $index) {\n @if (max() && $index >= max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n }\n </div>\n </tui-expand>\n <div\n class=\"t-bottom\"\n [class.t-bottom_collapsed]=\"!expanded()\"\n >\n <button\n appearance=\"outline\"\n size=\"m\"\n tuiButton\n type=\"button\"\n class=\"t-button\"\n (click)=\"expanded.set(!expanded())\"\n >\n {{ expanded() ? hideText() : showAllText() }}\n </button>\n </div>\n}\n", styles: ["tui-files{inline-size:100%;overflow:hidden;border-radius:var(--tui-radius-m)}tui-files:empty:empty{display:none}tui-files .t-files{position:relative;display:block;inline-size:100%;block-size:100%;border-radius:var(--tui-radius-m);overflow:hidden}tui-files .t-button{inline-size:100%;border-radius:inherit}tui-files .t-bottom{z-index:3;inline-size:100%;background:var(--tui-background-base);mask:none!important}tui-files .t-bottom_collapsed{box-shadow:var(--tui-shadow-popup);margin-block-start:-1.5rem}tui-files .t-extra-items{inline-size:100%}tui-files .t-extra-items>*{border-radius:0!important}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "component", type: TuiExpand, selector: "tui-expand", inputs: ["expanded"] }, { kind: "directive", type: TuiGroup, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "collapsed", "rounded", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
225
170
  }
226
171
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiFilesComponent, decorators: [{
227
172
  type: Component,
228
173
  args: [{ selector: 'tui-files', imports: [NgTemplateOutlet, TuiButton, TuiExpand, TuiGroup], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
229
174
  tuiGroupOptionsProvider({ size: 'm', collapsed: true, orientation: 'vertical' }),
230
- ], hostDirectives: [TuiGroup], template: "<ng-content />\n@for (item of items(); track item) {\n @if (!max() || $index < max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n}\n@if (hasExtraItems()) {\n <tui-expand [expanded]=\"expanded()\">\n <div\n tuiGroup\n class=\"t-extra-items\"\n >\n @for (item of items(); track item) {\n @if (max() && $index >= max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n }\n </div>\n </tui-expand>\n}\n@if (hasExtraItems()) {\n <div\n class=\"t-bottom\"\n [class.t-bottom_collapsed]=\"!expanded()\"\n >\n <button\n appearance=\"outline\"\n size=\"m\"\n tuiButton\n type=\"button\"\n class=\"t-button\"\n (click)=\"toggle()\"\n >\n {{ expanded() ? hideText() : showAllText() }}\n </button>\n </div>\n}\n", styles: ["tui-files{inline-size:100%;overflow:hidden;border-radius:var(--tui-radius-m)}tui-files:empty:empty{display:none}tui-files .t-files{position:relative;display:block;inline-size:100%;block-size:100%;border-radius:var(--tui-radius-m);overflow:hidden}tui-files .t-button{inline-size:100%;border-radius:inherit}tui-files .t-bottom{z-index:3;inline-size:100%;background:var(--tui-background-base);mask:none!important}tui-files .t-bottom_collapsed{box-shadow:var(--tui-shadow-popup);margin-block-start:-1.5rem}tui-files .t-extra-items{inline-size:100%}tui-files .t-extra-items>*{border-radius:0!important}\n"] }]
175
+ ], hostDirectives: [TuiGroup], template: "<ng-content />\n@for (item of items(); track $index) {\n @if (!max() || $index < max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n}\n@if (max() && items().length > max()) {\n <tui-expand [expanded]=\"expanded()\">\n <div\n tuiGroup\n class=\"t-extra-items\"\n >\n @for (item of items(); track $index) {\n @if (max() && $index >= max()) {\n <ng-container [ngTemplateOutlet]=\"item\" />\n }\n }\n </div>\n </tui-expand>\n <div\n class=\"t-bottom\"\n [class.t-bottom_collapsed]=\"!expanded()\"\n >\n <button\n appearance=\"outline\"\n size=\"m\"\n tuiButton\n type=\"button\"\n class=\"t-button\"\n (click)=\"expanded.set(!expanded())\"\n >\n {{ expanded() ? hideText() : showAllText() }}\n </button>\n </div>\n}\n", styles: ["tui-files{inline-size:100%;overflow:hidden;border-radius:var(--tui-radius-m)}tui-files:empty:empty{display:none}tui-files .t-files{position:relative;display:block;inline-size:100%;block-size:100%;border-radius:var(--tui-radius-m);overflow:hidden}tui-files .t-button{inline-size:100%;border-radius:inherit}tui-files .t-bottom{z-index:3;inline-size:100%;background:var(--tui-background-base);mask:none!important}tui-files .t-bottom_collapsed{box-shadow:var(--tui-shadow-popup);margin-block-start:-1.5rem}tui-files .t-extra-items{inline-size:100%}tui-files .t-extra-items>*{border-radius:0!important}\n"] }]
231
176
  }] });
232
177
 
233
178
  class TuiInputFilesContent {
234
179
  constructor() {
235
- this.breakpoint$ = inject(TuiBreakpointService);
236
- this.text$ = toObservable(inject(TUI_INPUT_FILE_TEXTS));
237
- this.context = injectContext();
180
+ this.texts = inject(TUI_INPUT_FILE_TEXTS);
238
181
  this.component = inject(TuiInputFiles);
239
- }
240
- get link$() {
241
- return this.computeLink$(this.context.$implicit, !!this.component.input?.input.multiple);
242
- }
243
- get label$() {
244
- return this.computeLabel$(this.context.$implicit, !!this.component.input?.input.multiple);
245
- }
246
- computeLink$(fileDragged, multiple) {
247
- return fileDragged
248
- ? of('')
249
- : this.text$.pipe(map((t) => (multiple ? t.defaultLinkMultiple : t.defaultLinkSingle)));
250
- }
251
- computeLabel$(fileDragged, multiple) {
252
- return fileDragged
253
- ? combineLatest([this.breakpoint$, this.text$]).pipe(map(([breakpoint, text]) => {
254
- if (breakpoint === 'mobile') {
255
- return '';
256
- }
257
- return multiple ? text.dropMultiple : text.drop;
258
- }))
259
- : combineLatest([this.breakpoint$, this.text$]).pipe(map(([breakpoint, text]) => {
260
- if (breakpoint === 'mobile') {
261
- return '';
262
- }
263
- return multiple
264
- ? text.defaultLabelMultiple
265
- : text.defaultLabelSingle;
266
- }));
182
+ this.breakpoint = inject(TUI_BREAKPOINT);
183
+ this.context = injectContext();
184
+ this.link = computed(() => this.component.input()?.el.multiple
185
+ ? this.texts().defaultLinkMultiple
186
+ : this.texts().defaultLinkSingle);
187
+ this.label = computed(() => this.component.input()?.el.multiple
188
+ ? this.texts().defaultLabelMultiple
189
+ : this.texts().defaultLabelSingle);
190
+ this.dragged = computed(() => this.component.input()?.el.multiple
191
+ ? this.texts().dropMultiple
192
+ : this.texts().drop);
267
193
  }
268
194
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiInputFilesContent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
269
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.17", type: TuiInputFilesContent, isStandalone: true, selector: "ng-component", ngImport: i0, template: `
270
- <a tuiLink>{{ link$ | async }}</a>
271
- {{ label$ | async }}
272
- `, isInline: true, dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]" }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
195
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: TuiInputFilesContent, isStandalone: true, selector: "ng-component", ngImport: i0, template: `
196
+ <a tuiLink>{{ context.$implicit ? '' : link() }}</a>
197
+ @if (breakpoint() !== 'mobile') {
198
+ {{ context.$implicit ? dragged() : label() }}
199
+ }
200
+ `, isInline: true, dependencies: [{ kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
273
201
  }
274
- __decorate([
275
- tuiPure
276
- ], TuiInputFilesContent.prototype, "computeLink$", null);
277
- __decorate([
278
- tuiPure
279
- ], TuiInputFilesContent.prototype, "computeLabel$", null);
280
202
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiInputFilesContent, decorators: [{
281
203
  type: Component,
282
204
  args: [{
283
- imports: [AsyncPipe, TuiLink],
205
+ imports: [TuiLink],
284
206
  template: `
285
- <a tuiLink>{{ link$ | async }}</a>
286
- {{ label$ | async }}
207
+ <a tuiLink>{{ context.$implicit ? '' : link() }}</a>
208
+ @if (breakpoint() !== 'mobile') {
209
+ {{ context.$implicit ? dragged() : label() }}
210
+ }
287
211
  `,
288
- // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection
289
- changeDetection: ChangeDetectionStrategy.Default,
212
+ changeDetection: ChangeDetectionStrategy.OnPush,
290
213
  }]
291
- }], propDecorators: { computeLink$: [], computeLabel$: [] } });
214
+ }] });
292
215
 
293
216
  const TUI_INPUT_FILES_DEFAULT_OPTIONS = {
294
217
  appearance: 'file',
@@ -343,12 +266,11 @@ class TuiInputFilesDirective extends TuiControl {
343
266
  super(...arguments);
344
267
  this.host = inject(forwardRef(() => TuiInputFiles));
345
268
  this.m = tuiAppearanceMode(this.mode);
346
- this.reject$ = timer(0, tuiZonefreeScheduler()).pipe(switchMap(() => tuiControlValue(this.control.control)), map(() => tuiFilesRejected(this.control.control)), filter(({ length }) => !!length));
347
- this.reject = outputFromObservable(this.reject$);
348
- this.input = tuiInjectElement();
269
+ this.el = tuiInjectElement();
270
+ this.reject = outputFromObservable(timer(0, tuiZonefreeScheduler()).pipe(switchMap(() => tuiControlValue(this.control.control)), map(() => tuiFilesRejected(this.control.control)), filter(({ length }) => !!length)));
349
271
  }
350
272
  process(files) {
351
- const fileOrFiles = this.input.multiple
273
+ const fileOrFiles = this.el.multiple
352
274
  ? [...toArray(this.value()), ...Array.from(files)]
353
275
  : files[0];
354
276
  if (fileOrFiles) {
@@ -356,7 +278,7 @@ class TuiInputFilesDirective extends TuiControl {
356
278
  }
357
279
  }
358
280
  onClick(event) {
359
- if (this.input.readOnly) {
281
+ if (this.el.readOnly) {
360
282
  event.preventDefault();
361
283
  }
362
284
  }
@@ -398,38 +320,40 @@ function toArray(value) {
398
320
  class TuiInputFiles {
399
321
  constructor() {
400
322
  this.content = new PolymorpheusComponent(TuiInputFilesContent);
323
+ this.template = contentChild(TemplateRef);
324
+ this.input = contentChild(TuiInputFilesDirective);
401
325
  }
402
326
  get fileDragged() {
403
- return !!this.files && !this.input?.disabled();
327
+ return !!this.files && !this.input()?.disabled();
404
328
  }
405
329
  onFilesSelected(input) {
406
330
  if (!input?.files) {
407
331
  return;
408
332
  }
409
- this.input?.process(input.files);
333
+ this.input()?.process(input.files);
410
334
  input.value = '';
411
335
  }
412
336
  onDropped({ dataTransfer }) {
413
337
  this.files = null;
414
- if (dataTransfer?.files && !this.input?.disabled()) {
415
- this.input?.process(dataTransfer.files);
338
+ if (dataTransfer?.files && !this.input()?.disabled()) {
339
+ this.input()?.process(dataTransfer.files);
416
340
  }
417
341
  }
418
342
  onDrag(dataTransfer) {
419
343
  this.files = dataTransfer?.files;
420
344
  }
421
345
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiInputFiles, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
422
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.17", type: TuiInputFiles, isStandalone: true, selector: "label[tuiInputFiles]", host: { listeners: { "dragover.prevent.zoneless": "0", "drop.prevent": "onDropped($event)", "dragenter": "onDrag($event.dataTransfer)", "dragleave": "onDrag(null)", "change": "onFilesSelected($event.target)" }, properties: { "class._dragged": "fileDragged" } }, queries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true }, { propertyName: "input", first: true, predicate: TuiInputFilesDirective, descendants: true }], ngImport: i0, template: `
346
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "19.2.17", type: TuiInputFiles, isStandalone: true, selector: "label[tuiInputFiles]", host: { listeners: { "dragover.prevent.zoneless": "0", "drop.prevent": "onDropped($event)", "dragenter": "onDrag($event.dataTransfer)", "dragleave": "onDrag(null)", "change": "onFilesSelected($event.target)" }, properties: { "class._dragged": "fileDragged" } }, queries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "input", first: true, predicate: TuiInputFilesDirective, descendants: true, isSignal: true }], ngImport: i0, template: `
423
347
  <ng-content />
424
348
  <span
425
349
  *polymorpheusOutlet="
426
- template || content as text;
350
+ template() || content as text;
427
351
  context: {$implicit: fileDragged}
428
352
  "
429
353
  >
430
354
  {{ text }}
431
355
  </span>
432
- `, isInline: true, styles: ["label[tuiInputFiles]{position:relative;display:flex;min-block-size:var(--tui-height-l);justify-content:center;align-items:center;text-align:center;border-radius:var(--tui-radius-m);font:var(--tui-font-text-m);overflow-wrap:break-word;padding:0 .5rem}label[tuiInputFiles]>:not(input){position:relative;pointer-events:none}label[tuiInputFiles] input{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;color:transparent;cursor:pointer}label[tuiInputFiles] input:disabled~*{opacity:var(--tui-disabled-opacity)}label[tuiInputFiles] input::-webkit-file-upload-button{display:none}label[tuiInputFiles] input::file-selector-button{display:none}*:disabled label[tuiInputFiles]{pointer-events:none}[tuiAppearance][data-appearance=file]{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;border-radius:inherit;box-sizing:border-box;border:1px dashed var(--tui-text-action);outline:none}tui-root._mobile [tuiAppearance][data-appearance=file]{border-style:solid}[tuiInputFiles]._dragged [tuiAppearance][data-appearance=file]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}@media (hover: hover) and (pointer: fine){[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):hover:not([data-state]){background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}}[tuiAppearance][data-appearance=file][data-state=hover]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):active:not([data-state]){background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file][data-state=active]{background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file]:disabled:not([data-state]),[tuiAppearance][data-appearance=file][data-state=disabled]{background:transparent;border-color:var(--tui-text-tertiary)}[tuiAppearance][data-appearance=file]:focus-visible:not([data-focus=false]){border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file][data-focus=true]{border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file]:not(:disabled)[data-mode~=invalid],[tuiAppearance][data-appearance=file]:invalid:not(:disabled):not([data-mode]){border-color:var(--tui-status-negative)!important}\n"], dependencies: [{ kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
356
+ `, isInline: true, styles: ["label[tuiInputFiles]{position:relative;display:flex;min-block-size:var(--tui-height-l);justify-content:center;align-items:center;text-align:center;border-radius:var(--tui-radius-m);font:var(--tui-font-body-m);overflow-wrap:break-word;padding:0 .5rem}label[tuiInputFiles]>:not(input){position:relative;pointer-events:none}label[tuiInputFiles] input{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;color:transparent;cursor:pointer}label[tuiInputFiles] input:disabled~*{opacity:var(--tui-disabled-opacity)}label[tuiInputFiles] input::-webkit-file-upload-button{display:none}label[tuiInputFiles] input::file-selector-button{display:none}*:disabled label[tuiInputFiles]{pointer-events:none}[tuiAppearance][data-appearance=file]{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;border-radius:inherit;box-sizing:border-box;border:1px dashed var(--tui-text-action);outline:none}tui-root._mobile [tuiAppearance][data-appearance=file]{border-style:solid}[tuiInputFiles]._dragged [tuiAppearance][data-appearance=file]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}@media (hover: hover) and (pointer: fine){[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):hover:not([data-state]){background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}}[tuiAppearance][data-appearance=file][data-state=hover]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):active:not([data-state]){background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file][data-state=active]{background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file]:disabled:not([data-state]),[tuiAppearance][data-appearance=file][data-state=disabled]{background:transparent;border-color:var(--tui-text-tertiary)}[tuiAppearance][data-appearance=file]:focus-visible:not([data-focus=false]){border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file][data-focus=true]{border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file]:not(:disabled)[data-mode~=invalid],[tuiAppearance][data-appearance=file]:invalid:not(:disabled):not([data-mode]){border-color:var(--tui-status-negative)!important}\n"], dependencies: [{ kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
433
357
  }
434
358
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TuiInputFiles, decorators: [{
435
359
  type: Component,
@@ -437,7 +361,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImpo
437
361
  <ng-content />
438
362
  <span
439
363
  *polymorpheusOutlet="
440
- template || content as text;
364
+ template() || content as text;
441
365
  context: {$implicit: fileDragged}
442
366
  "
443
367
  >
@@ -450,14 +374,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImpo
450
374
  '(dragleave)': 'onDrag(null)',
451
375
  '[class._dragged]': 'fileDragged',
452
376
  '(change)': 'onFilesSelected($event.target)',
453
- }, styles: ["label[tuiInputFiles]{position:relative;display:flex;min-block-size:var(--tui-height-l);justify-content:center;align-items:center;text-align:center;border-radius:var(--tui-radius-m);font:var(--tui-font-text-m);overflow-wrap:break-word;padding:0 .5rem}label[tuiInputFiles]>:not(input){position:relative;pointer-events:none}label[tuiInputFiles] input{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;color:transparent;cursor:pointer}label[tuiInputFiles] input:disabled~*{opacity:var(--tui-disabled-opacity)}label[tuiInputFiles] input::-webkit-file-upload-button{display:none}label[tuiInputFiles] input::file-selector-button{display:none}*:disabled label[tuiInputFiles]{pointer-events:none}[tuiAppearance][data-appearance=file]{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;border-radius:inherit;box-sizing:border-box;border:1px dashed var(--tui-text-action);outline:none}tui-root._mobile [tuiAppearance][data-appearance=file]{border-style:solid}[tuiInputFiles]._dragged [tuiAppearance][data-appearance=file]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}@media (hover: hover) and (pointer: fine){[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):hover:not([data-state]){background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}}[tuiAppearance][data-appearance=file][data-state=hover]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):active:not([data-state]){background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file][data-state=active]{background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file]:disabled:not([data-state]),[tuiAppearance][data-appearance=file][data-state=disabled]{background:transparent;border-color:var(--tui-text-tertiary)}[tuiAppearance][data-appearance=file]:focus-visible:not([data-focus=false]){border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file][data-focus=true]{border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file]:not(:disabled)[data-mode~=invalid],[tuiAppearance][data-appearance=file]:invalid:not(:disabled):not([data-mode]){border-color:var(--tui-status-negative)!important}\n"] }]
454
- }], propDecorators: { template: [{
455
- type: ContentChild,
456
- args: [TemplateRef]
457
- }], input: [{
458
- type: ContentChild,
459
- args: [TuiInputFilesDirective]
460
- }] } });
377
+ }, styles: ["label[tuiInputFiles]{position:relative;display:flex;min-block-size:var(--tui-height-l);justify-content:center;align-items:center;text-align:center;border-radius:var(--tui-radius-m);font:var(--tui-font-body-m);overflow-wrap:break-word;padding:0 .5rem}label[tuiInputFiles]>:not(input){position:relative;pointer-events:none}label[tuiInputFiles] input{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;color:transparent;cursor:pointer}label[tuiInputFiles] input:disabled~*{opacity:var(--tui-disabled-opacity)}label[tuiInputFiles] input::-webkit-file-upload-button{display:none}label[tuiInputFiles] input::file-selector-button{display:none}*:disabled label[tuiInputFiles]{pointer-events:none}[tuiAppearance][data-appearance=file]{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;border-radius:inherit;box-sizing:border-box;border:1px dashed var(--tui-text-action);outline:none}tui-root._mobile [tuiAppearance][data-appearance=file]{border-style:solid}[tuiInputFiles]._dragged [tuiAppearance][data-appearance=file]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}@media (hover: hover) and (pointer: fine){[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):hover:not([data-state]){background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}}[tuiAppearance][data-appearance=file][data-state=hover]{background:var(--tui-background-neutral-1);border-color:var(--tui-text-action-hover)}[tuiAppearance][data-appearance=file]:is(a,button,select,textarea,input,label,.tui-interactive):not(:disabled):active:not([data-state]){background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file][data-state=active]{background:var(--tui-background-neutral-1-hover)}[tuiAppearance][data-appearance=file]:disabled:not([data-state]),[tuiAppearance][data-appearance=file][data-state=disabled]{background:transparent;border-color:var(--tui-text-tertiary)}[tuiAppearance][data-appearance=file]:focus-visible:not([data-focus=false]){border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file][data-focus=true]{border:.125rem solid var(--tui-border-focus)}[tuiAppearance][data-appearance=file]:not(:disabled)[data-mode~=invalid],[tuiAppearance][data-appearance=file]:invalid:not(:disabled):not([data-mode]){border-color:var(--tui-status-negative)!important}\n"] }]
378
+ }] });
461
379
 
462
380
  class TuiFileRejectedPipe {
463
381
  constructor() {