@ptsecurity/mosaic 17.3.0 → 17.5.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.
- package/autocomplete/autocomplete-trigger.directive.d.ts +1 -0
- package/button/button.scss +14 -4
- package/checkbox/checkbox.d.ts +6 -6
- package/core/animation/animation.d.ts +2 -1
- package/core/common-behaviors/checkbox.d.ts +1 -0
- package/core/common-behaviors/index.d.ts +1 -0
- package/core/forms/index.d.ts +1 -0
- package/core/forms/validators.d.ts +22 -0
- package/core/locales/en-US.d.ts +17 -0
- package/core/locales/es-LA.d.ts +17 -0
- package/core/locales/fa-IR.d.ts +17 -0
- package/core/locales/index.d.ts +7 -0
- package/core/locales/locale-service.d.ts +175 -0
- package/core/locales/pt-BR.d.ts +17 -0
- package/core/locales/ru-RU.d.ts +17 -0
- package/core/locales/tk-TM.d.ts +64 -0
- package/core/locales/zh-CN.d.ts +17 -0
- package/core/pop-up/constants.d.ts +9 -0
- package/core/pop-up/pop-up-trigger.d.ts +28 -10
- package/core/pop-up/pop-up.d.ts +3 -3
- package/core/styles/theming/_theming.scss +1 -0
- package/datepicker/calendar-header.component.d.ts +11 -5
- package/datepicker/datepicker-input.directive.d.ts +10 -0
- package/dropdown/dropdown-trigger.directive.d.ts +1 -1
- package/ellipsis-center/ellipsis-center.directive.d.ts +3 -7
- package/esm2022/autocomplete/autocomplete-trigger.directive.mjs +13 -5
- package/esm2022/button/button.component.mjs +2 -2
- package/esm2022/checkbox/checkbox.mjs +5 -5
- package/esm2022/code-block/actionbar.component.mjs +1 -1
- package/esm2022/core/animation/animation.mjs +2 -1
- package/esm2022/core/common-behaviors/checkbox.mjs +2 -0
- package/esm2022/core/common-behaviors/index.mjs +2 -1
- package/esm2022/core/forms/index.mjs +2 -1
- package/esm2022/core/forms/validators.mjs +33 -0
- package/esm2022/core/locales/en-US.mjs +19 -2
- package/esm2022/core/locales/es-LA.mjs +19 -2
- package/esm2022/core/locales/fa-IR.mjs +19 -2
- package/esm2022/core/locales/index.mjs +8 -1
- package/esm2022/core/locales/locale-service.mjs +39 -3
- package/esm2022/core/locales/pt-BR.mjs +19 -2
- package/esm2022/core/locales/ru-RU.mjs +19 -2
- package/esm2022/core/locales/tk-TM.mjs +63 -0
- package/esm2022/core/locales/zh-CN.mjs +19 -2
- package/esm2022/core/pop-up/constants.mjs +6 -1
- package/esm2022/core/pop-up/pop-up-trigger.mjs +72 -23
- package/esm2022/core/pop-up/pop-up.mjs +7 -6
- package/esm2022/core/version.mjs +2 -2
- package/esm2022/datepicker/calendar-header.component.mjs +40 -10
- package/esm2022/datepicker/datepicker-input.directive.mjs +103 -23
- package/esm2022/dropdown/dropdown-trigger.directive.mjs +2 -2
- package/esm2022/ellipsis-center/ellipsis-center.directive.mjs +12 -23
- package/esm2022/file-upload/file-upload.mjs +39 -2
- package/esm2022/file-upload/file-upload.module.mjs +8 -1
- package/esm2022/file-upload/multiple-file-upload.component.mjs +159 -46
- package/esm2022/file-upload/single-file-upload.component.mjs +141 -41
- package/esm2022/form-field/form-field.mjs +6 -6
- package/esm2022/form-field/validate.directive.mjs +5 -2
- package/esm2022/input/input-number.mjs +31 -59
- package/esm2022/input/input-password.mjs +15 -26
- package/esm2022/input/input.mjs +3 -3
- package/esm2022/loader-overlay/loader-overlay.component.mjs +10 -8
- package/esm2022/modal/modal.component.mjs +3 -3
- package/esm2022/modal/modal.directive.mjs +38 -7
- package/esm2022/navbar/navbar-item.component.mjs +16 -30
- package/esm2022/popover/popover-confirm.component.mjs +11 -20
- package/esm2022/popover/popover.component.mjs +52 -29
- package/esm2022/progress-spinner/progress-spinner.component.mjs +2 -2
- package/esm2022/select/select-option.directive.mjs +7 -18
- package/esm2022/select/select.component.mjs +9 -6
- package/esm2022/sidebar/sidebar.component.mjs +10 -6
- package/esm2022/tabs/tab-group.component.mjs +1 -1
- package/esm2022/tabs/tab-header.component.mjs +2 -2
- package/esm2022/tabs/tab.component.mjs +3 -4
- package/esm2022/textarea/textarea.component.mjs +8 -4
- package/esm2022/timezone/timezone-option.directive.mjs +7 -18
- package/esm2022/title/title.directive.mjs +7 -18
- package/esm2022/toggle/toggle.component.mjs +103 -18
- package/esm2022/tooltip/tooltip.component.mjs +72 -45
- package/esm2022/tree-select/tree-select.component.mjs +9 -7
- package/fesm2022/ptsecurity-mosaic-autocomplete.mjs +12 -4
- package/fesm2022/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-button.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-button.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-checkbox.mjs +4 -4
- package/fesm2022/ptsecurity-mosaic-checkbox.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-code-block.mjs +1 -1
- package/fesm2022/ptsecurity-mosaic-code-block.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-core.mjs +325 -37
- package/fesm2022/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-datepicker.mjs +141 -31
- package/fesm2022/ptsecurity-mosaic-datepicker.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-dropdown.mjs +1 -1
- package/fesm2022/ptsecurity-mosaic-dropdown.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-ellipsis-center.mjs +11 -19
- package/fesm2022/ptsecurity-mosaic-ellipsis-center.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-file-upload.mjs +330 -80
- package/fesm2022/ptsecurity-mosaic-file-upload.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-form-field.mjs +9 -6
- package/fesm2022/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-input.mjs +39 -75
- package/fesm2022/ptsecurity-mosaic-input.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-loader-overlay.mjs +10 -8
- package/fesm2022/ptsecurity-mosaic-loader-overlay.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-modal.mjs +32 -7
- package/fesm2022/ptsecurity-mosaic-modal.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-navbar.mjs +14 -26
- package/fesm2022/ptsecurity-mosaic-navbar.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-popover.mjs +58 -40
- package/fesm2022/ptsecurity-mosaic-popover.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-progress-spinner.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-select.mjs +25 -28
- package/fesm2022/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-sidebar.mjs +8 -4
- package/fesm2022/ptsecurity-mosaic-sidebar.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-tabs.mjs +5 -6
- package/fesm2022/ptsecurity-mosaic-tabs.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-textarea.mjs +7 -3
- package/fesm2022/ptsecurity-mosaic-textarea.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-timezone.mjs +10 -17
- package/fesm2022/ptsecurity-mosaic-timezone.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-title.mjs +6 -14
- package/fesm2022/ptsecurity-mosaic-title.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-toggle.mjs +102 -17
- package/fesm2022/ptsecurity-mosaic-toggle.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-tooltip.mjs +71 -42
- package/fesm2022/ptsecurity-mosaic-tooltip.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-tree-select.mjs +8 -6
- package/fesm2022/ptsecurity-mosaic-tree-select.mjs.map +1 -1
- package/file-upload/_file-upload-theme.scss +23 -13
- package/file-upload/file-upload.d.ts +31 -3
- package/file-upload/file-upload.module.d.ts +11 -10
- package/file-upload/file-upload.scss +8 -1
- package/file-upload/multiple-file-upload.component.d.ts +62 -10
- package/file-upload/multiple-file-upload.component.scss +0 -8
- package/file-upload/single-file-upload.component.d.ts +55 -11
- package/file-upload/single-file-upload.component.scss +0 -8
- package/form-field/form-field.d.ts +1 -1
- package/form-field/validate.directive.d.ts +5 -2
- package/input/input-number.d.ts +10 -11
- package/input/input-password.d.ts +3 -6
- package/input/input.d.ts +1 -1
- package/loader-overlay/loader-overlay.component.d.ts +4 -3
- package/modal/modal.directive.d.ts +4 -1
- package/navbar/navbar-item.component.d.ts +5 -7
- package/package.json +24 -27
- package/popover/popover-confirm.component.d.ts +3 -6
- package/popover/popover.component.d.ts +14 -7
- package/prebuilt-themes/dark-theme.css +1 -1
- package/prebuilt-themes/default-theme.css +1 -1
- package/progress-spinner/progress-spinner.scss +1 -0
- package/select/select-option.directive.d.ts +3 -6
- package/sidebar/sidebar.component.d.ts +3 -2
- package/tabs/tab-header.scss +2 -2
- package/textarea/textarea.component.d.ts +1 -0
- package/timezone/timezone-option.directive.d.ts +3 -6
- package/title/title.directive.d.ts +3 -6
- package/toggle/_toggle-theme.scss +7 -1
- package/toggle/toggle.component.d.ts +23 -6
- package/toggle/toggle.scss +23 -0
- package/tooltip/tooltip.component.d.ts +25 -13
@@ -1,65 +1,152 @@
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Inject, Input, Optional, Output,
|
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';
|
2
5
|
import { BehaviorSubject } from 'rxjs';
|
3
|
-
import {
|
6
|
+
import { distinctUntilChanged } from 'rxjs/operators';
|
7
|
+
import { MC_FILE_UPLOAD_CONFIGURATION, McFileUploadBase } from './file-upload';
|
4
8
|
import * as i0 from "@angular/core";
|
5
9
|
import * as i1 from "@angular/common";
|
6
10
|
import * as i2 from "@ptsecurity/mosaic/progress-spinner";
|
7
11
|
import * as i3 from "@ptsecurity/mosaic/icon";
|
8
12
|
import * as i4 from "@ptsecurity/mosaic/button";
|
9
|
-
import * as i5 from "@ptsecurity/mosaic/
|
10
|
-
import * as i6 from "@ptsecurity/mosaic/
|
11
|
-
import * as i7 from "
|
12
|
-
import * as i8 from "./file-drop";
|
13
|
+
import * as i5 from "@ptsecurity/mosaic/ellipsis-center";
|
14
|
+
import * as i6 from "@ptsecurity/mosaic/link";
|
15
|
+
import * as i7 from "./file-drop";
|
13
16
|
let nextSingleFileUploadUniqueId = 0;
|
14
|
-
export const MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION =
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
17
|
+
export const MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION = ruRULocaleData['ru-RU'].fileUpload.single;
|
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.cdr.markForCheck();
|
26
|
+
}
|
19
27
|
get acceptedFiles() {
|
20
28
|
return this.accept && this.accept.length > 0 ? this.accept.map((ext) => `.${ext}`).join(',') : '*/*';
|
21
29
|
}
|
22
|
-
|
23
|
-
this.
|
24
|
-
|
30
|
+
get hasHint() {
|
31
|
+
return this.hint.length > 0;
|
32
|
+
}
|
33
|
+
/**
|
34
|
+
* Indicates an invalid state based on `errorState`,
|
35
|
+
* applying a CSS class in HTML for visual feedback.
|
36
|
+
*/
|
37
|
+
get invalid() {
|
38
|
+
return !!this.file?.hasError || this.errorState;
|
39
|
+
}
|
40
|
+
constructor(configuration) {
|
41
|
+
super();
|
42
|
+
this.configuration = configuration;
|
43
|
+
this._file = null;
|
25
44
|
this.disabled = false;
|
45
|
+
/**
|
46
|
+
* @deprecated use `FormControl.errors`
|
47
|
+
*/
|
26
48
|
this.errors = [];
|
27
|
-
this.files = [];
|
28
49
|
this.inputId = `mc-single-file-upload-${nextSingleFileUploadUniqueId++}`;
|
29
50
|
this.fileQueueChanged = new EventEmitter();
|
30
|
-
|
51
|
+
/** cvaOnChange function registered via registerOnChange (ControlValueAccessor).
|
52
|
+
* @docs-private
|
53
|
+
*/
|
54
|
+
// tslint:disable-next-line:no-empty
|
55
|
+
this.cvaOnChange = (_) => { };
|
56
|
+
/** onTouch function registered via registerOnTouch (ControlValueAccessor).
|
57
|
+
* @docs-private
|
58
|
+
*/
|
59
|
+
// tslint:disable-next-line:no-empty
|
60
|
+
this.onTouched = () => { };
|
61
|
+
this.updateLocaleParams = () => {
|
62
|
+
this.config = this.configuration || this.localeService?.getParams('fileUpload').multiple;
|
63
|
+
this.makeCaptionText();
|
64
|
+
this.cdr.markForCheck();
|
65
|
+
};
|
66
|
+
this.localeService?.changes.pipe(takeUntilDestroyed())
|
67
|
+
.subscribe(this.updateLocaleParams);
|
68
|
+
if (!this.localeService) {
|
69
|
+
this.initDefaultParams();
|
70
|
+
}
|
71
|
+
if (this.ngControl) {
|
72
|
+
// Note: we provide the value accessor through here, instead of
|
73
|
+
// the `providers` to avoid running into a circular import.
|
74
|
+
this.ngControl.valueAccessor = this;
|
75
|
+
}
|
76
|
+
}
|
77
|
+
ngAfterViewInit() {
|
78
|
+
// FormControl specific errors update
|
79
|
+
this.ngControl?.statusChanges?.pipe(distinctUntilChanged(), takeUntilDestroyed(this.destroyRef))
|
80
|
+
.subscribe((status) => {
|
81
|
+
if (this._file) {
|
82
|
+
this._file.hasError = status === 'INVALID';
|
83
|
+
}
|
84
|
+
this.errors = Object.values(this.ngControl?.errors || {});
|
85
|
+
this.cdr.markForCheck();
|
86
|
+
});
|
87
|
+
this.stateChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => this.cdr.markForCheck());
|
88
|
+
}
|
89
|
+
ngDoCheck() {
|
90
|
+
if (this.ngControl) {
|
91
|
+
// We need to re-evaluate this on every change detection cycle, because there are some
|
92
|
+
// error triggers that we can't subscribe to (e.g. parent form submissions). This means
|
93
|
+
// that whatever logic is in here has to be super lean or we risk destroying the performance.
|
94
|
+
this.updateErrorState();
|
95
|
+
}
|
96
|
+
}
|
97
|
+
/** Implemented as part of ControlValueAccessor. @docs-private */
|
98
|
+
writeValue(file) {
|
99
|
+
this.file = file instanceof File ? this.mapToFileItem(file) : file;
|
100
|
+
this.fileQueueChanged.emit(this._file);
|
101
|
+
}
|
102
|
+
/** Implemented as part of ControlValueAccessor. @docs-private */
|
103
|
+
registerOnChange(fn) { this.cvaOnChange = fn; }
|
104
|
+
/** Implemented as part of ControlValueAccessor. @docs-private */
|
105
|
+
registerOnTouched(fn) { this.onTouched = fn; }
|
106
|
+
/**
|
107
|
+
* Sets the disabled state of the control. Implemented as a part of ControlValueAccessor.
|
108
|
+
* @param isDisabled Whether the control should be disabled.
|
109
|
+
* @docs-private
|
110
|
+
*/
|
111
|
+
setDisabledState(isDisabled) {
|
112
|
+
this.disabled = isDisabled;
|
113
|
+
this.cdr.markForCheck();
|
31
114
|
}
|
32
115
|
onFileSelectedViaClick({ target }) {
|
33
116
|
if (this.disabled) {
|
34
117
|
return;
|
35
118
|
}
|
36
|
-
const files = target.files;
|
37
|
-
if (files?.length) {
|
38
|
-
this.files = [this.mapToFileItem(files[0])];
|
39
|
-
this.fileQueueChanged.emit(this.files[0]);
|
40
|
-
}
|
41
119
|
/* even if the user selects the same file,
|
42
120
|
the onchange event will be triggered every time user clicks on the control.*/
|
43
121
|
this.renderer.setProperty(this.input.nativeElement, 'value', null);
|
122
|
+
const files = target.files;
|
123
|
+
if (files?.length) {
|
124
|
+
this.file = this.mapToFileItem(files[0]);
|
125
|
+
this.fileQueueChanged.emit(this._file);
|
126
|
+
}
|
127
|
+
this.onTouched();
|
44
128
|
}
|
45
129
|
deleteItem(event) {
|
46
130
|
if (this.disabled) {
|
47
131
|
return;
|
48
132
|
}
|
49
133
|
event?.stopPropagation();
|
50
|
-
this.
|
134
|
+
this.file = null;
|
135
|
+
this.fileQueueChanged.emit(this.file);
|
51
136
|
this.errors = [];
|
52
|
-
|
137
|
+
// mark as touched after file drop even if file wasn't correct
|
138
|
+
this.onTouched();
|
53
139
|
}
|
54
140
|
onFileDropped(files) {
|
55
141
|
if (this.disabled) {
|
56
142
|
return;
|
57
143
|
}
|
58
|
-
if (this.isCorrectExtension(files[0])) {
|
59
|
-
this.
|
60
|
-
|
61
|
-
this.fileQueueChanged.emit(this.files[0]);
|
144
|
+
if (files?.length && this.isCorrectExtension(files[0])) {
|
145
|
+
this.file = this.mapToFileItem(files[0]);
|
146
|
+
this.fileQueueChanged.emit(this.file);
|
62
147
|
}
|
148
|
+
// mark as touched after file drop even if file wasn't correct
|
149
|
+
this.onTouched();
|
63
150
|
}
|
64
151
|
mapToFileItem(file) {
|
65
152
|
this.validateFile(file);
|
@@ -70,46 +157,59 @@ export class McSingleFileUploadComponent {
|
|
70
157
|
};
|
71
158
|
}
|
72
159
|
validateFile(file) {
|
73
|
-
if (this.customValidation
|
74
|
-
|
75
|
-
errors.push(validatorFn(file));
|
76
|
-
return errors;
|
77
|
-
}, []).filter(Boolean);
|
160
|
+
if (!this.customValidation?.length) {
|
161
|
+
return;
|
78
162
|
}
|
163
|
+
this.errors = this.customValidation.reduce((errors, validatorFn) => {
|
164
|
+
errors.push(validatorFn(file));
|
165
|
+
return errors;
|
166
|
+
}, []).filter(Boolean);
|
79
167
|
}
|
80
168
|
isCorrectExtension(file) {
|
81
169
|
const fileExt = file.name.split('.').pop() || '';
|
82
170
|
return this.acceptedFiles !== '*/*' && this.acceptedFiles.length > 0 ? this.acceptedFiles.includes(fileExt) : true;
|
83
171
|
}
|
84
|
-
|
85
|
-
|
172
|
+
initDefaultParams() {
|
173
|
+
this.config = MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION;
|
174
|
+
this.makeCaptionText();
|
175
|
+
}
|
176
|
+
makeCaptionText() {
|
177
|
+
this.separatedCaptionText = this.config.captionText.split('{{ browseLink }}');
|
178
|
+
}
|
179
|
+
/** @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 }); }
|
180
|
+
/** @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 }); }
|
86
181
|
}
|
87
182
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImport: i0, type: McSingleFileUploadComponent, decorators: [{
|
88
183
|
type: Component,
|
89
|
-
args: [{ selector: 'mc-single-file-upload', changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
184
|
+
args: [{ selector: 'mc-single-file-upload', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
90
185
|
class: 'mc-single-file-upload'
|
91
|
-
}, template: "<div class=\"mc-file-upload\"\n mcFileDrop\n [class.disabled]=\"disabled\"\n [class.mc-error]=\"
|
92
|
-
}], ctorParameters: () => [{ type:
|
186
|
+
}, 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"] }]
|
187
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
93
188
|
type: Optional
|
94
189
|
}, {
|
95
190
|
type: Inject,
|
96
191
|
args: [MC_FILE_UPLOAD_CONFIGURATION]
|
97
|
-
}] }], propDecorators: {
|
192
|
+
}] }], propDecorators: { file: [{
|
193
|
+
type: Input
|
194
|
+
}], accept: [{
|
98
195
|
type: Input
|
99
196
|
}], disabled: [{
|
100
197
|
type: Input
|
101
198
|
}], errors: [{
|
102
199
|
type: Input
|
103
|
-
}], files: [{
|
104
|
-
type: Input
|
105
200
|
}], inputId: [{
|
106
201
|
type: Input
|
107
202
|
}], customValidation: [{
|
108
203
|
type: Input
|
204
|
+
}], errorStateMatcher: [{
|
205
|
+
type: Input
|
109
206
|
}], fileQueueChanged: [{
|
110
207
|
type: Output
|
111
208
|
}], input: [{
|
112
209
|
type: ViewChild,
|
113
210
|
args: ['input']
|
211
|
+
}], hint: [{
|
212
|
+
type: ContentChildren,
|
213
|
+
args: [McHint]
|
114
214
|
}] } });
|
115
|
-
//# 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,\n    ElementRef,\n    EventEmitter, Inject,\n    Input, Optional,\n    Output, Renderer2,\n    ViewChild\n} from '@angular/core';\nimport { CanDisable } from '@ptsecurity/mosaic/core';\nimport { BehaviorSubject } 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 = {\n    captionText: 'Перетащите файл или',\n    browseLink: 'выберите'\n};\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 {\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    constructor(\n        private renderer: Renderer2,\n        @Optional() @Inject(MC_FILE_UPLOAD_CONFIGURATION) public config: McInputFileLabel\n    ) {\n        this.config = config || MC_SINGLE_FILE_UPLOAD_DEFAULT_CONFIGURATION;\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","<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                {{ config.captionText }}\n                <label mc-link pseudo [disabled]=\"disabled\" [tabIndex]=\"-1\" [for]=\"inputId\">\n                    {{ config.browseLink }}\n                    <input #input type=\"file\" class=\"cdk-visually-hidden\" [id]=\"inputId\" [accept]=\"acceptedFiles\" [disabled]=\"disabled\" (change)=\"onFileSelectedViaClick($event)\">\n                </label>\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"]}
|
215
|
+
//# 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.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        this.file = file instanceof File ? this.mapToFileItem(file) : file;\n        this.fileQueueChanged.emit(this._file);\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        /* 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        const files: FileList | null = (target as HTMLInputElement).files;\n        if (files?.length) {\n            this.file = this.mapToFileItem(files[0]);\n            this.fileQueueChanged.emit(this._file);\n        }\n        this.onTouched();\n    }\n\n    deleteItem(event?: MouseEvent): void {\n        if (this.disabled) { return; }\n\n        event?.stopPropagation();\n        this.file = null;\n        this.fileQueueChanged.emit(this.file);\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            this.fileQueueChanged.emit(this.file);\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"]}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { FocusMonitor } from '@angular/cdk/a11y';
|
2
2
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
3
|
-
import { Attribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, Directive, ElementRef, Optional, QueryList, Self, ViewChild, ViewEncapsulation } from '@angular/core';
|
3
|
+
import { afterNextRender, Attribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, Directive, ElementRef, Optional, QueryList, Self, ViewChild, ViewEncapsulation } from '@angular/core';
|
4
4
|
import { NgControl } from '@angular/forms';
|
5
5
|
import { ESCAPE, F8 } from '@ptsecurity/cdk/keycodes';
|
6
6
|
import { mixinColor, MC_FORM_FIELD_REF } from '@ptsecurity/mosaic/core';
|
@@ -70,7 +70,10 @@ export class McFormField extends McFormFieldMixinBase {
|
|
70
70
|
this.hovered = false;
|
71
71
|
this.canCleanerClearByEsc = true;
|
72
72
|
this.$unsubscribe = new Subject();
|
73
|
-
this.runFocusMonitor()
|
73
|
+
this.runFocusMonitor = () => {
|
74
|
+
this.focusMonitor.monitor(this.elementRef.nativeElement, true);
|
75
|
+
};
|
76
|
+
afterNextRender(this.runFocusMonitor);
|
74
77
|
}
|
75
78
|
ngAfterContentInit() {
|
76
79
|
if (this.control.numberInput && this.hasCleaner) {
|
@@ -153,9 +156,6 @@ export class McFormField extends McFormFieldMixinBase {
|
|
153
156
|
this.$unsubscribe.complete();
|
154
157
|
this.stopFocusMonitor();
|
155
158
|
}
|
156
|
-
runFocusMonitor() {
|
157
|
-
this.focusMonitor.monitor(this.elementRef.nativeElement, true);
|
158
|
-
}
|
159
159
|
stopFocusMonitor() {
|
160
160
|
this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);
|
161
161
|
}
|
@@ -264,4 +264,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
|
|
264
264
|
}, {
|
265
265
|
type: Self
|
266
266
|
}] }] });
|
267
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.js","sourceRoot":"","sources":["../../../../packages/mosaic/form-field/form-field.ts","../../../../packages/mosaic/form-field/form-field.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    AfterContentChecked,\n    AfterContentInit,\n    AfterViewInit,\n    Attribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    OnDestroy,\n    Optional,\n    QueryList,\n    Self,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { ESCAPE, F8 } from '@ptsecurity/cdk/keycodes';\nimport { CanColor, CanColorCtor, mixinColor, MC_FORM_FIELD_REF } from '@ptsecurity/mosaic/core';\nimport { EMPTY, merge, Subject } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\n\nimport { McCleaner } from './cleaner';\nimport { McFormFieldControl } from './form-field-control';\nimport {\n    getMcFormFieldMissingControlError,\n    getMcFormFieldYouCanNotUseCleanerInNumberInputError\n} from './form-field-errors';\nimport { McHint } from './hint';\nimport { hasPasswordStrengthError, McPasswordHint } from './password-hint';\nimport { McPrefix } from './prefix';\nimport { McStepper } from './stepper';\nimport { McSuffix } from './suffix';\n\n\nlet nextUniqueId = 0;\n\n\n/** @docs-private */\nexport class McFormFieldBase {\n    constructor(public elementRef: ElementRef) {}\n}\n\n/** @docs-private */\nexport const McFormFieldMixinBase: CanColorCtor & typeof McFormFieldBase = mixinColor(McFormFieldBase);\n\n@Component({\n    selector: 'mc-form-field',\n    exportAs: 'mcFormField',\n    templateUrl: 'form-field.html',\n    // McInput is a directive and can't have styles, so we need to include its styles here.\n    // The McInput styles are fairly minimal so it shouldn't be a big deal for people who\n    // aren't using McInput.\n    styleUrls: [\n        'form-field.scss',\n        '../input/input.scss',\n        '../timepicker/timepicker.scss',\n        '../datepicker/datepicker-input.scss',\n        '../textarea/textarea.scss'\n    ],\n    host: {\n        class: 'mc-form-field',\n        '[class.mc-form-field_invalid]': 'control.errorState',\n        '[class.mc-form-field_has-prefix]': 'hasPrefix',\n        '[class.mc-form-field_has-suffix]': 'hasSuffix',\n        '[class.mc-form-field_has-cleaner]': 'canShowCleaner',\n        '[class.mc-form-field_has-stepper]': 'canShowStepper',\n\n        '[class.mc-disabled]': 'control.disabled',\n\n        '[class.ng-untouched]': 'shouldForward(\"untouched\")',\n        '[class.ng-touched]': 'shouldForward(\"touched\")',\n        '[class.ng-pristine]': 'shouldForward(\"pristine\")',\n        '[class.ng-dirty]': 'shouldForward(\"dirty\")',\n        '[class.ng-valid]': 'shouldForward(\"valid\")',\n        '[class.ng-invalid]': 'shouldForward(\"invalid\")',\n        '[class.ng-pending]': 'shouldForward(\"pending\")',\n\n        '(keydown)': 'onKeyDown($event)',\n        '(mouseenter)': 'onHoverChanged(true)',\n        '(mouseleave)': 'onHoverChanged(false)'\n    },\n    inputs: ['color'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{ provide: MC_FORM_FIELD_REF, useExisting: McFormField }]\n})\nexport class McFormField extends McFormFieldMixinBase implements\n    AfterContentInit, AfterContentChecked, AfterViewInit, CanColor, OnDestroy {\n\n    @ContentChild(McFormFieldControl, { static: false }) control: McFormFieldControl<any>;\n    @ContentChild(McStepper, { static: false }) stepper: McStepper;\n    @ContentChild(McCleaner, { static: false }) cleaner: McCleaner | null;\n\n    @ContentChildren(McHint) hint: QueryList<McHint>;\n    @ContentChildren(McPasswordHint) passwordHints: QueryList<McPasswordHint>;\n    @ContentChildren(McSuffix) suffix: QueryList<McSuffix>;\n    @ContentChildren(McPrefix) prefix: QueryList<McPrefix>;\n\n    @ViewChild('connectionContainer', { static: true }) connectionContainerRef: ElementRef;\n\n    // Unique id for the internal form field label.\n    labelId = `mc-form-field-label-${nextUniqueId++}`;\n\n    hovered: boolean = false;\n\n\n    canCleanerClearByEsc: boolean = true;\n\n    private $unsubscribe = new Subject<void>();\n\n    get hasFocus(): boolean {\n        return this.control.focused;\n    }\n\n    get hasHint(): boolean {\n        return this.hint?.length > 0;\n    }\n\n    get hasSuffix(): boolean {\n        return this.suffix?.length > 0;\n    }\n\n    get hasPrefix(): boolean {\n        return this.prefix?.length > 0;\n    }\n\n    get hasCleaner(): boolean {\n        return !!this.cleaner;\n    }\n\n    get hasStepper(): boolean {\n        return !!this.stepper;\n    }\n\n    get canShowCleaner(): boolean {\n        return this.hasCleaner &&\n        this.control?.ngControl\n            ? this.control.ngControl.value && !this.control.disabled\n            : false;\n    }\n\n    get disabled(): boolean {\n        return this.control?.disabled;\n    }\n\n    get canShowStepper(): boolean {\n        return this.hasStepper &&\n            !this.disabled &&\n            (this.control?.focused || this.hovered);\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        private changeDetectorRef: ChangeDetectorRef,\n        private focusMonitor: FocusMonitor\n    ) {\n        super(elementRef);\n\n        this.runFocusMonitor();\n    }\n\n    ngAfterContentInit() {\n        if ((this.control as any).numberInput && this.hasCleaner) {\n            this.cleaner = null;\n            throw getMcFormFieldYouCanNotUseCleanerInNumberInputError();\n        }\n\n        this.validateControlChild();\n\n        if (this.control.controlType) {\n            this.elementRef.nativeElement.classList.add(`mc-form-field-type-${this.control.controlType}`);\n        }\n\n        // Subscribe to changes in the child control state in order to update the form field UI.\n        this.control.stateChanges\n            .pipe(startWith())\n            .subscribe((state: any) => {\n                if (this.passwordHints.length && !state?.focused && hasPasswordStrengthError(this.passwordHints)) {\n                    this.control.ngControl?.control?.setErrors({ passwordStrength: true });\n                }\n\n                this.changeDetectorRef.markForCheck();\n            });\n\n        if (this.hasStepper) {\n            this.stepper.connectTo((this.control as any).numberInput);\n        }\n\n        // Run change detection if the value changes.\n        const valueChanges = this.control.ngControl?.valueChanges || EMPTY;\n\n        merge(valueChanges)\n            .pipe(takeUntil(this.$unsubscribe))\n            .subscribe(() => this.changeDetectorRef.markForCheck());\n    }\n\n    ngAfterContentChecked() {\n        this.validateControlChild();\n    }\n\n    ngAfterViewInit() {\n        // Avoid animations on load.\n        this.changeDetectorRef.detectChanges();\n    }\n\n    focusViaKeyboard(): void {\n        this.control.focus();\n    }\n\n    clearValue($event) {\n        $event.stopPropagation();\n\n        this.control?.ngControl?.reset();\n        this.control?.focus();\n    }\n\n    onContainerClick($event) {\n        if (this.control.onContainerClick) {\n            this.control.onContainerClick($event);\n        }\n    }\n\n    onKeyDown(event: KeyboardEvent): void {\n        // tslint:disable-next-line:deprecation\n        if (this.control.controlType === 'input-password' && event.altKey && event.keyCode === F8) {\n            (this.control as unknown as { toggleType(): void }).toggleType();\n        }\n        // tslint:disable-next-line:deprecation\n        if (this.canCleanerClearByEsc && event.keyCode === ESCAPE && this.control.focused && this.hasCleaner) {\n            this.control?.ngControl?.reset();\n\n            event.preventDefault();\n        }\n    }\n\n    onHoverChanged(isHovered: boolean) {\n        if (isHovered !== this.hovered) {\n            this.hovered = isHovered;\n            this.changeDetectorRef.markForCheck();\n        }\n    }\n\n    /**\n     * Gets an ElementRef for the element that a overlay attached to the form-field should be\n     * positioned relative to.\n     */\n    getConnectedOverlayOrigin(): ElementRef {\n        return this.connectionContainerRef || this.elementRef;\n    }\n\n    /** Determines whether a class from the NgControl should be forwarded to the host element. */\n    shouldForward(prop: keyof NgControl): boolean {\n        const ngControl = this.control?.ngControl;\n\n        return ngControl && ngControl[prop];\n    }\n\n    ngOnDestroy(): void {\n        this.$unsubscribe.next();\n        this.$unsubscribe.complete();\n\n        this.stopFocusMonitor();\n    }\n\n    runFocusMonitor() {\n        this.focusMonitor.monitor(this.elementRef.nativeElement, true);\n    }\n\n    stopFocusMonitor() {\n        this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);\n    }\n\n    /** Throws an error if the form field's control is missing. */\n    protected validateControlChild() {\n        if (!this.control) {\n            throw getMcFormFieldMissingControlError();\n        }\n    }\n}\n\n@Directive({\n    selector: 'mc-form-field[mcFormFieldWithoutBorders]',\n    exportAs: 'mcFormFieldWithoutBorders',\n    host: { class: 'mc-form-field_without-borders' }\n})\nexport class McFormFieldWithoutBorders {}\n\n\n@Directive({\n    selector: '[mcInput], [mcTextarea]',\n    exportAs: 'McTrim',\n    host: { class: 'mc-trim' }\n})\nexport class McTrim {\n    private original: (fn: any) => void;\n\n    constructor(\n        @Attribute('no-trim') private readonly noTrim: boolean,\n        @Optional() @Self() private ngControl: NgControl\n    ) {\n        this.noTrim = coerceBooleanProperty(noTrim);\n\n        if (this.noTrim || !this.ngControl?.valueAccessor) { return; }\n\n        this.original = this.ngControl.valueAccessor.registerOnChange;\n\n        this.ngControl.valueAccessor.registerOnChange = this.registerOnChange;\n    }\n\n    trim(value) {\n        if (this.noTrim) { return value; }\n\n        return typeof value === 'string' ? value.trim() : value;\n    }\n\n    private registerOnChange = (fn) => {\n        return this.original.call(this.ngControl.valueAccessor, (value) => fn(this.trim(value)));\n    }\n}\n","<div class=\"mc-form-field__container\" (click)=\"onContainerClick($event)\" #connectionContainer>\n\n    <div class=\"mc-form-field__prefix\" *ngIf=\"hasPrefix\">\n        <ng-content select=\"[mcPrefix]\"></ng-content>\n    </div>\n\n    <div class=\"mc-form-field__infix\">\n        <ng-content></ng-content>\n    </div>\n\n    <div class=\"mc-form-field__suffix\" *ngIf=\"hasSuffix\">\n        <ng-content select=\"[mcSuffix]\"></ng-content>\n    </div>\n\n    <div class=\"mc-form-field__cleaner\"\n         *ngIf=\"canShowCleaner && !hasSuffix\"\n         (click)=\"clearValue($event)\">\n        <ng-content select=\"mc-cleaner\"></ng-content>\n    </div>\n\n    <ng-content select=\"mc-password-toggle\"></ng-content>\n\n    <ng-content *ngIf=\"canShowStepper\" select=\"mc-stepper\"></ng-content>\n</div>\n\n<div class=\"mc-form-field__hint\">\n    <ng-content select=\"mc-hint, mc-password-hint\"></ng-content>\n</div>\n"]}
|
267
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.js","sourceRoot":"","sources":["../../../../packages/mosaic/form-field/form-field.ts","../../../../packages/mosaic/form-field/form-field.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    AfterContentChecked,\n    AfterContentInit,\n    afterNextRender,\n    AfterViewInit,\n    Attribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    OnDestroy,\n    Optional,\n    QueryList,\n    Self,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { ESCAPE, F8 } from '@ptsecurity/cdk/keycodes';\nimport { CanColor, CanColorCtor, mixinColor, MC_FORM_FIELD_REF } from '@ptsecurity/mosaic/core';\nimport { EMPTY, merge, Subject } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\n\nimport { McCleaner } from './cleaner';\nimport { McFormFieldControl } from './form-field-control';\nimport {\n    getMcFormFieldMissingControlError,\n    getMcFormFieldYouCanNotUseCleanerInNumberInputError\n} from './form-field-errors';\nimport { McHint } from './hint';\nimport { hasPasswordStrengthError, McPasswordHint } from './password-hint';\nimport { McPrefix } from './prefix';\nimport { McStepper } from './stepper';\nimport { McSuffix } from './suffix';\n\n\nlet nextUniqueId = 0;\n\n\n/** @docs-private */\nexport class McFormFieldBase {\n    constructor(public elementRef: ElementRef) {}\n}\n\n/** @docs-private */\nexport const McFormFieldMixinBase: CanColorCtor & typeof McFormFieldBase = mixinColor(McFormFieldBase);\n\n@Component({\n    selector: 'mc-form-field',\n    exportAs: 'mcFormField',\n    templateUrl: 'form-field.html',\n    // McInput is a directive and can't have styles, so we need to include its styles here.\n    // The McInput styles are fairly minimal so it shouldn't be a big deal for people who\n    // aren't using McInput.\n    styleUrls: [\n        'form-field.scss',\n        '../input/input.scss',\n        '../timepicker/timepicker.scss',\n        '../datepicker/datepicker-input.scss',\n        '../textarea/textarea.scss'\n    ],\n    host: {\n        class: 'mc-form-field',\n        '[class.mc-form-field_invalid]': 'control.errorState',\n        '[class.mc-form-field_has-prefix]': 'hasPrefix',\n        '[class.mc-form-field_has-suffix]': 'hasSuffix',\n        '[class.mc-form-field_has-cleaner]': 'canShowCleaner',\n        '[class.mc-form-field_has-stepper]': 'canShowStepper',\n\n        '[class.mc-disabled]': 'control.disabled',\n\n        '[class.ng-untouched]': 'shouldForward(\"untouched\")',\n        '[class.ng-touched]': 'shouldForward(\"touched\")',\n        '[class.ng-pristine]': 'shouldForward(\"pristine\")',\n        '[class.ng-dirty]': 'shouldForward(\"dirty\")',\n        '[class.ng-valid]': 'shouldForward(\"valid\")',\n        '[class.ng-invalid]': 'shouldForward(\"invalid\")',\n        '[class.ng-pending]': 'shouldForward(\"pending\")',\n\n        '(keydown)': 'onKeyDown($event)',\n        '(mouseenter)': 'onHoverChanged(true)',\n        '(mouseleave)': 'onHoverChanged(false)'\n    },\n    inputs: ['color'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{ provide: MC_FORM_FIELD_REF, useExisting: McFormField }]\n})\nexport class McFormField extends McFormFieldMixinBase implements\n    AfterContentInit, AfterContentChecked, AfterViewInit, CanColor, OnDestroy {\n\n    @ContentChild(McFormFieldControl, { static: false }) control: McFormFieldControl<any>;\n    @ContentChild(McStepper, { static: false }) stepper: McStepper;\n    @ContentChild(McCleaner, { static: false }) cleaner: McCleaner | null;\n\n    @ContentChildren(McHint) hint: QueryList<McHint>;\n    @ContentChildren(McPasswordHint) passwordHints: QueryList<McPasswordHint>;\n    @ContentChildren(McSuffix) suffix: QueryList<McSuffix>;\n    @ContentChildren(McPrefix) prefix: QueryList<McPrefix>;\n\n    @ViewChild('connectionContainer', { static: true }) connectionContainerRef: ElementRef;\n\n    // Unique id for the internal form field label.\n    labelId = `mc-form-field-label-${nextUniqueId++}`;\n\n    hovered: boolean = false;\n\n\n    canCleanerClearByEsc: boolean = true;\n\n    private $unsubscribe = new Subject<void>();\n\n    get hasFocus(): boolean {\n        return this.control.focused;\n    }\n\n    get hasHint(): boolean {\n        return this.hint?.length > 0;\n    }\n\n    get hasSuffix(): boolean {\n        return this.suffix?.length > 0;\n    }\n\n    get hasPrefix(): boolean {\n        return this.prefix?.length > 0;\n    }\n\n    get hasCleaner(): boolean {\n        return !!this.cleaner;\n    }\n\n    get hasStepper(): boolean {\n        return !!this.stepper;\n    }\n\n    get canShowCleaner(): boolean {\n        return this.hasCleaner &&\n        this.control?.ngControl\n            ? this.control.ngControl.value && !this.control.disabled\n            : false;\n    }\n\n    get disabled(): boolean {\n        return this.control?.disabled;\n    }\n\n    get canShowStepper(): boolean {\n        return this.hasStepper &&\n            !this.disabled &&\n            (this.control?.focused || this.hovered);\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        private changeDetectorRef: ChangeDetectorRef,\n        private focusMonitor: FocusMonitor\n    ) {\n        super(elementRef);\n\n        afterNextRender(this.runFocusMonitor);\n    }\n\n    ngAfterContentInit() {\n        if ((this.control as any).numberInput && this.hasCleaner) {\n            this.cleaner = null;\n            throw getMcFormFieldYouCanNotUseCleanerInNumberInputError();\n        }\n\n        this.validateControlChild();\n\n        if (this.control.controlType) {\n            this.elementRef.nativeElement.classList.add(`mc-form-field-type-${this.control.controlType}`);\n        }\n\n        // Subscribe to changes in the child control state in order to update the form field UI.\n        this.control.stateChanges\n            .pipe(startWith())\n            .subscribe((state: any) => {\n                if (this.passwordHints.length && !state?.focused && hasPasswordStrengthError(this.passwordHints)) {\n                    this.control.ngControl?.control?.setErrors({ passwordStrength: true });\n                }\n\n                this.changeDetectorRef.markForCheck();\n            });\n\n        if (this.hasStepper) {\n            this.stepper.connectTo((this.control as any).numberInput);\n        }\n\n        // Run change detection if the value changes.\n        const valueChanges = this.control.ngControl?.valueChanges || EMPTY;\n\n        merge(valueChanges)\n            .pipe(takeUntil(this.$unsubscribe))\n            .subscribe(() => this.changeDetectorRef.markForCheck());\n    }\n\n    ngAfterContentChecked() {\n        this.validateControlChild();\n    }\n\n    ngAfterViewInit() {\n        // Avoid animations on load.\n        this.changeDetectorRef.detectChanges();\n    }\n\n    focusViaKeyboard(): void {\n        this.control.focus();\n    }\n\n    clearValue($event) {\n        $event.stopPropagation();\n\n        this.control?.ngControl?.reset();\n        this.control?.focus();\n    }\n\n    onContainerClick($event) {\n        if (this.control.onContainerClick) {\n            this.control.onContainerClick($event);\n        }\n    }\n\n    onKeyDown(event: KeyboardEvent): void {\n        // tslint:disable-next-line:deprecation\n        if (this.control.controlType === 'input-password' && event.altKey && event.keyCode === F8) {\n            (this.control as unknown as { toggleType(): void }).toggleType();\n        }\n        // tslint:disable-next-line:deprecation\n        if (this.canCleanerClearByEsc && event.keyCode === ESCAPE && this.control.focused && this.hasCleaner) {\n            this.control?.ngControl?.reset();\n\n            event.preventDefault();\n        }\n    }\n\n    onHoverChanged(isHovered: boolean) {\n        if (isHovered !== this.hovered) {\n            this.hovered = isHovered;\n            this.changeDetectorRef.markForCheck();\n        }\n    }\n\n    /**\n     * Gets an ElementRef for the element that a overlay attached to the form-field should be\n     * positioned relative to.\n     */\n    getConnectedOverlayOrigin(): ElementRef {\n        return this.connectionContainerRef || this.elementRef;\n    }\n\n    /** Determines whether a class from the NgControl should be forwarded to the host element. */\n    shouldForward(prop: keyof NgControl): boolean {\n        const ngControl = this.control?.ngControl;\n\n        return ngControl && ngControl[prop];\n    }\n\n    ngOnDestroy(): void {\n        this.$unsubscribe.next();\n        this.$unsubscribe.complete();\n\n        this.stopFocusMonitor();\n    }\n\n    runFocusMonitor = () => {\n        this.focusMonitor.monitor(this.elementRef.nativeElement, true);\n    }\n\n    stopFocusMonitor() {\n        this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);\n    }\n\n    /** Throws an error if the form field's control is missing. */\n    protected validateControlChild() {\n        if (!this.control) {\n            throw getMcFormFieldMissingControlError();\n        }\n    }\n}\n\n@Directive({\n    selector: 'mc-form-field[mcFormFieldWithoutBorders]',\n    exportAs: 'mcFormFieldWithoutBorders',\n    host: { class: 'mc-form-field_without-borders' }\n})\nexport class McFormFieldWithoutBorders {}\n\n\n@Directive({\n    selector: '[mcInput], [mcTextarea]',\n    exportAs: 'McTrim',\n    host: { class: 'mc-trim' }\n})\nexport class McTrim {\n    private original: (fn: any) => void;\n\n    constructor(\n        @Attribute('no-trim') private readonly noTrim: boolean,\n        @Optional() @Self() private ngControl: NgControl\n    ) {\n        this.noTrim = coerceBooleanProperty(noTrim);\n\n        if (this.noTrim || !this.ngControl?.valueAccessor) { return; }\n\n        this.original = this.ngControl.valueAccessor.registerOnChange;\n\n        this.ngControl.valueAccessor.registerOnChange = this.registerOnChange;\n    }\n\n    trim(value) {\n        if (this.noTrim) { return value; }\n\n        return typeof value === 'string' ? value.trim() : value;\n    }\n\n    private registerOnChange = (fn) => {\n        return this.original.call(this.ngControl.valueAccessor, (value) => fn(this.trim(value)));\n    }\n}\n","<div class=\"mc-form-field__container\" (click)=\"onContainerClick($event)\" #connectionContainer>\n\n    <div class=\"mc-form-field__prefix\" *ngIf=\"hasPrefix\">\n        <ng-content select=\"[mcPrefix]\"></ng-content>\n    </div>\n\n    <div class=\"mc-form-field__infix\">\n        <ng-content></ng-content>\n    </div>\n\n    <div class=\"mc-form-field__suffix\" *ngIf=\"hasSuffix\">\n        <ng-content select=\"[mcSuffix]\"></ng-content>\n    </div>\n\n    <div class=\"mc-form-field__cleaner\"\n         *ngIf=\"canShowCleaner && !hasSuffix\"\n         (click)=\"clearValue($event)\">\n        <ng-content select=\"mc-cleaner\"></ng-content>\n    </div>\n\n    <ng-content select=\"mc-password-toggle\"></ng-content>\n\n    <ng-content *ngIf=\"canShowStepper\" select=\"mc-stepper\"></ng-content>\n</div>\n\n<div class=\"mc-form-field__hint\">\n    <ng-content select=\"mc-hint, mc-password-hint\"></ng-content>\n</div>\n"]}
|