@taiga-ui/kit 3.21.0 → 3.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/bundles/taiga-ui-kit-components-input-files.umd.js +14 -11
  2. package/bundles/taiga-ui-kit-components-input-files.umd.js.map +1 -1
  3. package/bundles/taiga-ui-kit-components-input-tag.umd.js +8 -2
  4. package/bundles/taiga-ui-kit-components-input-tag.umd.js.map +1 -1
  5. package/bundles/taiga-ui-kit-components-multi-select.umd.js +260 -14
  6. package/bundles/taiga-ui-kit-components-multi-select.umd.js.map +1 -1
  7. package/bundles/taiga-ui-kit-components-select.umd.js +9 -25
  8. package/bundles/taiga-ui-kit-components-select.umd.js.map +1 -1
  9. package/bundles/taiga-ui-kit-components-text-area.umd.js +1 -1
  10. package/bundles/taiga-ui-kit-components-text-area.umd.js.map +1 -1
  11. package/bundles/taiga-ui-kit-utils-miscellaneous.umd.js +25 -14
  12. package/bundles/taiga-ui-kit-utils-miscellaneous.umd.js.map +1 -1
  13. package/components/input-files/input-files.component.d.ts +4 -3
  14. package/components/input-tag/input-tag.component.d.ts +2 -1
  15. package/components/multi-select/index.d.ts +4 -0
  16. package/components/multi-select/multi-select.component.d.ts +7 -3
  17. package/components/multi-select/multi-select.directive.d.ts +12 -0
  18. package/components/multi-select/multi-select.module.d.ts +13 -9
  19. package/components/multi-select/native-multi-select/native-multi-select-group.component.d.ts +8 -0
  20. package/components/multi-select/native-multi-select/native-multi-select.component.d.ts +7 -0
  21. package/components/multi-select/native-multi-select/native-multi-select.d.ts +18 -0
  22. package/components/select/native-select/native-select-group.component.d.ts +1 -1
  23. package/components/select/native-select/native-select.component.d.ts +1 -1
  24. package/esm2015/components/input-files/input-files.component.js +8 -5
  25. package/esm2015/components/input-files/max-size-rejection-error.pipe.js +2 -2
  26. package/esm2015/components/input-tag/input-tag.component.js +9 -3
  27. package/esm2015/components/multi-select/index.js +5 -1
  28. package/esm2015/components/multi-select/multi-select-group/multi-select-group.component.js +1 -1
  29. package/esm2015/components/multi-select/multi-select.component.js +19 -6
  30. package/esm2015/components/multi-select/multi-select.directive.js +28 -0
  31. package/esm2015/components/multi-select/multi-select.module.js +25 -3
  32. package/esm2015/components/multi-select/native-multi-select/native-multi-select-group.component.js +63 -0
  33. package/esm2015/components/multi-select/native-multi-select/native-multi-select.component.js +60 -0
  34. package/esm2015/components/multi-select/native-multi-select/native-multi-select.js +51 -0
  35. package/esm2015/components/select/native-select/native-select-group.component.js +6 -14
  36. package/esm2015/components/select/native-select/native-select.component.js +6 -14
  37. package/esm2015/components/select/select.component.js +2 -2
  38. package/esm2015/components/text-area/text-area.component.js +1 -1
  39. package/esm2015/utils/miscellaneous/create-time-periods.js +3 -3
  40. package/fesm2015/taiga-ui-kit-components-input-files.js +9 -6
  41. package/fesm2015/taiga-ui-kit-components-input-files.js.map +1 -1
  42. package/fesm2015/taiga-ui-kit-components-input-tag.js +8 -2
  43. package/fesm2015/taiga-ui-kit-components-input-tag.js.map +1 -1
  44. package/fesm2015/taiga-ui-kit-components-multi-select.js +219 -12
  45. package/fesm2015/taiga-ui-kit-components-multi-select.js.map +1 -1
  46. package/fesm2015/taiga-ui-kit-components-select.js +10 -26
  47. package/fesm2015/taiga-ui-kit-components-select.js.map +1 -1
  48. package/fesm2015/taiga-ui-kit-components-text-area.js +1 -1
  49. package/fesm2015/taiga-ui-kit-components-text-area.js.map +1 -1
  50. package/fesm2015/taiga-ui-kit-utils-miscellaneous.js +2 -2
  51. package/fesm2015/taiga-ui-kit-utils-miscellaneous.js.map +1 -1
  52. package/package.json +4 -4
@@ -3,16 +3,20 @@ import * as i1 from "./multi-select.component";
3
3
  import * as i2 from "./multi-select-group/multi-select-group.component";
4
4
  import * as i3 from "./multi-select-group/multi-select-group.directive";
5
5
  import * as i4 from "./hide-selected.pipe";
6
- import * as i5 from "@angular/common";
7
- import * as i6 from "@angular/forms";
8
- import * as i7 from "@tinkoff/ng-polymorpheus";
9
- import * as i8 from "@taiga-ui/core";
10
- import * as i9 from "@taiga-ui/cdk";
11
- import * as i10 from "@taiga-ui/kit/components/arrow";
12
- import * as i11 from "@taiga-ui/kit/components/input-tag";
13
- import * as i12 from "@taiga-ui/kit/components/multi-select-option";
6
+ import * as i5 from "./native-multi-select/native-multi-select.component";
7
+ import * as i6 from "./native-multi-select/native-multi-select-group.component";
8
+ import * as i7 from "./multi-select.directive";
9
+ import * as i8 from "@angular/common";
10
+ import * as i9 from "@angular/forms";
11
+ import * as i10 from "@tinkoff/ng-polymorpheus";
12
+ import * as i11 from "@taiga-ui/core";
13
+ import * as i12 from "@taiga-ui/cdk";
14
+ import * as i13 from "@taiga-ui/kit/components/arrow";
15
+ import * as i14 from "@taiga-ui/kit/components/input-tag";
16
+ import * as i15 from "@taiga-ui/kit/components/multi-select-option";
17
+ import * as i16 from "@taiga-ui/kit/components/data-list-wrapper";
14
18
  export declare class TuiMultiSelectModule {
15
19
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiMultiSelectModule, never>;
16
- static ɵmod: i0.ɵɵNgModuleDeclaration<TuiMultiSelectModule, [typeof i1.TuiMultiSelectComponent, typeof i2.TuiMultiSelectGroupComponent, typeof i3.TuiMultiSelectGroupDirective, typeof i4.TuiHideSelectedPipe], [typeof i5.CommonModule, typeof i6.FormsModule, typeof i7.PolymorpheusModule, typeof i8.TuiWrapperModule, typeof i9.TuiPreventDefaultModule, typeof i9.TuiActiveZoneModule, typeof i10.TuiArrowModule, typeof i9.TuiLetModule, typeof i9.TuiMapperPipeModule, typeof i8.TuiSvgModule, typeof i8.TuiHostedDropdownModule, typeof i11.TuiInputTagModule, typeof i12.TuiMultiSelectOptionModule, typeof i8.TuiLinkModule, typeof i8.TuiDataListModule, typeof i8.TuiTextfieldControllerModule], [typeof i1.TuiMultiSelectComponent, typeof i2.TuiMultiSelectGroupComponent, typeof i3.TuiMultiSelectGroupDirective, typeof i4.TuiHideSelectedPipe]>;
20
+ static ɵmod: i0.ɵɵNgModuleDeclaration<TuiMultiSelectModule, [typeof i1.TuiMultiSelectComponent, typeof i2.TuiMultiSelectGroupComponent, typeof i3.TuiMultiSelectGroupDirective, typeof i4.TuiHideSelectedPipe, typeof i5.TuiNativeMultiSelectComponent, typeof i6.TuiNativeMultiSelectGroupComponent, typeof i7.TuiMultiSelectDirective], [typeof i8.CommonModule, typeof i9.FormsModule, typeof i10.PolymorpheusModule, typeof i11.TuiWrapperModule, typeof i12.TuiPreventDefaultModule, typeof i12.TuiActiveZoneModule, typeof i13.TuiArrowModule, typeof i12.TuiLetModule, typeof i12.TuiMapperPipeModule, typeof i11.TuiSvgModule, typeof i11.TuiHostedDropdownModule, typeof i14.TuiInputTagModule, typeof i15.TuiMultiSelectOptionModule, typeof i16.TuiDataListWrapperModule, typeof i12.TuiMapperPipeModule, typeof i11.TuiLinkModule, typeof i11.TuiDataListModule, typeof i11.TuiTextfieldControllerModule], [typeof i1.TuiMultiSelectComponent, typeof i2.TuiMultiSelectGroupComponent, typeof i3.TuiMultiSelectGroupDirective, typeof i4.TuiHideSelectedPipe, typeof i7.TuiMultiSelectDirective, typeof i5.TuiNativeMultiSelectComponent, typeof i6.TuiNativeMultiSelectGroupComponent]>;
17
21
  static ɵinj: i0.ɵɵInjectorDeclaration<TuiMultiSelectModule>;
18
22
  }
@@ -0,0 +1,8 @@
1
+ import { AbstractTuiNativeMultiSelect } from './native-multi-select';
2
+ import * as i0 from "@angular/core";
3
+ export declare class TuiNativeMultiSelectGroupComponent extends AbstractTuiNativeMultiSelect {
4
+ items: readonly string[][] | null;
5
+ labels: readonly string[];
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiNativeMultiSelectGroupComponent, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiNativeMultiSelectGroupComponent, "select[multiple][tuiSelect][labels]", never, { "items": "items"; "labels": "labels"; }, {}, never, never>;
8
+ }
@@ -0,0 +1,7 @@
1
+ import { AbstractTuiNativeMultiSelect } from './native-multi-select';
2
+ import * as i0 from "@angular/core";
3
+ export declare class TuiNativeMultiSelectComponent extends AbstractTuiNativeMultiSelect {
4
+ items: string[] | null;
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiNativeMultiSelectComponent, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiNativeMultiSelectComponent, "select[multiple][tuiSelect]:not([labels])", never, { "items": "items"; }, {}, never, never>;
7
+ }
@@ -0,0 +1,18 @@
1
+ import { ChangeDetectorRef, ElementRef, TemplateRef } from '@angular/core';
2
+ import { AbstractTuiControl, TuiIdService, TuiMapper } from '@taiga-ui/cdk';
3
+ import { TuiMultiSelectDirective } from '../multi-select.directive';
4
+ import * as i0 from "@angular/core";
5
+ export declare abstract class AbstractTuiNativeMultiSelect {
6
+ readonly host: TuiMultiSelectDirective;
7
+ readonly control: AbstractTuiControl<unknown>;
8
+ private readonly elementRef;
9
+ private readonly idService;
10
+ readonly cdr: ChangeDetectorRef;
11
+ readonly datalist: TemplateRef<any> | null;
12
+ constructor(host: TuiMultiSelectDirective, control: AbstractTuiControl<unknown>, elementRef: ElementRef<HTMLSelectElement>, idService: TuiIdService, cdr: ChangeDetectorRef);
13
+ get id(): string;
14
+ selectedMapper: TuiMapper<string, boolean>;
15
+ onValueChange(): void;
16
+ static ɵfac: i0.ɵɵFactoryDeclaration<AbstractTuiNativeMultiSelect, never>;
17
+ static ɵdir: i0.ɵɵDirectiveDeclaration<AbstractTuiNativeMultiSelect, never, never, {}, {}, never>;
18
+ }
@@ -4,5 +4,5 @@ export declare class TuiNativeSelectGroupComponent extends AbstractTuiNativeSele
4
4
  items: readonly string[][] | null;
5
5
  labels: readonly string[];
6
6
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiNativeSelectGroupComponent, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiNativeSelectGroupComponent, "select[tuiSelect][labels]", never, { "items": "items"; "labels": "labels"; }, {}, never, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiNativeSelectGroupComponent, "select[tuiSelect][labels]:not([multiple])", never, { "items": "items"; "labels": "labels"; }, {}, never, never>;
8
8
  }
@@ -3,5 +3,5 @@ import * as i0 from "@angular/core";
3
3
  export declare class TuiNativeSelectComponent extends AbstractTuiNativeSelect {
4
4
  items: readonly string[] | null;
5
5
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiNativeSelectComponent, never>;
6
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiNativeSelectComponent, "select[tuiSelect]:not([labels])", never, { "items": "items"; }, {}, never, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiNativeSelectComponent, "select[tuiSelect]:not([labels]):not([multiple])", never, { "items": "items"; }, {}, never, never>;
7
7
  }
@@ -1,5 +1,5 @@
1
1
  import { __decorate } from "tslib";
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, HostListener, Inject, Input, Optional, Output, Self, ViewChild, ViewEncapsulation, } from '@angular/core';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, HostListener, Inject, Input, Optional, Output, Self, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
3
3
  import { NgControl } from '@angular/forms';
4
4
  import { AbstractTuiNullableControl, EMPTY_ARRAY, TUI_IS_MOBILE, tuiAsFocusableItemAccessor, tuiDefaultProp, tuiIsNativeFocused, tuiPure, } from '@taiga-ui/cdk';
5
5
  import { MODE_PROVIDER } from '@taiga-ui/core';
@@ -13,8 +13,8 @@ import { TUI_INPUT_FILES_OPTIONS } from './input-files.options';
13
13
  import * as i0 from "@angular/core";
14
14
  import * as i1 from "@taiga-ui/core";
15
15
  import * as i2 from "@taiga-ui/cdk";
16
- import * as i3 from "@tinkoff/ng-polymorpheus";
17
- import * as i4 from "@angular/common";
16
+ import * as i3 from "@angular/common";
17
+ import * as i4 from "@tinkoff/ng-polymorpheus";
18
18
  import * as i5 from "./max-size-rejection-error.pipe";
19
19
  import * as i6 from "@angular/forms";
20
20
  import * as i7 from "rxjs";
@@ -166,7 +166,7 @@ export class TuiInputFilesComponent extends AbstractTuiNullableControl {
166
166
  }
167
167
  }
168
168
  TuiInputFilesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputFilesComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_IS_MOBILE }, { token: TUI_INPUT_FILE_TEXTS }, { token: TUI_INPUT_FILES_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
169
- TuiInputFilesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputFilesComponent, selector: "tui-input-files", inputs: { link: "link", label: "label", accept: "accept", multiple: "multiple", size: "size", maxFileSize: "maxFileSize" }, outputs: { reject: "reject" }, host: { listeners: { "focusin": "onFocused(true)", "focusout": "onFocused(false)", "change": "onFilesSelected()" } }, providers: [MODE_PROVIDER, tuiAsFocusableItemAccessor(TuiInputFilesComponent)], queries: [{ propertyName: "nativeInput", first: true, predicate: TuiInputFilesDirective, descendants: true, read: TuiInputFilesDirective }], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "formatRejection", first: true, predicate: ["formatRejection"], descendants: true }, { propertyName: "maxSizeRejection", first: true, predicate: ["maxSizeRejection"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n tuiWrapper\n appearance=\"input-file\"\n class=\"t-wrapper\"\n [class._mobile]=\"isMobile\"\n [focus]=\"computedFocused\"\n [hover]=\"pseudoHover || fileDragged || null\"\n [active]=\"pseudoActive\"\n [disabled]=\"computedDisabled\"\n>\n <label\n automation-id=\"tui-input-file__label\"\n class=\"t-label\"\n (tuiDroppableDropped)=\"onDropped($event)\"\n (tuiDroppableDragOverChange)=\"onDragOver($event)\"\n (mousedown.prevent.silent)=\"(0)\"\n >\n <a tuiLink>\n <ng-container *polymorpheusOutlet=\"computedLink$ | async as text\">\n {{ text }}\n </ng-container>\n </a>\n <ng-container *polymorpheusOutlet=\"computedLabel$ | async as text\">\n {{ text }}\n </ng-container>\n <ng-container *ngIf=\"!readOnly && !computedDisabled\">\n <ng-content select=\"input\"></ng-content>\n <input\n #input\n type=\"file\"\n class=\"t-native\"\n [id]=\"id\"\n [accept]=\"accept\"\n [multiple]=\"multiple\"\n [tuiFocusable]=\"focusable\"\n />\n </ng-container>\n </label>\n</div>\n\n<ng-template #formatRejection>\n {{ (inputFileTexts$ | async)?.formatRejectionReason || '' }}\n</ng-template>\n\n<ng-template #maxSizeRejection>\n {{ maxFileSize | tuiMaxSizeRejectionError | async }}\n</ng-template>\n", styles: ["tui-input-files{display:block}tui-input-files .t-native{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}tui-input-files .t-native::-webkit-file-upload-button{display:none}tui-input-files .t-native+.t-native{display:none}tui-input-files .t-label{text-align:center}[tuiWrapper][data-appearance=input-file]{display:flex;background:transparent;font:var(--tui-font-text-m);word-wrap:break-word;color:var(--tui-text-02);flex:1;justify-content:center;align-items:center;min-height:var(--tui-height-l);border-radius:var(--tui-radius-m);padding:1rem .5rem;box-sizing:border-box}[tuiWrapper][data-appearance=input-file]:after{border:1px dashed;color:var(--tui-link)}[tuiWrapper][data-appearance=input-file]._mobile:after{border:1px solid}[tuiWrapper][data-appearance=input-file]:disabled:disabled,[tuiWrapper][data-appearance=input-file][data-state=disabled][data-state=disabled]{opacity:var(--tui-disabled-opacity);pointer-events:none}[tuiWrapper][data-appearance=input-file]:disabled:disabled:after,[tuiWrapper][data-appearance=input-file][data-state=disabled][data-state=disabled]:after{color:var(--tui-text-03)}[tuiWrapper][data-appearance=input-file]:focus-visible:focus-visible:after{border-style:solid;border-width:2px;color:var(--tui-focus)}[tuiWrapper][data-appearance=input-file]._focused._focused:after{border-style:solid;border-width:2px;color:var(--tui-focus)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]{color:var(--tui-text-01-night)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:after{color:var(--tui-text-01-night)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:focus-visible:focus-visible:after{color:var(--tui-text-01-night)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]._focused._focused:after{color:var(--tui-text-01-night)}@media (hover: hover){[tuiWrapper][data-appearance=input-file][data-mode=onDark]:hover:not(._no-hover),[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=hover]{background:var(--tui-clear-inverse-hover)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:hover:not(._no-hover):after,[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=hover]:after{color:var(--tui-text-03-night)}}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:active:not(._no-active),[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active],[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active]:hover{background:var(--tui-clear-inverse-active)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:active:not(._no-active):after,[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active]:after,[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active]:hover:after{color:var(--tui-text-03-night)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]{color:var(--tui-text-01)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:after{color:var(--tui-text-01)}@media (hover: hover){[tuiWrapper][data-appearance=input-file][data-mode=onLight]:hover:not(._no-hover),[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=hover]{background:var(--tui-clear-hover)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:hover:not(._no-hover):after,[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=hover]:after{color:var(--tui-text-03)}}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:active:not(._no-active),[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active],[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active]:hover{background:var(--tui-clear-active)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:active:not(._no-active):after,[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active]:after,[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active]:hover:after{color:var(--tui-text-03)}@media (hover: hover){[tuiWrapper][data-appearance=input-file]:hover:not(._no-hover),[tuiWrapper][data-appearance=input-file][data-state=hover]{background:var(--tui-secondary)}[tuiWrapper][data-appearance=input-file]:hover:not(._no-hover):after,[tuiWrapper][data-appearance=input-file][data-state=hover]:after{color:var(--tui-link-hover)}}[tuiWrapper][data-appearance=input-file]:active:not(._no-active),[tuiWrapper][data-appearance=input-file][data-state=active],[tuiWrapper][data-appearance=input-file][data-state=active]:hover{background:var(--tui-secondary-hover)}\n"], components: [{ type: i1.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }], directives: [{ type: i1.TuiWrapperDirective, selector: "[tuiWrapper]", inputs: ["disabled", "readOnly", "hover", "active", "focus", "invalid", "appearance"] }, { type: i2.TuiDroppableDirective, selector: "[tuiDroppableDropped], [tuiDroppableDragOverChange]", outputs: ["tuiDroppableDropped", "tuiDroppableDragOverChange"] }, { type: i3.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.TuiFocusableDirective, selector: "[tuiFocusable]", inputs: ["tuiFocusable"] }], pipes: { "async": i4.AsyncPipe, "tuiMaxSizeRejectionError": i5.TuiMaxSizeRejectionErrorPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
169
+ TuiInputFilesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputFilesComponent, selector: "tui-input-files", inputs: { link: "link", label: "label", accept: "accept", multiple: "multiple", size: "size", maxFileSize: "maxFileSize" }, outputs: { reject: "reject" }, host: { listeners: { "focusin": "onFocused(true)", "focusout": "onFocused(false)", "change": "onFilesSelected()" } }, providers: [MODE_PROVIDER, tuiAsFocusableItemAccessor(TuiInputFilesComponent)], queries: [{ propertyName: "nativeInput", first: true, predicate: TuiInputFilesDirective, descendants: true, read: TuiInputFilesDirective }, { propertyName: "template", first: true, predicate: TemplateRef, descendants: true }], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "formatRejection", first: true, predicate: ["formatRejection"], descendants: true }, { propertyName: "maxSizeRejection", first: true, predicate: ["maxSizeRejection"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n tuiWrapper\n appearance=\"input-file\"\n class=\"t-wrapper\"\n [class._mobile]=\"isMobile\"\n [focus]=\"computedFocused\"\n [hover]=\"pseudoHover || fileDragged || null\"\n [active]=\"pseudoActive\"\n [disabled]=\"computedDisabled\"\n>\n <label\n automation-id=\"tui-input-file__label\"\n class=\"t-label\"\n (tuiDroppableDropped)=\"onDropped($event)\"\n (tuiDroppableDragOverChange)=\"onDragOver($event)\"\n (mousedown.prevent.silent)=\"(0)\"\n >\n <ng-container *ngTemplateOutlet=\"template || null; context: {$implicit: fileDragged}\"></ng-container>\n <ng-container *ngIf=\"!template\">\n <a tuiLink>\n <ng-container *polymorpheusOutlet=\"computedLink$ | async as text\">\n {{ text }}\n </ng-container>\n </a>\n <ng-container *polymorpheusOutlet=\"computedLabel$ | async as text\">\n {{ text }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!readOnly && !computedDisabled\">\n <ng-content select=\"input\"></ng-content>\n <input\n #input\n type=\"file\"\n class=\"t-native\"\n [id]=\"id\"\n [accept]=\"accept\"\n [multiple]=\"multiple\"\n [tuiFocusable]=\"focusable\"\n />\n </ng-container>\n </label>\n</div>\n\n<ng-template #formatRejection>\n {{ (inputFileTexts$ | async)?.formatRejectionReason || '' }}\n</ng-template>\n\n<ng-template #maxSizeRejection>\n {{ maxFileSize | tuiMaxSizeRejectionError | async }}\n</ng-template>\n", styles: ["tui-input-files{display:block;min-height:var(--tui-height-l);border-radius:var(--tui-radius-m);font:var(--tui-font-text-m)}tui-input-files .t-native{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}tui-input-files .t-native::-webkit-file-upload-button{display:none}tui-input-files .t-native+.t-native{display:none}tui-input-files .t-label{text-align:center}[tuiWrapper][data-appearance=input-file]{display:flex;background:transparent;word-wrap:break-word;color:var(--tui-text-02);justify-content:center;align-items:center;min-height:inherit;border-radius:inherit;padding:0 .5rem;box-sizing:border-box}[tuiWrapper][data-appearance=input-file]:after{border:1px dashed;color:var(--tui-link)}[tuiWrapper][data-appearance=input-file]._mobile:after{border:1px solid}[tuiWrapper][data-appearance=input-file]:disabled:disabled,[tuiWrapper][data-appearance=input-file][data-state=disabled][data-state=disabled]{opacity:var(--tui-disabled-opacity);pointer-events:none}[tuiWrapper][data-appearance=input-file]:disabled:disabled:after,[tuiWrapper][data-appearance=input-file][data-state=disabled][data-state=disabled]:after{color:var(--tui-text-03)}[tuiWrapper][data-appearance=input-file]:focus-visible:focus-visible:after{border-style:solid;border-width:2px;color:var(--tui-focus)}[tuiWrapper][data-appearance=input-file]._focused._focused:after{border-style:solid;border-width:2px;color:var(--tui-focus)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]{color:var(--tui-text-01-night)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:after{color:var(--tui-text-01-night)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:focus-visible:focus-visible:after{color:var(--tui-text-01-night)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]._focused._focused:after{color:var(--tui-text-01-night)}@media (hover: hover){[tuiWrapper][data-appearance=input-file][data-mode=onDark]:hover:not(._no-hover),[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=hover]{background:var(--tui-clear-inverse-hover)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:hover:not(._no-hover):after,[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=hover]:after{color:var(--tui-text-03-night)}}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:active:not(._no-active),[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active],[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active]:hover{background:var(--tui-clear-inverse-active)}[tuiWrapper][data-appearance=input-file][data-mode=onDark]:active:not(._no-active):after,[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active]:after,[tuiWrapper][data-appearance=input-file][data-mode=onDark][data-state=active]:hover:after{color:var(--tui-text-03-night)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]{color:var(--tui-text-01)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:after{color:var(--tui-text-01)}@media (hover: hover){[tuiWrapper][data-appearance=input-file][data-mode=onLight]:hover:not(._no-hover),[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=hover]{background:var(--tui-clear-hover)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:hover:not(._no-hover):after,[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=hover]:after{color:var(--tui-text-03)}}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:active:not(._no-active),[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active],[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active]:hover{background:var(--tui-clear-active)}[tuiWrapper][data-appearance=input-file][data-mode=onLight]:active:not(._no-active):after,[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active]:after,[tuiWrapper][data-appearance=input-file][data-mode=onLight][data-state=active]:hover:after{color:var(--tui-text-03)}@media (hover: hover){[tuiWrapper][data-appearance=input-file]:hover:not(._no-hover),[tuiWrapper][data-appearance=input-file][data-state=hover]{background:var(--tui-secondary)}[tuiWrapper][data-appearance=input-file]:hover:not(._no-hover):after,[tuiWrapper][data-appearance=input-file][data-state=hover]:after{color:var(--tui-link-hover)}}[tuiWrapper][data-appearance=input-file]:active:not(._no-active),[tuiWrapper][data-appearance=input-file][data-state=active],[tuiWrapper][data-appearance=input-file][data-state=active]:hover{background:var(--tui-secondary-hover)}\n"], components: [{ type: i1.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }], directives: [{ type: i1.TuiWrapperDirective, selector: "[tuiWrapper]", inputs: ["disabled", "readOnly", "hover", "active", "focus", "invalid", "appearance"] }, { type: i2.TuiDroppableDirective, selector: "[tuiDroppableDropped], [tuiDroppableDragOverChange]", outputs: ["tuiDroppableDropped", "tuiDroppableDragOverChange"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i2.TuiFocusableDirective, selector: "[tuiFocusable]", inputs: ["tuiFocusable"] }], pipes: { "async": i3.AsyncPipe, "tuiMaxSizeRejectionError": i5.TuiMaxSizeRejectionErrorPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
170
170
  __decorate([
171
171
  tuiDefaultProp()
172
172
  ], TuiInputFilesComponent.prototype, "link", void 0);
@@ -229,6 +229,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
229
229
  }], nativeInput: [{
230
230
  type: ContentChild,
231
231
  args: [TuiInputFilesDirective, { read: TuiInputFilesDirective }]
232
+ }], template: [{
233
+ type: ContentChild,
234
+ args: [TemplateRef]
232
235
  }], formatRejection: [{
233
236
  type: ViewChild,
234
237
  args: ['formatRejection']
@@ -259,4 +262,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
259
262
  type: HostListener,
260
263
  args: ['change']
261
264
  }], computeLink$: [], computeLabel$: [], getValueArray: [] } });
262
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-files.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-files/input-files.component.ts","../../../../../projects/kit/components/input-files/input-files.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    EMPTY_ARRAY,\n    TUI_IS_MOBILE,\n    tuiAsFocusableItemAccessor,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    tuiIsNativeFocused,\n    TuiNativeFocusableElement,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {MODE_PROVIDER, TuiSizeL} from '@taiga-ui/core';\nimport {TuiFileLike} from '@taiga-ui/kit/interfaces';\nimport {TUI_INPUT_FILE_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiGetAcceptArray} from '@taiga-ui/kit/utils/files';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable, of} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// eslint-disable-next-line import/no-cycle\nimport {TuiInputFilesDirective} from './input-files.directive';\nimport {TUI_INPUT_FILES_OPTIONS, TuiInputFilesOptions} from './input-files.options';\n\n@Component({\n    selector: 'tui-input-files',\n    templateUrl: './input-files.template.html',\n    styleUrls: ['./input-files.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [MODE_PROVIDER, tuiAsFocusableItemAccessor(TuiInputFilesComponent)],\n})\nexport class TuiInputFilesComponent\n    extends AbstractTuiNullableControl<TuiFileLike | readonly TuiFileLike[]>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild('input')\n    private readonly input?: ElementRef<HTMLInputElement>;\n\n    private dataTransfer: DataTransfer | null = null;\n\n    @ContentChild(TuiInputFilesDirective, {read: TuiInputFilesDirective})\n    readonly nativeInput?: TuiInputFilesDirective;\n\n    @ViewChild('formatRejection')\n    readonly formatRejection!: PolymorpheusContent;\n\n    @ViewChild('maxSizeRejection')\n    readonly maxSizeRejection!: PolymorpheusContent;\n\n    @Input()\n    @tuiDefaultProp()\n    link: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    label: PolymorpheusContent = '';\n\n    /**\n     * @deprecated: use `<input tuiInputFiles accept=\"image/*\" />`\n     */\n    @Input()\n    @tuiDefaultProp()\n    accept = this.options.accepts;\n\n    /**\n     * @deprecated: use `<input tuiInputFiles multiple />`\n     */\n    @Input()\n    @tuiDefaultProp()\n    multiple = this.options.multiple;\n\n    @Input()\n    @tuiDefaultProp()\n    size: TuiSizeL = this.options.size;\n\n    @Input()\n    @tuiDefaultProp()\n    maxFileSize = this.options.maxFileSize;\n\n    @Output()\n    readonly reject = new EventEmitter<TuiFileLike | readonly TuiFileLike[]>();\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef)\n        changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_IS_MOBILE)\n        readonly isMobile: boolean,\n        @Inject(TUI_INPUT_FILE_TEXTS)\n        readonly inputFileTexts$: Observable<\n            Record<\n                | 'defaultLabelMultiple'\n                | 'defaultLabelSingle'\n                | 'defaultLinkMultiple'\n                | 'defaultLinkSingle'\n                | 'drop'\n                | 'dropMultiple'\n                | 'formatRejectionReason'\n                | 'maxSizeRejectionReason',\n                string\n            >\n        >,\n        @Inject(TUI_INPUT_FILES_OPTIONS)\n        readonly options: TuiInputFilesOptions,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get computedMultiple(): boolean {\n        return this.nativeInput?.multiple ?? this.multiple;\n    }\n\n    get computedAccept(): string {\n        return this.nativeInput?.accept ?? this.accept;\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return this.input?.nativeElement || null;\n    }\n\n    get focused(): boolean {\n        return tuiIsNativeFocused(this.nativeFocusableElement);\n    }\n\n    get computedPseudoHovered(): boolean | null {\n        return this.pseudoHover ?? (this.fileDragged || null);\n    }\n\n    get computedLink$(): Observable<PolymorpheusContent> {\n        return this.computeLink$(this.fileDragged, this.computedMultiple, this.link);\n    }\n\n    get computedLabel$(): Observable<PolymorpheusContent> {\n        return this.computeLabel$(\n            this.isMobile,\n            this.fileDragged,\n            this.computedMultiple,\n            this.label,\n        );\n    }\n\n    get fileDragged(): boolean {\n        return !!this.dataTransfer?.types.includes('Files');\n    }\n\n    get arrayValue(): readonly TuiFileLike[] {\n        return this.getValueArray(this.value);\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    @HostListener('change')\n    onFilesSelected(): void {\n        const input = this.nativeInput?.input ?? this.input?.nativeElement;\n\n        if (!input) {\n            return;\n        }\n\n        this.processSelectedFiles(input.files);\n\n        input.value = '';\n    }\n\n    onDropped(event: DataTransfer): void {\n        this.processSelectedFiles(event.files);\n    }\n\n    onDragOver(dataTransfer: DataTransfer | null): void {\n        this.dataTransfer = dataTransfer;\n    }\n\n    removeFile(removedFile: TuiFileLike): void {\n        this.updateValue(\n            this.computedMultiple\n                ? this.arrayValue.filter(file => file !== removedFile)\n                : null,\n        );\n    }\n\n    @tuiPure\n    private computeLink$(\n        fileDragged: boolean,\n        multiple: boolean,\n        link: PolymorpheusContent,\n    ): Observable<PolymorpheusContent> {\n        return fileDragged\n            ? of('')\n            : this.inputFileTexts$.pipe(\n                  map(texts =>\n                      multiple && link === ''\n                          ? texts.defaultLinkMultiple\n                          : link || texts.defaultLinkSingle,\n                  ),\n              );\n    }\n\n    @tuiPure\n    private computeLabel$(\n        isMobile: boolean,\n        fileDragged: boolean,\n        multiple: boolean,\n        label: PolymorpheusContent,\n    ): Observable<PolymorpheusContent> {\n        if (isMobile) {\n            return of('');\n        }\n\n        if (fileDragged) {\n            return this.inputFileTexts$.pipe(\n                map(texts => (multiple ? texts.dropMultiple : texts.drop)),\n            );\n        }\n\n        return this.inputFileTexts$.pipe(\n            map(texts =>\n                multiple && label === ''\n                    ? texts.defaultLabelMultiple\n                    : label || texts.defaultLabelSingle,\n            ),\n        );\n    }\n\n    @tuiPure\n    private getValueArray(\n        value: TuiFileLike | readonly TuiFileLike[] | null,\n    ): readonly TuiFileLike[] {\n        if (!value) {\n            return EMPTY_ARRAY;\n        }\n\n        return Array.isArray(value) ? value : [value];\n    }\n\n    private processSelectedFiles(files: FileList | null): void {\n        // IE11 after selecting a file through the open dialog generates a second event passing an empty FileList.\n        if (!files?.length) {\n            return;\n        }\n\n        const errors: Record<\n            'formatRejection' | 'maxSizeRejection',\n            PolymorpheusContent\n        > = {\n            formatRejection: this.formatRejection,\n            maxSizeRejection: this.maxSizeRejection,\n        };\n\n        const newFiles = this.computedMultiple ? Array.from(files) : [files[0]];\n        const tooBigFiles = newFiles.filter(file => file.size > this.maxFileSize);\n        const wrongFormatFiles = newFiles.filter(\n            file => !this.isFormatAcceptable(file) && !tooBigFiles.includes(file),\n        );\n        const acceptedFiles = newFiles.filter(\n            file => !tooBigFiles.includes(file) && !wrongFormatFiles.includes(file),\n        );\n\n        if (tooBigFiles.length || wrongFormatFiles.length) {\n            this.rejectFiles([\n                ...tooBigFiles.map(file => ({\n                    name: file.name,\n                    type: file.type,\n                    size: file.size,\n                    content: errors.maxSizeRejection,\n                })),\n                ...wrongFormatFiles.map(file => ({\n                    name: file.name,\n                    type: file.type,\n                    size: file.size,\n                    content: errors.formatRejection,\n                })),\n            ]);\n        }\n\n        this.updateValue(\n            this.computedMultiple\n                ? [...this.arrayValue, ...acceptedFiles]\n                : acceptedFiles[0] || null,\n        );\n    }\n\n    private isFormatAcceptable(file: File): boolean {\n        if (!this.computedAccept) {\n            return true;\n        }\n\n        const extension = `.${(file.name.split('.').pop() || '').toLowerCase()}`;\n\n        return tuiGetAcceptArray(this.computedAccept).some(\n            format =>\n                format === extension ||\n                format === file.type ||\n                (format.split('/')[1] === '*' &&\n                    file.type.split('/')[0] === format.split('/')[0]),\n        );\n    }\n\n    private rejectFiles(rejectedFiles: readonly TuiFileLike[]): void {\n        this.reject.emit(this.computedMultiple ? rejectedFiles : rejectedFiles[0]);\n    }\n}\n","<div\n    tuiWrapper\n    appearance=\"input-file\"\n    class=\"t-wrapper\"\n    [class._mobile]=\"isMobile\"\n    [focus]=\"computedFocused\"\n    [hover]=\"pseudoHover || fileDragged || null\"\n    [active]=\"pseudoActive\"\n    [disabled]=\"computedDisabled\"\n>\n    <label\n        automation-id=\"tui-input-file__label\"\n        class=\"t-label\"\n        (tuiDroppableDropped)=\"onDropped($event)\"\n        (tuiDroppableDragOverChange)=\"onDragOver($event)\"\n        (mousedown.prevent.silent)=\"(0)\"\n    >\n        <a tuiLink>\n            <ng-container *polymorpheusOutlet=\"computedLink$ | async as text\">\n                {{ text }}\n            </ng-container>\n        </a>\n        <ng-container *polymorpheusOutlet=\"computedLabel$ | async as text\">\n            {{ text }}\n        </ng-container>\n        <ng-container *ngIf=\"!readOnly && !computedDisabled\">\n            <ng-content select=\"input\"></ng-content>\n            <input\n                #input\n                type=\"file\"\n                class=\"t-native\"\n                [id]=\"id\"\n                [accept]=\"accept\"\n                [multiple]=\"multiple\"\n                [tuiFocusable]=\"focusable\"\n            />\n        </ng-container>\n    </label>\n</div>\n\n<ng-template #formatRejection>\n    {{ (inputFileTexts$ | async)?.formatRejectionReason || '' }}\n</ng-template>\n\n<ng-template #maxSizeRejection>\n    {{ maxFileSize | tuiMaxSizeRejectionError | async }}\n</ng-template>\n"]}
265
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-files.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-files/input-files.component.ts","../../../../../projects/kit/components/input-files/input-files.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    EMPTY_ARRAY,\n    TUI_IS_MOBILE,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    tuiIsNativeFocused,\n    TuiNativeFocusableElement,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {MODE_PROVIDER, TuiSizeL} from '@taiga-ui/core';\nimport {TuiFileLike} from '@taiga-ui/kit/interfaces';\nimport {TUI_INPUT_FILE_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiGetAcceptArray} from '@taiga-ui/kit/utils/files';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable, of} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// eslint-disable-next-line import/no-cycle\nimport {TuiInputFilesDirective} from './input-files.directive';\nimport {TUI_INPUT_FILES_OPTIONS, TuiInputFilesOptions} from './input-files.options';\n\n@Component({\n    selector: 'tui-input-files',\n    templateUrl: './input-files.template.html',\n    styleUrls: ['./input-files.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [MODE_PROVIDER, tuiAsFocusableItemAccessor(TuiInputFilesComponent)],\n})\nexport class TuiInputFilesComponent\n    extends AbstractTuiNullableControl<TuiFileLike | readonly TuiFileLike[]>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild('input')\n    private readonly input?: ElementRef<HTMLInputElement>;\n\n    private dataTransfer: DataTransfer | null = null;\n\n    @ContentChild(TuiInputFilesDirective, {read: TuiInputFilesDirective})\n    readonly nativeInput?: TuiInputFilesDirective;\n\n    @ContentChild(TemplateRef)\n    readonly template?: TemplateRef<TuiContextWithImplicit<boolean>>;\n\n    @ViewChild('formatRejection')\n    readonly formatRejection!: PolymorpheusContent;\n\n    @ViewChild('maxSizeRejection')\n    readonly maxSizeRejection!: PolymorpheusContent;\n\n    @Input()\n    @tuiDefaultProp()\n    link: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    label: PolymorpheusContent = '';\n\n    /**\n     * @deprecated: use `<input tuiInputFiles accept=\"image/*\" />`\n     */\n    @Input()\n    @tuiDefaultProp()\n    accept = this.options.accepts;\n\n    /**\n     * @deprecated: use `<input tuiInputFiles multiple />`\n     */\n    @Input()\n    @tuiDefaultProp()\n    multiple = this.options.multiple;\n\n    @Input()\n    @tuiDefaultProp()\n    size: TuiSizeL = this.options.size;\n\n    @Input()\n    @tuiDefaultProp()\n    maxFileSize = this.options.maxFileSize;\n\n    @Output()\n    readonly reject = new EventEmitter<TuiFileLike | readonly TuiFileLike[]>();\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef)\n        changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_IS_MOBILE)\n        readonly isMobile: boolean,\n        @Inject(TUI_INPUT_FILE_TEXTS)\n        readonly inputFileTexts$: Observable<\n            Record<\n                | 'defaultLabelMultiple'\n                | 'defaultLabelSingle'\n                | 'defaultLinkMultiple'\n                | 'defaultLinkSingle'\n                | 'drop'\n                | 'dropMultiple'\n                | 'formatRejectionReason'\n                | 'maxSizeRejectionReason',\n                string\n            >\n        >,\n        @Inject(TUI_INPUT_FILES_OPTIONS)\n        readonly options: TuiInputFilesOptions,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get computedMultiple(): boolean {\n        return this.nativeInput?.multiple ?? this.multiple;\n    }\n\n    get computedAccept(): string {\n        return this.nativeInput?.accept ?? this.accept;\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return this.input?.nativeElement || null;\n    }\n\n    get focused(): boolean {\n        return tuiIsNativeFocused(this.nativeFocusableElement);\n    }\n\n    get computedPseudoHovered(): boolean | null {\n        return this.pseudoHover ?? (this.fileDragged || null);\n    }\n\n    get computedLink$(): Observable<PolymorpheusContent> {\n        return this.computeLink$(this.fileDragged, this.computedMultiple, this.link);\n    }\n\n    get computedLabel$(): Observable<PolymorpheusContent> {\n        return this.computeLabel$(\n            this.isMobile,\n            this.fileDragged,\n            this.computedMultiple,\n            this.label,\n        );\n    }\n\n    get fileDragged(): boolean {\n        return !!this.dataTransfer?.types.includes('Files');\n    }\n\n    get arrayValue(): readonly TuiFileLike[] {\n        return this.getValueArray(this.value);\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    @HostListener('change')\n    onFilesSelected(): void {\n        const input = this.nativeInput?.input ?? this.input?.nativeElement;\n\n        if (!input) {\n            return;\n        }\n\n        this.processSelectedFiles(input.files);\n\n        input.value = '';\n    }\n\n    onDropped(event: DataTransfer): void {\n        this.processSelectedFiles(event.files);\n    }\n\n    onDragOver(dataTransfer: DataTransfer | null): void {\n        this.dataTransfer = dataTransfer;\n    }\n\n    removeFile(removedFile: TuiFileLike): void {\n        this.updateValue(\n            this.computedMultiple\n                ? this.arrayValue.filter(file => file !== removedFile)\n                : null,\n        );\n    }\n\n    @tuiPure\n    private computeLink$(\n        fileDragged: boolean,\n        multiple: boolean,\n        link: PolymorpheusContent,\n    ): Observable<PolymorpheusContent> {\n        return fileDragged\n            ? of('')\n            : this.inputFileTexts$.pipe(\n                  map(texts =>\n                      multiple && link === ''\n                          ? texts.defaultLinkMultiple\n                          : link || texts.defaultLinkSingle,\n                  ),\n              );\n    }\n\n    @tuiPure\n    private computeLabel$(\n        isMobile: boolean,\n        fileDragged: boolean,\n        multiple: boolean,\n        label: PolymorpheusContent,\n    ): Observable<PolymorpheusContent> {\n        if (isMobile) {\n            return of('');\n        }\n\n        if (fileDragged) {\n            return this.inputFileTexts$.pipe(\n                map(texts => (multiple ? texts.dropMultiple : texts.drop)),\n            );\n        }\n\n        return this.inputFileTexts$.pipe(\n            map(texts =>\n                multiple && label === ''\n                    ? texts.defaultLabelMultiple\n                    : label || texts.defaultLabelSingle,\n            ),\n        );\n    }\n\n    @tuiPure\n    private getValueArray(\n        value: TuiFileLike | readonly TuiFileLike[] | null,\n    ): readonly TuiFileLike[] {\n        if (!value) {\n            return EMPTY_ARRAY;\n        }\n\n        return Array.isArray(value) ? value : [value];\n    }\n\n    private processSelectedFiles(files: FileList | null): void {\n        // IE11 after selecting a file through the open dialog generates a second event passing an empty FileList.\n        if (!files?.length) {\n            return;\n        }\n\n        const errors: Record<\n            'formatRejection' | 'maxSizeRejection',\n            PolymorpheusContent\n        > = {\n            formatRejection: this.formatRejection,\n            maxSizeRejection: this.maxSizeRejection,\n        };\n\n        const newFiles = this.computedMultiple ? Array.from(files) : [files[0]];\n        const tooBigFiles = newFiles.filter(file => file.size > this.maxFileSize);\n        const wrongFormatFiles = newFiles.filter(\n            file => !this.isFormatAcceptable(file) && !tooBigFiles.includes(file),\n        );\n        const acceptedFiles = newFiles.filter(\n            file => !tooBigFiles.includes(file) && !wrongFormatFiles.includes(file),\n        );\n\n        if (tooBigFiles.length || wrongFormatFiles.length) {\n            this.rejectFiles([\n                ...tooBigFiles.map(file => ({\n                    name: file.name,\n                    type: file.type,\n                    size: file.size,\n                    content: errors.maxSizeRejection,\n                })),\n                ...wrongFormatFiles.map(file => ({\n                    name: file.name,\n                    type: file.type,\n                    size: file.size,\n                    content: errors.formatRejection,\n                })),\n            ]);\n        }\n\n        this.updateValue(\n            this.computedMultiple\n                ? [...this.arrayValue, ...acceptedFiles]\n                : acceptedFiles[0] || null,\n        );\n    }\n\n    private isFormatAcceptable(file: File): boolean {\n        if (!this.computedAccept) {\n            return true;\n        }\n\n        const extension = `.${(file.name.split('.').pop() || '').toLowerCase()}`;\n\n        return tuiGetAcceptArray(this.computedAccept).some(\n            format =>\n                format === extension ||\n                format === file.type ||\n                (format.split('/')[1] === '*' &&\n                    file.type.split('/')[0] === format.split('/')[0]),\n        );\n    }\n\n    private rejectFiles(rejectedFiles: readonly TuiFileLike[]): void {\n        this.reject.emit(this.computedMultiple ? rejectedFiles : rejectedFiles[0]);\n    }\n}\n","<div\n    tuiWrapper\n    appearance=\"input-file\"\n    class=\"t-wrapper\"\n    [class._mobile]=\"isMobile\"\n    [focus]=\"computedFocused\"\n    [hover]=\"pseudoHover || fileDragged || null\"\n    [active]=\"pseudoActive\"\n    [disabled]=\"computedDisabled\"\n>\n    <label\n        automation-id=\"tui-input-file__label\"\n        class=\"t-label\"\n        (tuiDroppableDropped)=\"onDropped($event)\"\n        (tuiDroppableDragOverChange)=\"onDragOver($event)\"\n        (mousedown.prevent.silent)=\"(0)\"\n    >\n        <ng-container *ngTemplateOutlet=\"template || null; context: {$implicit: fileDragged}\"></ng-container>\n        <ng-container *ngIf=\"!template\">\n            <a tuiLink>\n                <ng-container *polymorpheusOutlet=\"computedLink$ | async as text\">\n                    {{ text }}\n                </ng-container>\n            </a>\n            <ng-container *polymorpheusOutlet=\"computedLabel$ | async as text\">\n                {{ text }}\n            </ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!readOnly && !computedDisabled\">\n            <ng-content select=\"input\"></ng-content>\n            <input\n                #input\n                type=\"file\"\n                class=\"t-native\"\n                [id]=\"id\"\n                [accept]=\"accept\"\n                [multiple]=\"multiple\"\n                [tuiFocusable]=\"focusable\"\n            />\n        </ng-container>\n    </label>\n</div>\n\n<ng-template #formatRejection>\n    {{ (inputFileTexts$ | async)?.formatRejectionReason || '' }}\n</ng-template>\n\n<ng-template #maxSizeRejection>\n    {{ maxFileSize | tuiMaxSizeRejectionError | async }}\n</ng-template>\n"]}
@@ -10,7 +10,7 @@ export class TuiMaxSizeRejectionErrorPipe {
10
10
  this.units$ = units$;
11
11
  }
12
12
  transform(maxFileSize) {
13
- return combineLatest([this.inputFileTexts$, this.units$]).pipe(map(([{ maxSizeRejectionReason }, units]) => maxSizeRejectionReason + tuiFormatSize(units, maxFileSize)));
13
+ return combineLatest([this.inputFileTexts$, this.units$]).pipe(map(([{ maxSizeRejectionReason }, units]) => `${maxSizeRejectionReason}${tuiFormatSize(units, maxFileSize)}`));
14
14
  }
15
15
  }
16
16
  TuiMaxSizeRejectionErrorPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiMaxSizeRejectionErrorPipe, deps: [{ token: TUI_INPUT_FILE_TEXTS }, { token: TUI_DIGITAL_INFORMATION_UNITS }], target: i0.ɵɵFactoryTarget.Pipe });
@@ -25,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
25
25
  type: Inject,
26
26
  args: [TUI_DIGITAL_INFORMATION_UNITS]
27
27
  }] }]; } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF4LXNpemUtcmVqZWN0aW9uLWVycm9yLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1maWxlcy9tYXgtc2l6ZS1yZWplY3Rpb24tZXJyb3IucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBZ0IsTUFBTSxlQUFlLENBQUM7QUFFMUQsT0FBTyxFQUFDLDZCQUE2QixFQUFFLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDekYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ2xELE9BQU8sRUFBQyxhQUFhLEVBQWEsTUFBTSxNQUFNLENBQUM7QUFDL0MsT0FBTyxFQUFDLEdBQUcsRUFBQyxNQUFNLGdCQUFnQixDQUFDOztBQUduQyxNQUFNLE9BQU8sNEJBQTRCO0lBQ3JDLFlBRXFCLGVBRWhCLEVBRWdCLE1BRWhCO1FBTmdCLG9CQUFlLEdBQWYsZUFBZSxDQUUvQjtRQUVnQixXQUFNLEdBQU4sTUFBTSxDQUV0QjtJQUNGLENBQUM7SUFFSixTQUFTLENBQUMsV0FBbUI7UUFDekIsT0FBTyxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDMUQsR0FBRyxDQUNDLENBQUMsQ0FBQyxFQUFDLHNCQUFzQixFQUFDLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUNsQyxzQkFBc0IsR0FBRyxhQUFhLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUNqRSxDQUNKLENBQUM7SUFDTixDQUFDOzswSEFuQlEsNEJBQTRCLGtCQUV6QixvQkFBb0IsYUFJcEIsNkJBQTZCO3dIQU5oQyw0QkFBNEI7NEZBQTVCLDRCQUE0QjtrQkFEeEMsSUFBSTttQkFBQyxFQUFDLElBQUksRUFBRSwwQkFBMEIsRUFBQzs7MEJBRy9CLE1BQU07MkJBQUMsb0JBQW9COzswQkFJM0IsTUFBTTsyQkFBQyw2QkFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgUGlwZSwgUGlwZVRyYW5zZm9ybX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1R1aUluamVjdGlvblRva2VuVHlwZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1RVSV9ESUdJVEFMX0lORk9STUFUSU9OX1VOSVRTLCBUVUlfSU5QVVRfRklMRV9URVhUU30gZnJvbSAnQHRhaWdhLXVpL2tpdC90b2tlbnMnO1xuaW1wb3J0IHt0dWlGb3JtYXRTaXplfSBmcm9tICdAdGFpZ2EtdWkva2l0L3V0aWxzJztcbmltcG9ydCB7Y29tYmluZUxhdGVzdCwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge21hcH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5AUGlwZSh7bmFtZTogYHR1aU1heFNpemVSZWplY3Rpb25FcnJvcmB9KVxuZXhwb3J0IGNsYXNzIFR1aU1heFNpemVSZWplY3Rpb25FcnJvclBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChUVUlfSU5QVVRfRklMRV9URVhUUylcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBpbnB1dEZpbGVUZXh0cyQ6IFR1aUluamVjdGlvblRva2VuVHlwZTxcbiAgICAgICAgICAgIHR5cGVvZiBUVUlfSU5QVVRfRklMRV9URVhUU1xuICAgICAgICA+LFxuICAgICAgICBASW5qZWN0KFRVSV9ESUdJVEFMX0lORk9STUFUSU9OX1VOSVRTKVxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IHVuaXRzJDogVHVpSW5qZWN0aW9uVG9rZW5UeXBlPFxuICAgICAgICAgICAgdHlwZW9mIFRVSV9ESUdJVEFMX0lORk9STUFUSU9OX1VOSVRTXG4gICAgICAgID4sXG4gICAgKSB7fVxuXG4gICAgdHJhbnNmb3JtKG1heEZpbGVTaXplOiBudW1iZXIpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuICAgICAgICByZXR1cm4gY29tYmluZUxhdGVzdChbdGhpcy5pbnB1dEZpbGVUZXh0cyQsIHRoaXMudW5pdHMkXSkucGlwZShcbiAgICAgICAgICAgIG1hcChcbiAgICAgICAgICAgICAgICAoW3ttYXhTaXplUmVqZWN0aW9uUmVhc29ufSwgdW5pdHNdKSA9PlxuICAgICAgICAgICAgICAgICAgICBtYXhTaXplUmVqZWN0aW9uUmVhc29uICsgdHVpRm9ybWF0U2l6ZSh1bml0cywgbWF4RmlsZVNpemUpLFxuICAgICAgICAgICAgKSxcbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF4LXNpemUtcmVqZWN0aW9uLWVycm9yLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1maWxlcy9tYXgtc2l6ZS1yZWplY3Rpb24tZXJyb3IucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBZ0IsTUFBTSxlQUFlLENBQUM7QUFFMUQsT0FBTyxFQUFDLDZCQUE2QixFQUFFLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDekYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ2xELE9BQU8sRUFBQyxhQUFhLEVBQWEsTUFBTSxNQUFNLENBQUM7QUFDL0MsT0FBTyxFQUFDLEdBQUcsRUFBQyxNQUFNLGdCQUFnQixDQUFDOztBQUduQyxNQUFNLE9BQU8sNEJBQTRCO0lBQ3JDLFlBRXFCLGVBRWhCLEVBRWdCLE1BRWhCO1FBTmdCLG9CQUFlLEdBQWYsZUFBZSxDQUUvQjtRQUVnQixXQUFNLEdBQU4sTUFBTSxDQUV0QjtJQUNGLENBQUM7SUFFSixTQUFTLENBQUMsV0FBbUI7UUFDekIsT0FBTyxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDMUQsR0FBRyxDQUNDLENBQUMsQ0FBQyxFQUFDLHNCQUFzQixFQUFDLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUNsQyxHQUFHLHNCQUFzQixHQUFHLGFBQWEsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLEVBQUUsQ0FDdEUsQ0FDSixDQUFDO0lBQ04sQ0FBQzs7MEhBbkJRLDRCQUE0QixrQkFFekIsb0JBQW9CLGFBSXBCLDZCQUE2Qjt3SEFOaEMsNEJBQTRCOzRGQUE1Qiw0QkFBNEI7a0JBRHhDLElBQUk7bUJBQUMsRUFBQyxJQUFJLEVBQUUsMEJBQTBCLEVBQUM7OzBCQUcvQixNQUFNOzJCQUFDLG9CQUFvQjs7MEJBSTNCLE1BQU07MkJBQUMsNkJBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3QsIFBpcGUsIFBpcGVUcmFuc2Zvcm19IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlJbmplY3Rpb25Ub2tlblR5cGV9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtUVUlfRElHSVRBTF9JTkZPUk1BVElPTl9VTklUUywgVFVJX0lOUFVUX0ZJTEVfVEVYVFN9IGZyb20gJ0B0YWlnYS11aS9raXQvdG9rZW5zJztcbmltcG9ydCB7dHVpRm9ybWF0U2l6ZX0gZnJvbSAnQHRhaWdhLXVpL2tpdC91dGlscyc7XG5pbXBvcnQge2NvbWJpbmVMYXRlc3QsIE9ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHttYXB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQFBpcGUoe25hbWU6IGB0dWlNYXhTaXplUmVqZWN0aW9uRXJyb3JgfSlcbmV4cG9ydCBjbGFzcyBUdWlNYXhTaXplUmVqZWN0aW9uRXJyb3JQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIEBJbmplY3QoVFVJX0lOUFVUX0ZJTEVfVEVYVFMpXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgaW5wdXRGaWxlVGV4dHMkOiBUdWlJbmplY3Rpb25Ub2tlblR5cGU8XG4gICAgICAgICAgICB0eXBlb2YgVFVJX0lOUFVUX0ZJTEVfVEVYVFNcbiAgICAgICAgPixcbiAgICAgICAgQEluamVjdChUVUlfRElHSVRBTF9JTkZPUk1BVElPTl9VTklUUylcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSB1bml0cyQ6IFR1aUluamVjdGlvblRva2VuVHlwZTxcbiAgICAgICAgICAgIHR5cGVvZiBUVUlfRElHSVRBTF9JTkZPUk1BVElPTl9VTklUU1xuICAgICAgICA+LFxuICAgICkge31cblxuICAgIHRyYW5zZm9ybShtYXhGaWxlU2l6ZTogbnVtYmVyKTogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcbiAgICAgICAgcmV0dXJuIGNvbWJpbmVMYXRlc3QoW3RoaXMuaW5wdXRGaWxlVGV4dHMkLCB0aGlzLnVuaXRzJF0pLnBpcGUoXG4gICAgICAgICAgICBtYXAoXG4gICAgICAgICAgICAgICAgKFt7bWF4U2l6ZVJlamVjdGlvblJlYXNvbn0sIHVuaXRzXSkgPT5cbiAgICAgICAgICAgICAgICAgICAgYCR7bWF4U2l6ZVJlamVjdGlvblJlYXNvbn0ke3R1aUZvcm1hdFNpemUodW5pdHMsIG1heEZpbGVTaXplKX1gLFxuICAgICAgICAgICAgKSxcbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=