@ptsecurity/mosaic 17.2.13 → 17.2.14

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 (42) hide show
  1. package/core/forms/index.d.ts +1 -0
  2. package/core/forms/validators.d.ts +22 -0
  3. package/core/pop-up/constants.d.ts +13 -0
  4. package/core/pop-up/pop-up-trigger.d.ts +14 -1
  5. package/core/styles/theming/_theming.scss +1 -0
  6. package/esm2022/core/forms/index.mjs +2 -1
  7. package/esm2022/core/forms/validators.mjs +33 -0
  8. package/esm2022/core/pop-up/constants.mjs +10 -1
  9. package/esm2022/core/pop-up/pop-up-trigger.mjs +45 -3
  10. package/esm2022/core/version.mjs +2 -2
  11. package/esm2022/file-upload/file-upload.mjs +39 -2
  12. package/esm2022/file-upload/file-upload.module.mjs +8 -1
  13. package/esm2022/file-upload/multiple-file-upload.component.mjs +129 -37
  14. package/esm2022/file-upload/single-file-upload.component.mjs +124 -46
  15. package/esm2022/popover/popover.component.mjs +2 -2
  16. package/esm2022/select/select.component.mjs +6 -4
  17. package/esm2022/tooltip/tooltip.component.mjs +5 -2
  18. package/esm2022/tree-select/tree-select.component.mjs +6 -4
  19. package/fesm2022/ptsecurity-mosaic-core.mjs +86 -3
  20. package/fesm2022/ptsecurity-mosaic-core.mjs.map +1 -1
  21. package/fesm2022/ptsecurity-mosaic-file-upload.mjs +282 -72
  22. package/fesm2022/ptsecurity-mosaic-file-upload.mjs.map +1 -1
  23. package/fesm2022/ptsecurity-mosaic-popover.mjs +1 -1
  24. package/fesm2022/ptsecurity-mosaic-popover.mjs.map +1 -1
  25. package/fesm2022/ptsecurity-mosaic-select.mjs +5 -3
  26. package/fesm2022/ptsecurity-mosaic-select.mjs.map +1 -1
  27. package/fesm2022/ptsecurity-mosaic-tooltip.mjs +5 -2
  28. package/fesm2022/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  29. package/fesm2022/ptsecurity-mosaic-tree-select.mjs +5 -3
  30. package/fesm2022/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  31. package/file-upload/_file-upload-theme.scss +21 -11
  32. package/file-upload/file-upload.d.ts +31 -3
  33. package/file-upload/file-upload.module.d.ts +11 -10
  34. package/file-upload/file-upload.scss +8 -1
  35. package/file-upload/multiple-file-upload.component.d.ts +54 -13
  36. package/file-upload/multiple-file-upload.component.scss +0 -8
  37. package/file-upload/single-file-upload.component.d.ts +49 -14
  38. package/file-upload/single-file-upload.component.scss +0 -8
  39. package/package.json +45 -45
  40. package/prebuilt-themes/dark-theme.css +1 -1
  41. package/prebuilt-themes/default-theme.css +1 -1
  42. package/tooltip/tooltip.component.d.ts +2 -1
@@ -1,45 +1,121 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, Input, Optional, Output, Renderer2, ViewChild } from '@angular/core';
2
- import { MC_LOCALE_SERVICE, McLocaleService, ruRULocaleData } from '@ptsecurity/mosaic/core';
3
- import { BehaviorSubject, Subscription } from 'rxjs';
4
- import { MC_FILE_UPLOAD_CONFIGURATION } from './file-upload';
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Inject, Input, Optional, Output, QueryList, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
+ import { ErrorStateMatcher, ruRULocaleData } from '@ptsecurity/mosaic/core';
4
+ import { McHint } from '@ptsecurity/mosaic/form-field';
5
+ import { BehaviorSubject } from 'rxjs';
6
+ import { distinctUntilChanged } from 'rxjs/operators';
7
+ import { MC_FILE_UPLOAD_CONFIGURATION, McFileUploadBase } from './file-upload';
5
8
  import * as i0 from "@angular/core";
6
9
  import * as i1 from "@angular/common";
7
10
  import * as i2 from "@ptsecurity/mosaic/progress-spinner";
8
11
  import * as i3 from "@ptsecurity/mosaic/icon";
9
12
  import * as i4 from "@ptsecurity/mosaic/button";
10
- import * as i5 from "@ptsecurity/mosaic/form-field";
11
- import * as i6 from "@ptsecurity/mosaic/ellipsis-center";
12
- import * as i7 from "@ptsecurity/mosaic/link";
13
- import * as i8 from "./file-drop";
14
- import * as i9 from "@ptsecurity/mosaic/core";
13
+ import * as i5 from "@ptsecurity/mosaic/ellipsis-center";
14
+ import * as i6 from "@ptsecurity/mosaic/link";
15
+ import * as i7 from "./file-drop";
15
16
  let nextSingleFileUploadUniqueId = 0;
16
17
  export const MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION = ruRULocaleData['ru-RU'].fileUpload.single;
17
- export class McSingleFileUploadComponent {
18
+ export class McSingleFileUploadComponent extends McFileUploadBase {
19
+ get file() {
20
+ return this._file;
21
+ }
22
+ set file(currentFile) {
23
+ this._file = currentFile;
24
+ this.cvaOnChange(this._file);
25
+ this.fileQueueChanged.emit(this._file);
26
+ this.cdr.markForCheck();
27
+ }
18
28
  get acceptedFiles() {
19
29
  return this.accept && this.accept.length > 0 ? this.accept.map((ext) => `.${ext}`).join(',') : '*/*';
20
30
  }
21
- constructor(renderer, cdr, configuration, localeService) {
22
- this.renderer = renderer;
23
- this.cdr = cdr;
31
+ get hasHint() {
32
+ return this.hint.length > 0;
33
+ }
34
+ /**
35
+ * Indicates an invalid state based on `errorState`,
36
+ * applying a CSS class in HTML for visual feedback.
37
+ */
38
+ get invalid() {
39
+ return !!this.file?.hasError || this.errorState;
40
+ }
41
+ constructor(configuration) {
42
+ super();
24
43
  this.configuration = configuration;
25
- this.localeService = localeService;
44
+ this._file = null;
26
45
  this.disabled = false;
46
+ /**
47
+ * @deprecated use `FormControl.errors`
48
+ */
27
49
  this.errors = [];
28
- this.files = [];
29
50
  this.inputId = `mc-single-file-upload-${nextSingleFileUploadUniqueId++}`;
30
51
  this.fileQueueChanged = new EventEmitter();
52
+ /** cvaOnChange function registered via registerOnChange (ControlValueAccessor).
53
+ * @docs-private
54
+ */
55
+ // tslint:disable-next-line:no-empty
56
+ this.cvaOnChange = (_) => { };
57
+ /** onTouch function registered via registerOnTouch (ControlValueAccessor).
58
+ * @docs-private
59
+ */
60
+ // tslint:disable-next-line:no-empty
61
+ this.onTouched = () => { };
31
62
  this.updateLocaleParams = () => {
32
63
  this.config = this.configuration || this.localeService?.getParams('fileUpload').multiple;
33
64
  this.makeCaptionText();
34
65
  this.cdr.markForCheck();
35
66
  };
36
- this.localeSubscription = this.localeService?.changes.subscribe(this.updateLocaleParams) || Subscription.EMPTY;
37
- if (!localeService) {
67
+ this.localeService?.changes.pipe(takeUntilDestroyed())
68
+ .subscribe(this.updateLocaleParams);
69
+ if (!this.localeService) {
38
70
  this.initDefaultParams();
39
71
  }
72
+ if (this.ngControl) {
73
+ // Note: we provide the value accessor through here, instead of
74
+ // the `providers` to avoid running into a circular import.
75
+ this.ngControl.valueAccessor = this;
76
+ }
40
77
  }
41
- ngOnDestroy() {
42
- this.localeSubscription.unsubscribe();
78
+ ngAfterViewInit() {
79
+ // FormControl specific errors update
80
+ this.ngControl?.statusChanges?.pipe(distinctUntilChanged(), takeUntilDestroyed(this.destroyRef))
81
+ .subscribe((status) => {
82
+ if (this._file) {
83
+ this._file.hasError = status === 'INVALID';
84
+ }
85
+ this.errors = Object.values(this.ngControl?.errors || {});
86
+ this.cdr.markForCheck();
87
+ });
88
+ this.stateChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => this.cdr.markForCheck());
89
+ }
90
+ ngDoCheck() {
91
+ if (this.ngControl) {
92
+ // We need to re-evaluate this on every change detection cycle, because there are some
93
+ // error triggers that we can't subscribe to (e.g. parent form submissions). This means
94
+ // that whatever logic is in here has to be super lean or we risk destroying the performance.
95
+ this.updateErrorState();
96
+ }
97
+ }
98
+ /** Implemented as part of ControlValueAccessor. @docs-private */
99
+ writeValue(file) {
100
+ if (file instanceof File) {
101
+ this.file = this.mapToFileItem(file);
102
+ }
103
+ else {
104
+ this.file = file;
105
+ }
106
+ }
107
+ /** Implemented as part of ControlValueAccessor. @docs-private */
108
+ registerOnChange(fn) { this.cvaOnChange = fn; }
109
+ /** Implemented as part of ControlValueAccessor. @docs-private */
110
+ registerOnTouched(fn) { this.onTouched = fn; }
111
+ /**
112
+ * Sets the disabled state of the control. Implemented as a part of ControlValueAccessor.
113
+ * @param isDisabled Whether the control should be disabled.
114
+ * @docs-private
115
+ */
116
+ setDisabledState(isDisabled) {
117
+ this.disabled = isDisabled;
118
+ this.cdr.markForCheck();
43
119
  }
44
120
  onFileSelectedViaClick({ target }) {
45
121
  if (this.disabled) {
@@ -47,9 +123,9 @@ export class McSingleFileUploadComponent {
47
123
  }
48
124
  const files = target.files;
49
125
  if (files?.length) {
50
- this.files = [this.mapToFileItem(files[0])];
51
- this.fileQueueChanged.emit(this.files[0]);
126
+ this.file = this.mapToFileItem(files[0]);
52
127
  }
128
+ this.onTouched();
53
129
  /* even if the user selects the same file,
54
130
  the onchange event will be triggered every time user clicks on the control.*/
55
131
  this.renderer.setProperty(this.input.nativeElement, 'value', null);
@@ -59,19 +135,20 @@ export class McSingleFileUploadComponent {
59
135
  return;
60
136
  }
61
137
  event?.stopPropagation();
62
- this.files = [];
138
+ this.file = null;
63
139
  this.errors = [];
64
- this.fileQueueChanged.emit(null);
140
+ // mark as touched after file drop even if file wasn't correct
141
+ this.onTouched();
65
142
  }
66
143
  onFileDropped(files) {
67
144
  if (this.disabled) {
68
145
  return;
69
146
  }
70
- if (this.isCorrectExtension(files[0])) {
71
- this.files = Array.from(files)
72
- .map((file) => this.mapToFileItem(file));
73
- this.fileQueueChanged.emit(this.files[0]);
147
+ if (files?.length && this.isCorrectExtension(files[0])) {
148
+ this.file = this.mapToFileItem(files[0]);
74
149
  }
150
+ // mark as touched after file drop even if file wasn't correct
151
+ this.onTouched();
75
152
  }
76
153
  mapToFileItem(file) {
77
154
  this.validateFile(file);
@@ -82,12 +159,13 @@ export class McSingleFileUploadComponent {
82
159
  };
83
160
  }
84
161
  validateFile(file) {
85
- if (this.customValidation && this.customValidation.length) {
86
- this.errors = this.customValidation.reduce((errors, validatorFn) => {
87
- errors.push(validatorFn(file));
88
- return errors;
89
- }, []).filter(Boolean);
162
+ if (!this.customValidation?.length) {
163
+ return;
90
164
  }
165
+ this.errors = this.customValidation.reduce((errors, validatorFn) => {
166
+ errors.push(validatorFn(file));
167
+ return errors;
168
+ }, []).filter(Boolean);
91
169
  }
92
170
  isCorrectExtension(file) {
93
171
  const fileExt = file.name.split('.').pop() || '';
@@ -100,40 +178,40 @@ export class McSingleFileUploadComponent {
100
178
  makeCaptionText() {
101
179
  this.separatedCaptionText = this.config.captionText.split('{{ browseLink }}');
102
180
  }
103
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McSingleFileUploadComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: MC_FILE_UPLOAD_CONFIGURATION, optional: true }, { token: MC_LOCALE_SERVICE, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
104
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.0", type: McSingleFileUploadComponent, selector: "mc-single-file-upload", inputs: { accept: "accept", disabled: "disabled", errors: "errors", files: "files", inputId: "inputId", customValidation: "customValidation" }, outputs: { fileQueueChanged: "fileQueueChanged" }, host: { classAttribute: "mc-single-file-upload" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<div class=\"mc-file-upload\"\n mcFileDrop\n [class.disabled]=\"disabled\"\n [class.mc-error]=\"errors && errors.length\"\n (filesDropped)=\"onFileDropped($event)\">\n <div class=\"dropzone\" *ngIf=\"!files.length; else fileOutput\">\n <i mc-icon=\"mc-upload-to-cloud_24\"></i>\n <span class=\"dropzone__text\">\n {{ separatedCaptionText[0] }}<label mc-link pseudo [disabled]=\"disabled\" [tabIndex]=\"-1\" [for]=\"inputId\">{{ config.browseLink }}<input #input type=\"file\" class=\"cdk-visually-hidden\" [id]=\"inputId\" [accept]=\"acceptedFiles\" [disabled]=\"disabled\" (change)=\"onFileSelectedViaClick($event)\"></label>{{ separatedCaptionText[1] }}\n </span>\n </div>\n</div>\n\n<mc-hint class=\"mc-file-upload__hint\">\n <ng-content select=\"[hint]\"></ng-content>\n</mc-hint>\n<ng-container *ngIf=\"errors && errors.length\">\n <mc-hint class=\"mc-file-upload__hint mc-error\" *ngFor=\"let error of errors\">{{ error }}</mc-hint>\n</ng-container>\n\n\n<ng-template #fileOutput>\n <div class=\"file-item\" *ngIf=\"files && files.length\">\n <div class=\"file-item__text-wrapper\">\n <ng-container *ngIf=\"{ loading: files[0].loading | async, progress: files[0].progress | async} as asyncData\">\n <ng-container *ngIf=\"!asyncData.loading\">\n <ng-content select=\"[mc-icon]\"></ng-content>\n </ng-container>\n\n <mc-progress-spinner\n [value]=\"asyncData.progress || 0\"\n *ngIf=\"asyncData.loading\"\n ></mc-progress-spinner>\n </ng-container>\n\n <div class=\"file-item__text\" [mcEllipsisCenter]=\"files[0].file.name\" [minVisibleLength]=\"10\"></div>\n </div>\n <button mc-button\n class=\"mc-button_transparent\"\n [disabled]=\"disabled\"\n (keydown.delete)=\"deleteItem()\"\n (keydown.backspace)=\"deleteItem()\"\n (click)=\"deleteItem($event)\">\n <i mc-icon=\"mc-close-circle_16\"></i>\n </button>\n </div>\n</ng-template>\n", styles: [".mc-file-upload{box-sizing:border-box;display:flex;align-items:center;position:relative}.mc-file-upload .dropzone,.mc-file-upload .file-item{display:flex;align-items:center}.mc-file-upload .mc-ellipsis-center{position:relative;display:flex}.mc-file-upload .mc-ellipsis-center .data-text-start{flex:0 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:pre}.mc-file-upload .mc-ellipsis-center .data-text-end{flex:1 0 auto;overflow:hidden;white-space:pre}\n", "@keyframes mc-progress{0%{background-position:0 0}to{background-position:29px 0}}.mc-progress{position:relative}.mc-progress:after{content:\"\";position:absolute;border-radius:inherit;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.05) 10px,transparent 10px,transparent 20px,rgba(0,0,0,.05) 20px,rgba(0,0,0,.05) 30px,transparent 30px) repeat;background-size:29px 29px;animation:mc-progress 1s linear infinite}.mc-group{display:flex;flex-direction:row}.mc-group .mc-group_justified>.mc-group-item{width:100%}.mc-group .mc-group-item+.mc-group-item{margin-left:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group{display:flex;flex-direction:column}.mc-vertical-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-bottom-left-radius:0;border-top-right-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-bottom-left-radius:0}.mc-vertical-group>.mc-group-item:last-child:not(:first-child){border-top-right-radius:0;border-top-left-radius:0;border-bottom-left-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-top-right-radius:0;border-top-left-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group .mc-group-item+.mc-group-item{margin-top:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.mc-file-upload{height:var(--mc-file-upload-size-single-height, 48px);padding-top:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-bottom:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-left:var(--mc-size-m, 12px);border-radius:var(--mc-file-upload-size-single-border-radius, 4px);border-width:var(--mc-file-upload-size-single-border-width, 1px);border-style:var(--mc-file-upload-size-single-border-style, dashed)}.mc-file-upload .dropzone .dropzone__text{margin-left:var(--mc-size-xs, 6px)}.mc-file-upload .file-item{width:100%}.mc-file-upload .file-item .file-item__text-wrapper{display:flex;align-items:center;width:100%}.mc-file-upload .file-item .file-item__text-wrapper .file-item__text{margin-left:var(--mc-size-s, 8px);width:120px;flex-grow:1}.mc-hint{display:block}.mc-file-upload__hint{margin-top:var(--mc-form-field-hint-size-margin-top, 4px)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.McProgressSpinner, selector: "mc-progress-spinner", inputs: ["color", "id", "value", "mode", "size"] }, { kind: "component", type: i3.McIcon, selector: "[mc-icon]", inputs: ["color"] }, { kind: "directive", type: i3.McIconCSSStyler, selector: "[mc-icon]" }, { kind: "component", type: i4.McButton, selector: "[mc-button]", inputs: ["color", "tabIndex", "disabled"] }, { kind: "directive", type: i4.McButtonCssStyler, selector: "[mc-button]" }, { kind: "directive", type: i5.McHint, selector: "mc-hint", inputs: ["color", "id"] }, { kind: "directive", type: i6.McEllipsisCenterDirective, selector: "[mcEllipsisCenter]", inputs: ["mcEllipsisCenter", "minVisibleLength"] }, { kind: "directive", type: i7.McLink, selector: "[mc-link]", inputs: ["tabIndex", "disabled", "pseudo", "noUnderline", "caption", "useVisited", "print"], exportAs: ["mcLink"] }, { kind: "directive", type: i8.McFileDropDirective, selector: "[mcFileDrop]", outputs: ["filesDropped"], exportAs: ["mcFileDrop"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
181
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McSingleFileUploadComponent, deps: [{ token: MC_FILE_UPLOAD_CONFIGURATION, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
182
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.0", type: McSingleFileUploadComponent, selector: "mc-single-file-upload", inputs: { file: "file", accept: "accept", disabled: "disabled", errors: "errors", inputId: "inputId", customValidation: "customValidation", errorStateMatcher: "errorStateMatcher" }, outputs: { fileQueueChanged: "fileQueueChanged" }, host: { classAttribute: "mc-single-file-upload" }, queries: [{ propertyName: "hint", predicate: McHint }], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"mc-file-upload\"\n mcFileDrop\n [class.disabled]=\"disabled\"\n [class.mc-error]=\"invalid\"\n (filesDropped)=\"onFileDropped($event)\">\n <div class=\"dropzone\" *ngIf=\"!file; else fileOutput\">\n <i mc-icon=\"mc-upload-to-cloud_24\"></i>\n <span class=\"dropzone__text\">\n {{ separatedCaptionText[0] }}<label mc-link pseudo [disabled]=\"disabled\" [tabIndex]=\"-1\" [for]=\"inputId\">{{ config.browseLink }}<input #input type=\"file\" class=\"cdk-visually-hidden\" [id]=\"inputId\" [accept]=\"acceptedFiles\" [disabled]=\"disabled\" (change)=\"onFileSelectedViaClick($event)\"></label>{{ separatedCaptionText[1] }}\n </span>\n </div>\n</div>\n\n<ng-container *ngIf=\"hasHint\">\n <div class=\"mc-file-upload__hint\">\n <ng-content select=\"mc-hint,[hint]\" />\n </div>\n</ng-container>\n\n<ng-template #fileOutput>\n <div class=\"file-item\" *ngIf=\"file\">\n <div class=\"file-item__text-wrapper\">\n <ng-container *ngIf=\"{ loading: file.loading | async, progress: file.progress | async} as asyncData\">\n <ng-container *ngIf=\"!asyncData.loading\">\n <ng-content select=\"[mc-icon]\"></ng-content>\n </ng-container>\n\n <mc-progress-spinner\n [value]=\"asyncData.progress || 0\"\n *ngIf=\"asyncData.loading\"\n ></mc-progress-spinner>\n </ng-container>\n\n <div class=\"file-item__text\" [mcEllipsisCenter]=\"file.file.name\" [minVisibleLength]=\"10\"></div>\n </div>\n <button mc-button\n class=\"mc-button_transparent\"\n [disabled]=\"disabled\"\n (keydown.delete)=\"deleteItem()\"\n (keydown.backspace)=\"deleteItem()\"\n (click)=\"deleteItem($event)\">\n <i mc-icon=\"mc-close-circle_16\"></i>\n </button>\n </div>\n</ng-template>\n", styles: [".mc-file-upload{box-sizing:border-box;display:flex;align-items:center;position:relative}.mc-file-upload .dropzone,.mc-file-upload .file-item{display:flex;align-items:center}.mc-file-upload .mc-ellipsis-center{position:relative;display:flex}.mc-file-upload .mc-ellipsis-center .data-text-start{flex:0 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:pre}.mc-file-upload .mc-ellipsis-center .data-text-end{flex:1 0 auto;overflow:hidden;white-space:pre}.mc-file-upload__hint>.mc-hint{margin-top:var(--mc-form-field-hint-size-margin-top, 4px)}\n", "@keyframes mc-progress{0%{background-position:0 0}to{background-position:29px 0}}.mc-progress{position:relative}.mc-progress:after{content:\"\";position:absolute;border-radius:inherit;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.05) 10px,transparent 10px,transparent 20px,rgba(0,0,0,.05) 20px,rgba(0,0,0,.05) 30px,transparent 30px) repeat;background-size:29px 29px;animation:mc-progress 1s linear infinite}.mc-group{display:flex;flex-direction:row}.mc-group .mc-group_justified>.mc-group-item{width:100%}.mc-group .mc-group-item+.mc-group-item{margin-left:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group{display:flex;flex-direction:column}.mc-vertical-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-bottom-left-radius:0;border-top-right-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-bottom-left-radius:0}.mc-vertical-group>.mc-group-item:last-child:not(:first-child){border-top-right-radius:0;border-top-left-radius:0;border-bottom-left-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-top-right-radius:0;border-top-left-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group .mc-group-item+.mc-group-item{margin-top:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.mc-file-upload{height:var(--mc-file-upload-size-single-height, 48px);padding-top:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-bottom:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-left:var(--mc-size-m, 12px);border-radius:var(--mc-file-upload-size-single-border-radius, 4px);border-width:var(--mc-file-upload-size-single-border-width, 1px);border-style:var(--mc-file-upload-size-single-border-style, dashed)}.mc-file-upload .dropzone .dropzone__text{margin-left:var(--mc-size-xs, 6px)}.mc-file-upload .file-item{width:100%}.mc-file-upload .file-item .file-item__text-wrapper{display:flex;align-items:center;width:100%}.mc-file-upload .file-item .file-item__text-wrapper .file-item__text{margin-left:var(--mc-size-s, 8px);width:120px;flex-grow:1}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.McProgressSpinner, selector: "mc-progress-spinner", inputs: ["color", "id", "value", "mode", "size"] }, { kind: "component", type: i3.McIcon, selector: "[mc-icon]", inputs: ["color"] }, { kind: "directive", type: i3.McIconCSSStyler, selector: "[mc-icon]" }, { kind: "component", type: i4.McButton, selector: "[mc-button]", inputs: ["color", "tabIndex", "disabled"] }, { kind: "directive", type: i4.McButtonCssStyler, selector: "[mc-button]" }, { kind: "directive", type: i5.McEllipsisCenterDirective, selector: "[mcEllipsisCenter]", inputs: ["mcEllipsisCenter", "minVisibleLength"] }, { kind: "directive", type: i6.McLink, selector: "[mc-link]", inputs: ["tabIndex", "disabled", "pseudo", "noUnderline", "caption", "useVisited", "print"], exportAs: ["mcLink"] }, { kind: "directive", type: i7.McFileDropDirective, selector: "[mcFileDrop]", outputs: ["filesDropped"], exportAs: ["mcFileDrop"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
105
183
  }
106
184
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McSingleFileUploadComponent, decorators: [{
107
185
  type: Component,
108
- args: [{ selector: 'mc-single-file-upload', changeDetection: ChangeDetectionStrategy.OnPush, host: {
186
+ args: [{ selector: 'mc-single-file-upload', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
109
187
  class: 'mc-single-file-upload'
110
- }, template: "<div class=\"mc-file-upload\"\n mcFileDrop\n [class.disabled]=\"disabled\"\n [class.mc-error]=\"errors && errors.length\"\n (filesDropped)=\"onFileDropped($event)\">\n <div class=\"dropzone\" *ngIf=\"!files.length; else fileOutput\">\n <i mc-icon=\"mc-upload-to-cloud_24\"></i>\n <span class=\"dropzone__text\">\n {{ separatedCaptionText[0] }}<label mc-link pseudo [disabled]=\"disabled\" [tabIndex]=\"-1\" [for]=\"inputId\">{{ config.browseLink }}<input #input type=\"file\" class=\"cdk-visually-hidden\" [id]=\"inputId\" [accept]=\"acceptedFiles\" [disabled]=\"disabled\" (change)=\"onFileSelectedViaClick($event)\"></label>{{ separatedCaptionText[1] }}\n </span>\n </div>\n</div>\n\n<mc-hint class=\"mc-file-upload__hint\">\n <ng-content select=\"[hint]\"></ng-content>\n</mc-hint>\n<ng-container *ngIf=\"errors && errors.length\">\n <mc-hint class=\"mc-file-upload__hint mc-error\" *ngFor=\"let error of errors\">{{ error }}</mc-hint>\n</ng-container>\n\n\n<ng-template #fileOutput>\n <div class=\"file-item\" *ngIf=\"files && files.length\">\n <div class=\"file-item__text-wrapper\">\n <ng-container *ngIf=\"{ loading: files[0].loading | async, progress: files[0].progress | async} as asyncData\">\n <ng-container *ngIf=\"!asyncData.loading\">\n <ng-content select=\"[mc-icon]\"></ng-content>\n </ng-container>\n\n <mc-progress-spinner\n [value]=\"asyncData.progress || 0\"\n *ngIf=\"asyncData.loading\"\n ></mc-progress-spinner>\n </ng-container>\n\n <div class=\"file-item__text\" [mcEllipsisCenter]=\"files[0].file.name\" [minVisibleLength]=\"10\"></div>\n </div>\n <button mc-button\n class=\"mc-button_transparent\"\n [disabled]=\"disabled\"\n (keydown.delete)=\"deleteItem()\"\n (keydown.backspace)=\"deleteItem()\"\n (click)=\"deleteItem($event)\">\n <i mc-icon=\"mc-close-circle_16\"></i>\n </button>\n </div>\n</ng-template>\n", styles: [".mc-file-upload{box-sizing:border-box;display:flex;align-items:center;position:relative}.mc-file-upload .dropzone,.mc-file-upload .file-item{display:flex;align-items:center}.mc-file-upload .mc-ellipsis-center{position:relative;display:flex}.mc-file-upload .mc-ellipsis-center .data-text-start{flex:0 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:pre}.mc-file-upload .mc-ellipsis-center .data-text-end{flex:1 0 auto;overflow:hidden;white-space:pre}\n", "@keyframes mc-progress{0%{background-position:0 0}to{background-position:29px 0}}.mc-progress{position:relative}.mc-progress:after{content:\"\";position:absolute;border-radius:inherit;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.05) 10px,transparent 10px,transparent 20px,rgba(0,0,0,.05) 20px,rgba(0,0,0,.05) 30px,transparent 30px) repeat;background-size:29px 29px;animation:mc-progress 1s linear infinite}.mc-group{display:flex;flex-direction:row}.mc-group .mc-group_justified>.mc-group-item{width:100%}.mc-group .mc-group-item+.mc-group-item{margin-left:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group{display:flex;flex-direction:column}.mc-vertical-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-bottom-left-radius:0;border-top-right-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-bottom-left-radius:0}.mc-vertical-group>.mc-group-item:last-child:not(:first-child){border-top-right-radius:0;border-top-left-radius:0;border-bottom-left-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-top-right-radius:0;border-top-left-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group .mc-group-item+.mc-group-item{margin-top:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.mc-file-upload{height:var(--mc-file-upload-size-single-height, 48px);padding-top:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-bottom:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-left:var(--mc-size-m, 12px);border-radius:var(--mc-file-upload-size-single-border-radius, 4px);border-width:var(--mc-file-upload-size-single-border-width, 1px);border-style:var(--mc-file-upload-size-single-border-style, dashed)}.mc-file-upload .dropzone .dropzone__text{margin-left:var(--mc-size-xs, 6px)}.mc-file-upload .file-item{width:100%}.mc-file-upload .file-item .file-item__text-wrapper{display:flex;align-items:center;width:100%}.mc-file-upload .file-item .file-item__text-wrapper .file-item__text{margin-left:var(--mc-size-s, 8px);width:120px;flex-grow:1}.mc-hint{display:block}.mc-file-upload__hint{margin-top:var(--mc-form-field-hint-size-margin-top, 4px)}\n"] }]
111
- }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
188
+ }, template: "<div class=\"mc-file-upload\"\n mcFileDrop\n [class.disabled]=\"disabled\"\n [class.mc-error]=\"invalid\"\n (filesDropped)=\"onFileDropped($event)\">\n <div class=\"dropzone\" *ngIf=\"!file; else fileOutput\">\n <i mc-icon=\"mc-upload-to-cloud_24\"></i>\n <span class=\"dropzone__text\">\n {{ separatedCaptionText[0] }}<label mc-link pseudo [disabled]=\"disabled\" [tabIndex]=\"-1\" [for]=\"inputId\">{{ config.browseLink }}<input #input type=\"file\" class=\"cdk-visually-hidden\" [id]=\"inputId\" [accept]=\"acceptedFiles\" [disabled]=\"disabled\" (change)=\"onFileSelectedViaClick($event)\"></label>{{ separatedCaptionText[1] }}\n </span>\n </div>\n</div>\n\n<ng-container *ngIf=\"hasHint\">\n <div class=\"mc-file-upload__hint\">\n <ng-content select=\"mc-hint,[hint]\" />\n </div>\n</ng-container>\n\n<ng-template #fileOutput>\n <div class=\"file-item\" *ngIf=\"file\">\n <div class=\"file-item__text-wrapper\">\n <ng-container *ngIf=\"{ loading: file.loading | async, progress: file.progress | async} as asyncData\">\n <ng-container *ngIf=\"!asyncData.loading\">\n <ng-content select=\"[mc-icon]\"></ng-content>\n </ng-container>\n\n <mc-progress-spinner\n [value]=\"asyncData.progress || 0\"\n *ngIf=\"asyncData.loading\"\n ></mc-progress-spinner>\n </ng-container>\n\n <div class=\"file-item__text\" [mcEllipsisCenter]=\"file.file.name\" [minVisibleLength]=\"10\"></div>\n </div>\n <button mc-button\n class=\"mc-button_transparent\"\n [disabled]=\"disabled\"\n (keydown.delete)=\"deleteItem()\"\n (keydown.backspace)=\"deleteItem()\"\n (click)=\"deleteItem($event)\">\n <i mc-icon=\"mc-close-circle_16\"></i>\n </button>\n </div>\n</ng-template>\n", styles: [".mc-file-upload{box-sizing:border-box;display:flex;align-items:center;position:relative}.mc-file-upload .dropzone,.mc-file-upload .file-item{display:flex;align-items:center}.mc-file-upload .mc-ellipsis-center{position:relative;display:flex}.mc-file-upload .mc-ellipsis-center .data-text-start{flex:0 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:pre}.mc-file-upload .mc-ellipsis-center .data-text-end{flex:1 0 auto;overflow:hidden;white-space:pre}.mc-file-upload__hint>.mc-hint{margin-top:var(--mc-form-field-hint-size-margin-top, 4px)}\n", "@keyframes mc-progress{0%{background-position:0 0}to{background-position:29px 0}}.mc-progress{position:relative}.mc-progress:after{content:\"\";position:absolute;border-radius:inherit;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.05) 10px,transparent 10px,transparent 20px,rgba(0,0,0,.05) 20px,rgba(0,0,0,.05) 30px,transparent 30px) repeat;background-size:29px 29px;animation:mc-progress 1s linear infinite}.mc-group{display:flex;flex-direction:row}.mc-group .mc-group_justified>.mc-group-item{width:100%}.mc-group .mc-group-item+.mc-group-item{margin-left:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-top-right-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-bottom-left-radius:0;border-top-left-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group{display:flex;flex-direction:column}.mc-vertical-group>.mc-group-item:first-child:not(:last-child){border-bottom-right-radius:0;border-bottom-left-radius:0;border-top-right-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:first-child:not(:last-child)>.mc-form-field__container{border-bottom-right-radius:0;border-bottom-left-radius:0}.mc-vertical-group>.mc-group-item:last-child:not(:first-child){border-top-right-radius:0;border-top-left-radius:0;border-bottom-left-radius:var(--mc-button-size-border-radius, 4px)}.mc-vertical-group>.mc-group-item:last-child:not(:first-child)>.mc-form-field__container{border-top-right-radius:0;border-top-left-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child){border-radius:0}.mc-vertical-group>.mc-group-item:not(:first-child):not(:last-child)>.mc-form-field__container{border-radius:0}.mc-vertical-group .mc-group-item+.mc-group-item{margin-top:calc(-1 * var(--mc-button-size-border-width, 1px))}.mc-no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.mc-file-upload{height:var(--mc-file-upload-size-single-height, 48px);padding-top:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-bottom:var(--mc-file-upload-size-single-vertical-padding, 12px);padding-left:var(--mc-size-m, 12px);border-radius:var(--mc-file-upload-size-single-border-radius, 4px);border-width:var(--mc-file-upload-size-single-border-width, 1px);border-style:var(--mc-file-upload-size-single-border-style, dashed)}.mc-file-upload .dropzone .dropzone__text{margin-left:var(--mc-size-xs, 6px)}.mc-file-upload .file-item{width:100%}.mc-file-upload .file-item .file-item__text-wrapper{display:flex;align-items:center;width:100%}.mc-file-upload .file-item .file-item__text-wrapper .file-item__text{margin-left:var(--mc-size-s, 8px);width:120px;flex-grow:1}\n"] }]
189
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
112
190
  type: Optional
113
191
  }, {
114
192
  type: Inject,
115
193
  args: [MC_FILE_UPLOAD_CONFIGURATION]
116
- }] }, { type: i9.McLocaleService, decorators: [{
117
- type: Optional
118
- }, {
119
- type: Inject,
120
- args: [MC_LOCALE_SERVICE]
121
- }] }], propDecorators: { accept: [{
194
+ }] }], propDecorators: { file: [{
195
+ type: Input
196
+ }], accept: [{
122
197
  type: Input
123
198
  }], disabled: [{
124
199
  type: Input
125
200
  }], errors: [{
126
201
  type: Input
127
- }], files: [{
128
- type: Input
129
202
  }], inputId: [{
130
203
  type: Input
131
204
  }], customValidation: [{
132
205
  type: Input
206
+ }], errorStateMatcher: [{
207
+ type: Input
133
208
  }], fileQueueChanged: [{
134
209
  type: Output
135
210
  }], input: [{
136
211
  type: ViewChild,
137
212
  args: ['input']
213
+ }], hint: [{
214
+ type: ContentChildren,
215
+ args: [McHint]
138
216
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-file-upload.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/file-upload/single-file-upload.component.ts","../../../../packages/mosaic/file-upload/single-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy, ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter, Inject,\n    Input, OnDestroy, Optional,\n    Output, Renderer2,\n    ViewChild\n} from '@angular/core';\nimport { CanDisable, MC_LOCALE_SERVICE, McLocaleService, ruRULocaleData } from '@ptsecurity/mosaic/core';\nimport { BehaviorSubject, Subscription } from 'rxjs';\n\nimport {\n    MC_FILE_UPLOAD_CONFIGURATION,\n    McFile,\n    McFileItem,\n    McFileValidatorFn,\n    McInputFile,\n    McInputFileLabel\n} from './file-upload';\n\n\nlet nextSingleFileUploadUniqueId = 0;\n\nexport const MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION: McInputFileLabel = ruRULocaleData['ru-RU'].fileUpload.single;\n\n@Component({\n    selector: 'mc-single-file-upload',\n    templateUrl: './single-file-upload.component.html',\n    styleUrls: ['./file-upload.scss', './single-file-upload.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'mc-single-file-upload'\n    }\n})\nexport class McSingleFileUploadComponent implements McInputFile, CanDisable, OnDestroy {\n    @Input() accept: string[];\n    @Input() disabled: boolean = false;\n    @Input() errors: string[] = [];\n    @Input() files: McFileItem[] = [];\n    @Input() inputId: string = `mc-single-file-upload-${nextSingleFileUploadUniqueId++}`;\n    @Input() customValidation?: McFileValidatorFn[];\n    @Output() fileQueueChanged: EventEmitter<McFileItem | null> = new EventEmitter<McFileItem | null>();\n\n    @ViewChild('input') input: ElementRef<HTMLInputElement>;\n\n    get acceptedFiles(): string {\n        return this.accept && this.accept.length > 0 ? this.accept.map((ext: string) => `.${ext}`).join(',') : '*/*';\n    }\n\n    config: McInputFileLabel;\n\n    separatedCaptionText: string[];\n\n    private localeSubscription: Subscription;\n\n    constructor(\n        private renderer: Renderer2,\n        private cdr: ChangeDetectorRef,\n        @Optional() @Inject(MC_FILE_UPLOAD_CONFIGURATION) readonly configuration: McInputFileLabel,\n        @Optional() @Inject(MC_LOCALE_SERVICE) private localeService?: McLocaleService\n    ) {\n        this.localeSubscription = this.localeService?.changes.subscribe(this.updateLocaleParams) || Subscription.EMPTY;\n\n        if (!localeService) {\n            this.initDefaultParams();\n        }\n    }\n\n    ngOnDestroy() {\n        this.localeSubscription.unsubscribe();\n    }\n\n    onFileSelectedViaClick({ target }: Event): void {\n        if (this.disabled) { return; }\n\n        const files: FileList | null = (target as HTMLInputElement).files;\n        if (files?.length) {\n            this.files = [this.mapToFileItem(files[0])];\n            this.fileQueueChanged.emit(this.files[0]);\n        }\n        /* even if the user selects the same file,\n         the onchange event will be triggered every time user clicks on the control.*/\n        this.renderer.setProperty(this.input.nativeElement, 'value', null);\n    }\n\n    deleteItem(event?: MouseEvent): void {\n        if (this.disabled) { return; }\n\n        event?.stopPropagation();\n        this.files = [];\n        this.errors = [];\n        this.fileQueueChanged.emit(null);\n    }\n\n    onFileDropped(files: FileList | McFile[]): void {\n        if (this.disabled) { return; }\n\n        if (this.isCorrectExtension(files[0])) {\n            this.files = Array.from(files)\n                .map((file) => this.mapToFileItem(file));\n            this.fileQueueChanged.emit(this.files[0]);\n        }\n    }\n\n    private mapToFileItem(file: File): McFileItem {\n        this.validateFile(file);\n\n        return {\n            file,\n            progress: new BehaviorSubject<number>(0),\n            loading: new BehaviorSubject<boolean>(false)\n        };\n    }\n\n    private validateFile(file: File): void {\n        if (this.customValidation && this.customValidation.length) {\n            this.errors = this.customValidation.reduce(\n                (errors: (string | null)[], validatorFn: McFileValidatorFn) => {\n                    errors.push(validatorFn(file));\n\n                    return errors;\n                },\n                []).filter(Boolean) as string[];\n        }\n    }\n\n    private isCorrectExtension(file: File): boolean {\n        const fileExt: string = file.name.split('.').pop() || '';\n\n        return this.acceptedFiles !== '*/*' && this.acceptedFiles.length > 0 ? this.acceptedFiles.includes(fileExt) : true;\n    }\n\n    private updateLocaleParams = () => {\n        this.config = this.configuration || this.localeService?.getParams('fileUpload').multiple;\n\n        this.makeCaptionText();\n\n        this.cdr.markForCheck();\n    }\n\n    private initDefaultParams() {\n        this.config = MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION;\n\n        this.makeCaptionText();\n    }\n\n    private makeCaptionText() {\n        this.separatedCaptionText = this.config.captionText.split('{{ browseLink }}');\n    }\n}\n","<div class=\"mc-file-upload\"\n     mcFileDrop\n     [class.disabled]=\"disabled\"\n     [class.mc-error]=\"errors && errors.length\"\n     (filesDropped)=\"onFileDropped($event)\">\n        <div class=\"dropzone\" *ngIf=\"!files.length; else fileOutput\">\n            <i mc-icon=\"mc-upload-to-cloud_24\"></i>\n            <span class=\"dropzone__text\">\n                {{ separatedCaptionText[0] }}<label mc-link pseudo [disabled]=\"disabled\" [tabIndex]=\"-1\" [for]=\"inputId\">{{ config.browseLink }}<input #input type=\"file\" class=\"cdk-visually-hidden\" [id]=\"inputId\" [accept]=\"acceptedFiles\" [disabled]=\"disabled\" (change)=\"onFileSelectedViaClick($event)\"></label>{{ separatedCaptionText[1] }}\n            </span>\n        </div>\n</div>\n\n<mc-hint class=\"mc-file-upload__hint\">\n    <ng-content select=\"[hint]\"></ng-content>\n</mc-hint>\n<ng-container *ngIf=\"errors && errors.length\">\n    <mc-hint class=\"mc-file-upload__hint mc-error\" *ngFor=\"let error of errors\">{{ error }}</mc-hint>\n</ng-container>\n\n\n<ng-template #fileOutput>\n    <div class=\"file-item\" *ngIf=\"files && files.length\">\n        <div class=\"file-item__text-wrapper\">\n            <ng-container *ngIf=\"{ loading: files[0].loading | async, progress: files[0].progress | async} as asyncData\">\n                <ng-container *ngIf=\"!asyncData.loading\">\n                    <ng-content select=\"[mc-icon]\"></ng-content>\n                </ng-container>\n\n                <mc-progress-spinner\n                    [value]=\"asyncData.progress || 0\"\n                    *ngIf=\"asyncData.loading\"\n                ></mc-progress-spinner>\n            </ng-container>\n\n            <div class=\"file-item__text\" [mcEllipsisCenter]=\"files[0].file.name\" [minVisibleLength]=\"10\"></div>\n        </div>\n        <button mc-button\n                class=\"mc-button_transparent\"\n                [disabled]=\"disabled\"\n                (keydown.delete)=\"deleteItem()\"\n                (keydown.backspace)=\"deleteItem()\"\n                (click)=\"deleteItem($event)\">\n            <i mc-icon=\"mc-close-circle_16\"></i>\n        </button>\n    </div>\n</ng-template>\n"]}
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-file-upload.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/file-upload/single-file-upload.component.ts","../../../../packages/mosaic/file-upload/single-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component, ContentChildren, DoCheck,\n    ElementRef,\n    EventEmitter, Inject,\n    Input, Optional,\n    Output, QueryList,\n    ViewChild, ViewEncapsulation\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlValueAccessor, FormControlStatus } from '@angular/forms';\nimport {\n    CanDisable,\n    ErrorStateMatcher,\n    ruRULocaleData\n} from '@ptsecurity/mosaic/core';\nimport { McHint } from '@ptsecurity/mosaic/form-field';\nimport { BehaviorSubject } from 'rxjs';\nimport { distinctUntilChanged } from 'rxjs/operators';\n\nimport {\n    MC_FILE_UPLOAD_CONFIGURATION,\n    McFile,\n    McFileItem, McFileUploadBase,\n    McFileValidatorFn,\n    McInputFile,\n    McInputFileLabel\n} from './file-upload';\n\n\nlet nextSingleFileUploadUniqueId = 0;\n\nexport const MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION: McInputFileLabel = ruRULocaleData['ru-RU'].fileUpload.single;\n\n@Component({\n    selector: 'mc-single-file-upload',\n    templateUrl: './single-file-upload.component.html',\n    styleUrls: ['./file-upload.scss', './single-file-upload.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'mc-single-file-upload'\n    }\n})\nexport class McSingleFileUploadComponent\n    extends McFileUploadBase\n    implements McInputFile, CanDisable, DoCheck, ControlValueAccessor {\n    get file(): McFileItem | null {\n        return this._file;\n    }\n\n    @Input()\n    set file(currentFile: McFileItem | null) {\n        this._file = currentFile;\n        this.cvaOnChange(this._file);\n        this.fileQueueChanged.emit(this._file);\n        this.cdr.markForCheck();\n    }\n    private _file: McFileItem | null = null;\n\n    get acceptedFiles(): string {\n        return this.accept && this.accept.length > 0 ? this.accept.map((ext: string) => `.${ext}`).join(',') : '*/*';\n    }\n    get hasHint(): boolean {\n        return this.hint.length > 0;\n    }\n\n    /**\n     * Indicates an invalid state based on `errorState`,\n     * applying a CSS class in HTML for visual feedback.\n     */\n    get invalid(): boolean {\n        return !!this.file?.hasError || this.errorState;\n    }\n\n    @Input() accept: string[];\n    @Input() disabled: boolean = false;\n    /**\n     * @deprecated use `FormControl.errors`\n     */\n    @Input() errors: string[] = [];\n    @Input() inputId: string = `mc-single-file-upload-${nextSingleFileUploadUniqueId++}`;\n    /**\n     * @deprecated use FormControl for validation\n     */\n    @Input() customValidation?: McFileValidatorFn[];\n\n    /** An object used to control the error state of the component. */\n    @Input() errorStateMatcher: ErrorStateMatcher;\n\n    @Output() fileQueueChanged: EventEmitter<McFileItem | null> = new EventEmitter<McFileItem | null>();\n\n    @ViewChild('input') input: ElementRef<HTMLInputElement>;\n\n    config: McInputFileLabel;\n\n    separatedCaptionText: string[];\n\n    @ContentChildren(McHint) private readonly hint: QueryList<McHint>;\n\n    constructor(\n        @Optional() @Inject(MC_FILE_UPLOAD_CONFIGURATION) readonly configuration: McInputFileLabel\n    ) {\n        super();\n        this.localeService?.changes.pipe(takeUntilDestroyed())\n            .subscribe(this.updateLocaleParams);\n\n        if (!this.localeService) {\n            this.initDefaultParams();\n        }\n\n        if (this.ngControl) {\n            // Note: we provide the value accessor through here, instead of\n            // the `providers` to avoid running into a circular import.\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    /** cvaOnChange function registered via registerOnChange (ControlValueAccessor).\n     * @docs-private\n     */\n    // tslint:disable-next-line:no-empty\n    cvaOnChange = (_: McFileItem | null) => {};\n\n    /** onTouch function registered via registerOnTouch (ControlValueAccessor).\n     * @docs-private\n     */\n    // tslint:disable-next-line:no-empty\n    onTouched =  () => {};\n\n    ngAfterViewInit() {\n        // FormControl specific errors update\n        this.ngControl?.statusChanges?.pipe(distinctUntilChanged(), takeUntilDestroyed(this.destroyRef))\n            .subscribe((status: FormControlStatus) => {\n                if (this._file) { this._file.hasError = status === 'INVALID'; }\n                this.errors = Object.values(this.ngControl?.errors || {});\n                this.cdr.markForCheck();\n            });\n\n        this.stateChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => this.cdr.markForCheck());\n    }\n\n    ngDoCheck() {\n        if (this.ngControl) {\n            // We need to re-evaluate this on every change detection cycle, because there are some\n            // error triggers that we can't subscribe to (e.g. parent form submissions). This means\n            // that whatever logic is in here has to be super lean or we risk destroying the performance.\n            this.updateErrorState();\n        }\n    }\n\n    /** Implemented as part of ControlValueAccessor. @docs-private */\n    writeValue(file: File | McFileItem | null): void {\n        if (file instanceof File) {\n            this.file = this.mapToFileItem(file);\n        } else {\n            this.file = file;\n        }\n    }\n\n    /** Implemented as part of ControlValueAccessor. @docs-private */\n    registerOnChange(fn: any): void { this.cvaOnChange = fn; }\n\n    /** Implemented as part of ControlValueAccessor. @docs-private */\n    registerOnTouched(fn: any): void { this.onTouched = fn; }\n\n    /**\n     * Sets the disabled state of the control. Implemented as a part of ControlValueAccessor.\n     * @param isDisabled Whether the control should be disabled.\n     * @docs-private\n     */\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n        this.cdr.markForCheck();\n    }\n\n    onFileSelectedViaClick({ target }: Event): void {\n        if (this.disabled) { return; }\n\n        const files: FileList | null = (target as HTMLInputElement).files;\n        if (files?.length) {\n            this.file = this.mapToFileItem(files[0]);\n        }\n        this.onTouched();\n        /* even if the user selects the same file,\n         the onchange event will be triggered every time user clicks on the control.*/\n        this.renderer.setProperty(this.input.nativeElement, 'value', null);\n    }\n\n    deleteItem(event?: MouseEvent): void {\n        if (this.disabled) { return; }\n\n        event?.stopPropagation();\n        this.file = null;\n        this.errors = [];\n        // mark as touched after file drop even if file wasn't correct\n        this.onTouched();\n    }\n\n    onFileDropped(files: FileList | McFile[]): void {\n        if (this.disabled) { return; }\n\n        if (files?.length && this.isCorrectExtension(files[0])) {\n            this.file = this.mapToFileItem(files[0]);\n        }\n        // mark as touched after file drop even if file wasn't correct\n        this.onTouched();\n    }\n\n    private mapToFileItem(file: File): McFileItem {\n        this.validateFile(file);\n\n        return {\n            file,\n            progress: new BehaviorSubject<number>(0),\n            loading: new BehaviorSubject<boolean>(false)\n        };\n    }\n\n    private validateFile(file: File): void {\n        if (!this.customValidation?.length) { return; }\n        this.errors = this.customValidation.reduce(\n            (errors: (string | null)[], validatorFn: McFileValidatorFn) => {\n                errors.push(validatorFn(file));\n\n                return errors;\n            },\n            []).filter(Boolean) as string[];\n    }\n\n    private isCorrectExtension(file: File): boolean {\n        const fileExt: string = file.name.split('.').pop() || '';\n\n        return this.acceptedFiles !== '*/*' && this.acceptedFiles.length > 0 ? this.acceptedFiles.includes(fileExt) : true;\n    }\n\n    private updateLocaleParams = () => {\n        this.config = this.configuration || this.localeService?.getParams('fileUpload').multiple;\n\n        this.makeCaptionText();\n\n        this.cdr.markForCheck();\n    }\n\n    private initDefaultParams() {\n        this.config = MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION;\n\n        this.makeCaptionText();\n    }\n\n    private makeCaptionText() {\n        this.separatedCaptionText = this.config.captionText.split('{{ browseLink }}');\n    }\n}\n","<div class=\"mc-file-upload\"\n     mcFileDrop\n     [class.disabled]=\"disabled\"\n     [class.mc-error]=\"invalid\"\n     (filesDropped)=\"onFileDropped($event)\">\n        <div class=\"dropzone\" *ngIf=\"!file; else fileOutput\">\n            <i mc-icon=\"mc-upload-to-cloud_24\"></i>\n            <span class=\"dropzone__text\">\n                {{ separatedCaptionText[0] }}<label mc-link pseudo [disabled]=\"disabled\" [tabIndex]=\"-1\" [for]=\"inputId\">{{ config.browseLink }}<input #input type=\"file\" class=\"cdk-visually-hidden\" [id]=\"inputId\" [accept]=\"acceptedFiles\" [disabled]=\"disabled\" (change)=\"onFileSelectedViaClick($event)\"></label>{{ separatedCaptionText[1] }}\n            </span>\n        </div>\n</div>\n\n<ng-container *ngIf=\"hasHint\">\n    <div class=\"mc-file-upload__hint\">\n        <ng-content select=\"mc-hint,[hint]\" />\n    </div>\n</ng-container>\n\n<ng-template #fileOutput>\n    <div class=\"file-item\" *ngIf=\"file\">\n        <div class=\"file-item__text-wrapper\">\n            <ng-container *ngIf=\"{ loading: file.loading | async, progress: file.progress | async} as asyncData\">\n                <ng-container *ngIf=\"!asyncData.loading\">\n                    <ng-content select=\"[mc-icon]\"></ng-content>\n                </ng-container>\n\n                <mc-progress-spinner\n                    [value]=\"asyncData.progress || 0\"\n                    *ngIf=\"asyncData.loading\"\n                ></mc-progress-spinner>\n            </ng-container>\n\n            <div class=\"file-item__text\" [mcEllipsisCenter]=\"file.file.name\" [minVisibleLength]=\"10\"></div>\n        </div>\n        <button mc-button\n                class=\"mc-button_transparent\"\n                [disabled]=\"disabled\"\n                (keydown.delete)=\"deleteItem()\"\n                (keydown.backspace)=\"deleteItem()\"\n                (click)=\"deleteItem($event)\">\n            <i mc-icon=\"mc-close-circle_16\"></i>\n        </button>\n    </div>\n</ng-template>\n"]}
@@ -175,7 +175,7 @@ export class McPopoverTrigger extends McPopUpTrigger {
175
175
  updatePosition(reapplyPosition = false) {
176
176
  this.overlayRef = this.createOverlay();
177
177
  const position = this.overlayRef.getConfig().positionStrategy
178
- .withPositions(this.getPrioritizedPositions())
178
+ .withPositions(this.getAdjustedPositions())
179
179
  .withPush(true);
180
180
  if (reapplyPosition) {
181
181
  setTimeout(() => position.reapplyLastPosition());
@@ -261,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
261
261
  type: Output,
262
262
  args: ['mcPopoverVisibleChange']
263
263
  }] } });
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/popover/popover.component.ts","../../../../packages/mosaic/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    FlexibleConnectedPositionStrategy,\n    Overlay,\n    ScrollStrategy,\n    OverlayConfig\n} from '@angular/cdk/overlay';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    Directive,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    Output,\n    TemplateRef,\n    Type,\n    ViewEncapsulation\n} from '@angular/core';\nimport {\n    McPopUp,\n    McPopUpTrigger,\n    PopUpPlacements,\n    PopUpSizes,\n    PopUpTriggers,\n    POSITION_TO_CSS_MAP\n} from '@ptsecurity/mosaic/core';\nimport { merge, NEVER } from 'rxjs';\n\nimport { mcPopoverAnimations } from './popover-animations';\n\n\n@Component({\n    selector: 'mc-popover-component',\n    templateUrl: './popover.component.html',\n    preserveWhitespaces: false,\n    styleUrls: ['./popover.scss'],\n    host: {\n        '(keydown.esc)': 'hide(0)'\n    },\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [mcPopoverAnimations.popoverState]\n})\nexport class McPopoverComponent extends McPopUp {\n    prefix = 'mc-popover';\n\n    header: string | TemplateRef<any>;\n    footer: string | TemplateRef<any>;\n\n    isTrapFocus: boolean = false;\n\n    updateClassMap(placement: string, customClass: string, size: PopUpSizes) {\n        super.updateClassMap(\n            placement,\n            customClass,\n            { [`${this.prefix}_${size}`]: !!size }\n        );\n    }\n\n    updateTrapFocus(isTrapFocus: boolean): void {\n        this.isTrapFocus = isTrapFocus;\n    }\n}\n\nexport const MC_POPOVER_SCROLL_STRATEGY =\n    new InjectionToken<() => ScrollStrategy>('mc-popover-scroll-strategy');\n\n/** @docs-private */\nexport function mcPopoverScrollStrategyFactory(overlay: Overlay): () => ScrollStrategy {\n    return () => overlay.scrollStrategies.reposition({ scrollThrottle: 20 });\n}\n\n/** @docs-private */\nexport const MC_POPOVER_SCROLL_STRATEGY_FACTORY_PROVIDER = {\n    provide: MC_POPOVER_SCROLL_STRATEGY,\n    deps: [Overlay],\n    useFactory: mcPopoverScrollStrategyFactory\n};\n\n/** Creates an error to be thrown if the user supplied an invalid popover position. */\nexport function getMcPopoverInvalidPositionError(position: string) {\n    return Error(`McPopover position \"${position}\" is invalid.`);\n}\n\n\n@Directive({\n    selector: '[mcPopover]',\n    exportAs: 'mcPopover',\n    host: {\n        '[class.mc-popover_open]': 'isOpen',\n        '[class.mc-active]': 'hasClickTrigger && isOpen',\n        '(keydown)': 'handleKeydown($event)',\n        '(touchend)': 'handleTouchend()'\n    }\n})\nexport class McPopoverTrigger extends McPopUpTrigger<McPopoverComponent> {\n    @Input('mcPopoverVisible')\n    get popoverVisible(): boolean {\n        return this.visible;\n    }\n\n    set popoverVisible(value: boolean) {\n        super.updateVisible(value);\n    }\n\n    @Input('mcPopoverPlacement')\n    get popoverPlacement(): PopUpPlacements {\n        return this.placement;\n    }\n\n    set popoverPlacement(value: PopUpPlacements) {\n        super.updatePlacement(value);\n    }\n\n    @Input('mcPopoverPlacementPriority')\n    get popoverPlacementPriority() {\n        return this.placementPriority;\n    }\n\n    set popoverPlacementPriority(value) {\n        super.updatePlacementPriority(value);\n    }\n\n    @Input()\n    get hasBackdrop(): boolean {\n        return this._hasBackdrop;\n    }\n\n    set hasBackdrop(value: boolean) {\n        this._hasBackdrop = coerceBooleanProperty(value);\n    }\n\n    private _hasBackdrop: boolean = false;\n\n    @Input('mcPopoverHeader')\n    get header(): string | TemplateRef<any> {\n        return this._header;\n    }\n\n    set header(value: string | TemplateRef<any>) {\n        this._header = value;\n\n        this.updateData();\n    }\n\n    private _header: string | TemplateRef<any>;\n\n    @Input('mcPopoverContent')\n    get content(): string | TemplateRef<any> {\n        return this._content;\n    }\n\n    set content(value: string | TemplateRef<any>) {\n        this._content = value;\n\n        this.updateData();\n    }\n\n    @Input('mcPopoverFooter')\n    get footer(): string | TemplateRef<any> {\n        return this._footer;\n    }\n\n    set footer(value: string | TemplateRef<any>) {\n        this._footer = value;\n\n        this.updateData();\n    }\n\n    private _footer: string | TemplateRef<any>;\n\n    @Input('mcPopoverDisabled')\n    get disabled(): boolean {\n        return this._disabled;\n    }\n\n    set disabled(value) {\n        this._disabled = coerceBooleanProperty(value);\n    }\n\n    @Input('mcTrigger')\n    get trigger(): string {\n        return this._trigger;\n    }\n\n    set trigger(value: string) {\n        if (value) {\n            this._trigger = value;\n        } else {\n            this._trigger = `${PopUpTriggers.Click}, ${PopUpTriggers.Keydown}`;\n        }\n\n        this.initListeners();\n    }\n\n    private _trigger: string = `${PopUpTriggers.Click}, ${PopUpTriggers.Keydown}`;\n\n    @Input('mcPopoverSize')\n    get size(): PopUpSizes {\n        return this._size;\n    }\n\n    set size(value: PopUpSizes) {\n        if ([PopUpSizes.Small, PopUpSizes.Medium, PopUpSizes.Large].includes(value)) {\n            this._size = value;\n\n            this.updateClassMap();\n        } else {\n            this._size = PopUpSizes.Medium;\n        }\n    }\n\n    private _size: PopUpSizes = PopUpSizes.Medium;\n\n    @Input('mcPopoverClass')\n    get customClass() {\n        return this._customClass;\n    }\n\n    set customClass(value: string) {\n        this._customClass = value;\n\n        this.updateClassMap();\n    }\n\n    /**\n     * Controls the behavior of closing the component on scroll.\n     * The default value is `false`.\n     * Use CloseScrollStrategy as alternative\n     */\n    @Input()\n    get closeOnScroll(): boolean {\n        return this._closeOnScroll;\n    }\n\n    set closeOnScroll(value: boolean) {\n        this._closeOnScroll = coerceBooleanProperty(value);\n    }\n\n    private _closeOnScroll: boolean = false;\n\n    get hasClickTrigger(): boolean {\n        return this.trigger.includes(PopUpTriggers.Click);\n    }\n\n    @Input() backdropClass: string = 'cdk-overlay-transparent-backdrop';\n\n    @Output('mcPopoverPlacementChange') placementChange = new EventEmitter();\n\n    @Output('mcPopoverVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n    protected scrollStrategy: () => ScrollStrategy = inject(MC_POPOVER_SCROLL_STRATEGY);\n\n    protected originSelector = '.mc-popover';\n\n    protected get overlayConfig(): OverlayConfig {\n        return {\n            panelClass: 'mc-popover__panel',\n            hasBackdrop: this.hasBackdrop,\n            backdropClass: this.backdropClass\n        };\n    }\n\n    updateData() {\n        if (!this.instance) { return; }\n\n        this.instance.header = this.header;\n        this.instance.content = this.content;\n        this.instance.footer = this.footer;\n\n        this.instance.updateTrapFocus(this.trigger !== PopUpTriggers.Focus);\n\n        if (this.isOpen) {\n            this.updatePosition(true);\n        }\n    }\n\n    /** Updates the position of the current popover. */\n    updatePosition(reapplyPosition: boolean = false) {\n        this.overlayRef = this.createOverlay();\n\n        const position = (this.overlayRef.getConfig().positionStrategy as FlexibleConnectedPositionStrategy)\n            .withPositions(this.getPrioritizedPositions())\n            .withPush(true);\n\n        if (reapplyPosition) {\n            setTimeout(() => position.reapplyLastPosition());\n        }\n    }\n\n    getOverlayHandleComponentType(): Type<McPopoverComponent> {\n        return McPopoverComponent;\n    }\n\n    updateClassMap(newPlacement: string = this.placement) {\n        if (!this.instance) { return; }\n\n        this.instance.updateClassMap(POSITION_TO_CSS_MAP[newPlacement], this.customClass, this.size);\n        this.instance.markForCheck();\n    }\n\n    closingActionsForClick() {\n        if (this.hasClickTrigger) {\n            return [\n                this.overlayRef!.backdropClick(),\n                this.hasBackdrop ? NEVER : this.overlayRef!.outsidePointerEvents()\n            ];\n        }\n\n        return [];\n    }\n\n    closingActions() {\n        return merge(\n            ...this.closingActionsForClick(),\n            this.closeOnScroll ? this.scrollDispatcher.scrolled() : NEVER\n        );\n    }\n}\n","<div class=\"mc-popover\"\n     [cdkTrapFocus]=\"isTrapFocus\"\n     [cdkTrapFocusAutoCapture]=\"isTrapFocus\"\n     [ngClass]=\"classMap\"\n     [@state]=\"visibility\"\n     (@state.start)=\"animationStart()\"\n     (@state.done)=\"animationDone($event)\">\n\n    <div class=\"mc-popover__container\">\n        <div class=\"mc-popover__header\" *ngIf=\"header\">\n            <ng-container *ngIf=\"isTemplateRef(header)\" [ngTemplateOutlet]=\"$any(header)\"></ng-container>\n            <ng-container *ngIf=\"!isTemplateRef(header)\">\n                <div>{{ header }}</div>\n            </ng-container>\n        </div>\n\n        <div class=\"mc-popover__content\"\n             [ngClass]=\"{ 'mc-popover__content_padding_bottom': footer }\"\n             *ngIf=\"content\">\n            <ng-container *ngIf=\"isTemplateRef(content)\" [ngTemplateOutlet]=\"$any(content)\"></ng-container>\n            <ng-container *ngIf=\"!isTemplateRef(content)\">\n                <div>{{ content }}</div>\n            </ng-container>\n        </div>\n\n        <div class=\"mc-popover__footer\" *ngIf=\"footer\">\n            <ng-container *ngIf=\"isTemplateRef(footer)\" [ngTemplateOutlet]=\"$any(footer)\"></ng-container>\n            <ng-container *ngIf=\"!isTemplateRef(footer)\">\n                <div>{{ footer }}</div>\n            </ng-container>\n        </div>\n    </div>\n\n    <div class=\"mc-popover__arrow\" [class.mc-popover__arrow_with-footer]=\"footer\"></div>\n</div>\n"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/popover/popover.component.ts","../../../../packages/mosaic/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    FlexibleConnectedPositionStrategy,\n    Overlay,\n    ScrollStrategy,\n    OverlayConfig\n} from '@angular/cdk/overlay';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    Directive,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    Output,\n    TemplateRef,\n    Type,\n    ViewEncapsulation\n} from '@angular/core';\nimport {\n    McPopUp,\n    McPopUpTrigger,\n    PopUpPlacements,\n    PopUpSizes,\n    PopUpTriggers,\n    POSITION_TO_CSS_MAP\n} from '@ptsecurity/mosaic/core';\nimport { merge, NEVER } from 'rxjs';\n\nimport { mcPopoverAnimations } from './popover-animations';\n\n\n@Component({\n    selector: 'mc-popover-component',\n    templateUrl: './popover.component.html',\n    preserveWhitespaces: false,\n    styleUrls: ['./popover.scss'],\n    host: {\n        '(keydown.esc)': 'hide(0)'\n    },\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [mcPopoverAnimations.popoverState]\n})\nexport class McPopoverComponent extends McPopUp {\n    prefix = 'mc-popover';\n\n    header: string | TemplateRef<any>;\n    footer: string | TemplateRef<any>;\n\n    isTrapFocus: boolean = false;\n\n    updateClassMap(placement: string, customClass: string, size: PopUpSizes) {\n        super.updateClassMap(\n            placement,\n            customClass,\n            { [`${this.prefix}_${size}`]: !!size }\n        );\n    }\n\n    updateTrapFocus(isTrapFocus: boolean): void {\n        this.isTrapFocus = isTrapFocus;\n    }\n}\n\nexport const MC_POPOVER_SCROLL_STRATEGY =\n    new InjectionToken<() => ScrollStrategy>('mc-popover-scroll-strategy');\n\n/** @docs-private */\nexport function mcPopoverScrollStrategyFactory(overlay: Overlay): () => ScrollStrategy {\n    return () => overlay.scrollStrategies.reposition({ scrollThrottle: 20 });\n}\n\n/** @docs-private */\nexport const MC_POPOVER_SCROLL_STRATEGY_FACTORY_PROVIDER = {\n    provide: MC_POPOVER_SCROLL_STRATEGY,\n    deps: [Overlay],\n    useFactory: mcPopoverScrollStrategyFactory\n};\n\n/** Creates an error to be thrown if the user supplied an invalid popover position. */\nexport function getMcPopoverInvalidPositionError(position: string) {\n    return Error(`McPopover position \"${position}\" is invalid.`);\n}\n\n\n@Directive({\n    selector: '[mcPopover]',\n    exportAs: 'mcPopover',\n    host: {\n        '[class.mc-popover_open]': 'isOpen',\n        '[class.mc-active]': 'hasClickTrigger && isOpen',\n        '(keydown)': 'handleKeydown($event)',\n        '(touchend)': 'handleTouchend()'\n    }\n})\nexport class McPopoverTrigger extends McPopUpTrigger<McPopoverComponent> {\n    @Input('mcPopoverVisible')\n    get popoverVisible(): boolean {\n        return this.visible;\n    }\n\n    set popoverVisible(value: boolean) {\n        super.updateVisible(value);\n    }\n\n    @Input('mcPopoverPlacement')\n    get popoverPlacement(): PopUpPlacements {\n        return this.placement;\n    }\n\n    set popoverPlacement(value: PopUpPlacements) {\n        super.updatePlacement(value);\n    }\n\n    @Input('mcPopoverPlacementPriority')\n    get popoverPlacementPriority() {\n        return this.placementPriority;\n    }\n\n    set popoverPlacementPriority(value) {\n        super.updatePlacementPriority(value);\n    }\n\n    @Input()\n    get hasBackdrop(): boolean {\n        return this._hasBackdrop;\n    }\n\n    set hasBackdrop(value: boolean) {\n        this._hasBackdrop = coerceBooleanProperty(value);\n    }\n\n    private _hasBackdrop: boolean = false;\n\n    @Input('mcPopoverHeader')\n    get header(): string | TemplateRef<any> {\n        return this._header;\n    }\n\n    set header(value: string | TemplateRef<any>) {\n        this._header = value;\n\n        this.updateData();\n    }\n\n    private _header: string | TemplateRef<any>;\n\n    @Input('mcPopoverContent')\n    get content(): string | TemplateRef<any> {\n        return this._content;\n    }\n\n    set content(value: string | TemplateRef<any>) {\n        this._content = value;\n\n        this.updateData();\n    }\n\n    @Input('mcPopoverFooter')\n    get footer(): string | TemplateRef<any> {\n        return this._footer;\n    }\n\n    set footer(value: string | TemplateRef<any>) {\n        this._footer = value;\n\n        this.updateData();\n    }\n\n    private _footer: string | TemplateRef<any>;\n\n    @Input('mcPopoverDisabled')\n    get disabled(): boolean {\n        return this._disabled;\n    }\n\n    set disabled(value) {\n        this._disabled = coerceBooleanProperty(value);\n    }\n\n    @Input('mcTrigger')\n    get trigger(): string {\n        return this._trigger;\n    }\n\n    set trigger(value: string) {\n        if (value) {\n            this._trigger = value;\n        } else {\n            this._trigger = `${PopUpTriggers.Click}, ${PopUpTriggers.Keydown}`;\n        }\n\n        this.initListeners();\n    }\n\n    private _trigger: string = `${PopUpTriggers.Click}, ${PopUpTriggers.Keydown}`;\n\n    @Input('mcPopoverSize')\n    get size(): PopUpSizes {\n        return this._size;\n    }\n\n    set size(value: PopUpSizes) {\n        if ([PopUpSizes.Small, PopUpSizes.Medium, PopUpSizes.Large].includes(value)) {\n            this._size = value;\n\n            this.updateClassMap();\n        } else {\n            this._size = PopUpSizes.Medium;\n        }\n    }\n\n    private _size: PopUpSizes = PopUpSizes.Medium;\n\n    @Input('mcPopoverClass')\n    get customClass() {\n        return this._customClass;\n    }\n\n    set customClass(value: string) {\n        this._customClass = value;\n\n        this.updateClassMap();\n    }\n\n    /**\n     * Controls the behavior of closing the component on scroll.\n     * The default value is `false`.\n     * Use CloseScrollStrategy as alternative\n     */\n    @Input()\n    get closeOnScroll(): boolean {\n        return this._closeOnScroll;\n    }\n\n    set closeOnScroll(value: boolean) {\n        this._closeOnScroll = coerceBooleanProperty(value);\n    }\n\n    private _closeOnScroll: boolean = false;\n\n    get hasClickTrigger(): boolean {\n        return this.trigger.includes(PopUpTriggers.Click);\n    }\n\n    @Input() backdropClass: string = 'cdk-overlay-transparent-backdrop';\n\n    @Output('mcPopoverPlacementChange') placementChange = new EventEmitter();\n\n    @Output('mcPopoverVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n    protected scrollStrategy: () => ScrollStrategy = inject(MC_POPOVER_SCROLL_STRATEGY);\n\n    protected originSelector = '.mc-popover';\n\n    protected get overlayConfig(): OverlayConfig {\n        return {\n            panelClass: 'mc-popover__panel',\n            hasBackdrop: this.hasBackdrop,\n            backdropClass: this.backdropClass\n        };\n    }\n\n    updateData() {\n        if (!this.instance) { return; }\n\n        this.instance.header = this.header;\n        this.instance.content = this.content;\n        this.instance.footer = this.footer;\n\n        this.instance.updateTrapFocus(this.trigger !== PopUpTriggers.Focus);\n\n        if (this.isOpen) {\n            this.updatePosition(true);\n        }\n    }\n\n    /** Updates the position of the current popover. */\n    updatePosition(reapplyPosition: boolean = false) {\n        this.overlayRef = this.createOverlay();\n\n        const position = (this.overlayRef.getConfig().positionStrategy as FlexibleConnectedPositionStrategy)\n            .withPositions(this.getAdjustedPositions())\n            .withPush(true);\n\n        if (reapplyPosition) {\n            setTimeout(() => position.reapplyLastPosition());\n        }\n    }\n\n    getOverlayHandleComponentType(): Type<McPopoverComponent> {\n        return McPopoverComponent;\n    }\n\n    updateClassMap(newPlacement: string = this.placement) {\n        if (!this.instance) { return; }\n\n        this.instance.updateClassMap(POSITION_TO_CSS_MAP[newPlacement], this.customClass, this.size);\n        this.instance.markForCheck();\n    }\n\n    closingActionsForClick() {\n        if (this.hasClickTrigger) {\n            return [\n                this.overlayRef!.backdropClick(),\n                this.hasBackdrop ? NEVER : this.overlayRef!.outsidePointerEvents()\n            ];\n        }\n\n        return [];\n    }\n\n    closingActions() {\n        return merge(\n            ...this.closingActionsForClick(),\n            this.closeOnScroll ? this.scrollDispatcher.scrolled() : NEVER\n        );\n    }\n}\n","<div class=\"mc-popover\"\n     [cdkTrapFocus]=\"isTrapFocus\"\n     [cdkTrapFocusAutoCapture]=\"isTrapFocus\"\n     [ngClass]=\"classMap\"\n     [@state]=\"visibility\"\n     (@state.start)=\"animationStart()\"\n     (@state.done)=\"animationDone($event)\">\n\n    <div class=\"mc-popover__container\">\n        <div class=\"mc-popover__header\" *ngIf=\"header\">\n            <ng-container *ngIf=\"isTemplateRef(header)\" [ngTemplateOutlet]=\"$any(header)\"></ng-container>\n            <ng-container *ngIf=\"!isTemplateRef(header)\">\n                <div>{{ header }}</div>\n            </ng-container>\n        </div>\n\n        <div class=\"mc-popover__content\"\n             [ngClass]=\"{ 'mc-popover__content_padding_bottom': footer }\"\n             *ngIf=\"content\">\n            <ng-container *ngIf=\"isTemplateRef(content)\" [ngTemplateOutlet]=\"$any(content)\"></ng-container>\n            <ng-container *ngIf=\"!isTemplateRef(content)\">\n                <div>{{ content }}</div>\n            </ng-container>\n        </div>\n\n        <div class=\"mc-popover__footer\" *ngIf=\"footer\">\n            <ng-container *ngIf=\"isTemplateRef(footer)\" [ngTemplateOutlet]=\"$any(footer)\"></ng-container>\n            <ng-container *ngIf=\"!isTemplateRef(footer)\">\n                <div>{{ footer }}</div>\n            </ng-container>\n        </div>\n    </div>\n\n    <div class=\"mc-popover__arrow\" [class.mc-popover__arrow_with-footer]=\"footer\"></div>\n</div>\n"]}