myrta-ui 13.0.10 → 13.0.12
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/esm2020/lib/components/form/input-file/input-file.component.mjs +32 -27
- package/esm2020/lib/components/form/input-number/input-number.component.mjs +7 -4
- package/esm2020/lib/components/pdf-viewer/pdf-viewer.component.mjs +2 -2
- package/fesm2015/myrta-ui.mjs +38 -30
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +38 -30
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/lib/components/form/input-file/input-file.component.d.ts +5 -5
- package/lib/components/form/input-number/input-number.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -78,7 +78,9 @@ export class InputFileComponent {
|
|
|
78
78
|
if (this.showInputWithError) {
|
|
79
79
|
return this.maxFiles > this.files.filter(s => !s.error).length;
|
|
80
80
|
}
|
|
81
|
-
|
|
81
|
+
else {
|
|
82
|
+
return this.maxFiles > this.files.length;
|
|
83
|
+
}
|
|
82
84
|
}
|
|
83
85
|
get getTarget() {
|
|
84
86
|
return InputFileTargetTypesEnum[this.target];
|
|
@@ -113,13 +115,13 @@ export class InputFileComponent {
|
|
|
113
115
|
const findFile = this.files.find(s => s.uuid === file.uuid);
|
|
114
116
|
if (findFile) {
|
|
115
117
|
if (this.deleteEndPoint) {
|
|
116
|
-
const formData = this.
|
|
118
|
+
const formData = this._createFormData();
|
|
117
119
|
formData.append('Qquuid', file.uuid);
|
|
118
120
|
findFile.deleting = true;
|
|
119
121
|
if (this.autoUpload) {
|
|
120
122
|
this.fileUploadService.delete(this.deleteEndPoint, formData).subscribe(result => {
|
|
121
123
|
this.files.splice(this.files.indexOf(findFile), 1);
|
|
122
|
-
this.
|
|
124
|
+
this._validateUploadedAllFiles();
|
|
123
125
|
this.filesChanged.emit(this.files);
|
|
124
126
|
});
|
|
125
127
|
}
|
|
@@ -129,7 +131,7 @@ export class InputFileComponent {
|
|
|
129
131
|
}
|
|
130
132
|
else {
|
|
131
133
|
this.files.splice(this.files.indexOf(findFile), 1);
|
|
132
|
-
this.
|
|
134
|
+
this._validateUploadedAllFiles();
|
|
133
135
|
this.filesChanged.emit(this.files);
|
|
134
136
|
}
|
|
135
137
|
}
|
|
@@ -140,19 +142,6 @@ export class InputFileComponent {
|
|
|
140
142
|
canCancelUploading(file) {
|
|
141
143
|
return !!file.uploading && file.percentage ? file.percentage < 90 : false;
|
|
142
144
|
}
|
|
143
|
-
validateUploadedAllFiles() {
|
|
144
|
-
for (let i = 0; i < this.files.length; i++) {
|
|
145
|
-
const data = this.files[i];
|
|
146
|
-
data.error = undefined;
|
|
147
|
-
this.checkForUpload(data, true);
|
|
148
|
-
if (this.maxFiles <= i) {
|
|
149
|
-
data.error = this.messageTooManyFiles;
|
|
150
|
-
}
|
|
151
|
-
else if (!data.error) {
|
|
152
|
-
data.uuid = data.uuid || data.tempUuid || '';
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
145
|
clear(file) {
|
|
157
146
|
if (file.uploading) {
|
|
158
147
|
if (file.execution) {
|
|
@@ -164,7 +153,7 @@ export class InputFileComponent {
|
|
|
164
153
|
this.files.splice(findFileIdx, 1);
|
|
165
154
|
this.filesChanged.emit(this.files);
|
|
166
155
|
}
|
|
167
|
-
this.
|
|
156
|
+
this._validateUploadedAllFiles();
|
|
168
157
|
}
|
|
169
158
|
downloadUrl(file) {
|
|
170
159
|
if (file.url && !file.size) {
|
|
@@ -182,7 +171,7 @@ export class InputFileComponent {
|
|
|
182
171
|
if (droppedFile.fileEntry.isFile) {
|
|
183
172
|
const fileEntry = droppedFile.fileEntry;
|
|
184
173
|
fileEntry.file((file) => {
|
|
185
|
-
this.
|
|
174
|
+
this._uploadFile(file);
|
|
186
175
|
});
|
|
187
176
|
}
|
|
188
177
|
else {
|
|
@@ -191,19 +180,32 @@ export class InputFileComponent {
|
|
|
191
180
|
}
|
|
192
181
|
}
|
|
193
182
|
}
|
|
194
|
-
|
|
183
|
+
_validateUploadedAllFiles() {
|
|
184
|
+
for (let i = 0; i < this.files.length; i++) {
|
|
185
|
+
const data = this.files[i];
|
|
186
|
+
data.error = undefined;
|
|
187
|
+
this._checkForUpload(data, true);
|
|
188
|
+
if (this.maxFiles <= i) {
|
|
189
|
+
data.error = this.messageTooManyFiles;
|
|
190
|
+
}
|
|
191
|
+
else if (!data.error) {
|
|
192
|
+
data.uuid = data.uuid || data.tempUuid || '';
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
_formDataKeys() {
|
|
195
197
|
return Object.keys(this.formData);
|
|
196
198
|
}
|
|
197
|
-
|
|
199
|
+
_createFormData() {
|
|
198
200
|
const form = new FormData();
|
|
199
201
|
if (this.maxFiles) {
|
|
200
202
|
form.append('MaxFiles', this.maxFiles.toString(10));
|
|
201
203
|
}
|
|
202
|
-
const keys = this.
|
|
204
|
+
const keys = this._formDataKeys();
|
|
203
205
|
keys.forEach(key => form.append(key, this.formData[key]));
|
|
204
206
|
return form;
|
|
205
207
|
}
|
|
206
|
-
|
|
208
|
+
_uploadFile(file) {
|
|
207
209
|
const data = {
|
|
208
210
|
uuid: '',
|
|
209
211
|
tempUuid: uuidv4(),
|
|
@@ -213,10 +215,13 @@ export class InputFileComponent {
|
|
|
213
215
|
percentage: 0,
|
|
214
216
|
file: file
|
|
215
217
|
};
|
|
216
|
-
if (!this.
|
|
218
|
+
if (!this._checkForUpload(data)) {
|
|
219
|
+
if (!this.autoUpload) {
|
|
220
|
+
this.filesChanged.emit(this.files);
|
|
221
|
+
}
|
|
217
222
|
return;
|
|
218
223
|
}
|
|
219
|
-
const formData = this.
|
|
224
|
+
const formData = this._createFormData();
|
|
220
225
|
formData.append('File', file);
|
|
221
226
|
if (this.uploadAdditionalData && Object.keys(this.uploadAdditionalData).length) {
|
|
222
227
|
Object.keys(this.uploadAdditionalData).forEach(key => {
|
|
@@ -265,7 +270,7 @@ export class InputFileComponent {
|
|
|
265
270
|
}
|
|
266
271
|
}
|
|
267
272
|
}
|
|
268
|
-
|
|
273
|
+
_checkForUpload(data, existing) {
|
|
269
274
|
this.checkDroppedFile.emit(data);
|
|
270
275
|
if (!this.canAdd && !existing) {
|
|
271
276
|
data.error = this.messageTooManyFiles;
|
|
@@ -376,4 +381,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
376
381
|
}], checkDroppedFile: [{
|
|
377
382
|
type: Output
|
|
378
383
|
}] } });
|
|
379
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-file.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-file/input-file.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-file/input-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\r\nimport { NgxFileDropEntry } from 'ngx-file-drop';\r\nimport { HttpEvent, HttpEventType } from '@angular/common/http';\r\nimport { catchError } from 'rxjs/operators';\r\nimport { EMPTY } from 'rxjs';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { InputFileModel, UploadedFileModel, UploadedResultModel } from '../../../models/input-file/input-file.model';\r\nimport { formatBytes } from '../../../helpers/extension/input-file.extension';\r\nimport { FileUploadService } from '../../../services/file-upload/file-upload.service';\r\nimport { ErrorMessagesEnum } from './enums/error-messages.enum';\r\nimport { InputFileTargetTypes, InputFileTargetTypesEnum } from './input-file.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-file',\r\n  templateUrl: './input-file.component.html',\r\n  styleUrls: ['./input-file.component.less'],\r\n})\r\nexport class InputFileComponent {\r\n  formatBytes = formatBytes;\r\n  extensions?: string;\r\n  allowedExtensions: string[] = [];\r\n  files: InputFileModel[] = [];\r\n\r\n  @Input() public autoUpload = true;\r\n  @Input() public required = false;\r\n  @Input() public readonly = false;\r\n  @Input() public viewOnly = false;\r\n  @Input() public disabled = false;\r\n  @Input() public bottomFiles = false;\r\n  @Input() public maxSize = 31457280;\r\n  @Input() public maxFiles = 5;\r\n  @Input() public minFiles = 0;\r\n  @Input() public formData: any = {}; // Параметры, которые будут передаваться в форме\r\n  @Input() public uploadEndPoint!: string;\r\n  @Input() public deleteEndPoint?: string;\r\n  @Input() public downloadEndPoint?: string;\r\n  @Input() public fileNamePlaceholder?: string;\r\n  @Input() public showInputWithError = true;\r\n  @Input() public showDeleteButton = true;\r\n  @Input() public isTooltipValue = false;\r\n  @Input() public isDownloadingFile = true;\r\n  @Input() public isHideListFiles = false;\r\n  @Input() public target: InputFileTargetTypes = '_self';\r\n  @Input() public deleteConfirm?: (file: UploadedFileModel, result: (ok: boolean) => void) => void;\r\n\r\n  @Input() public innerTemplate!: TemplateRef<any>;\r\n\r\n  @Input() public uploadAdditionalData: any = {};\r\n\r\n  // ERROR\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  // ERROR MESSAGES\r\n  @Input() public messageTooManyFiles: string = ErrorMessagesEnum.TooManyFiles;\r\n  @Input() public messageFileTooBig: string = ErrorMessagesEnum.FileTooBig;\r\n  @Input() public messageEmptyFile: string = ErrorMessagesEnum.EmptyFile;\r\n  @Input() public messageInvalidFileFormat: string = ErrorMessagesEnum.InvalidFileFormat;\r\n\r\n  // PLACEHOLDERS\r\n  @Input() public placeholder = 'Перенесите файл с устройства или нажмите на данное поле для добавления файла';\r\n  @Input() public placeholderFileMaxSize = 'Размер файла: не больше';\r\n  @Input() public placeholderFileFormat = 'Формат файла:';\r\n\r\n  @Input('files')\r\n  set initFiles(data: UploadedFileModel[] | UploadedFileModel) {\r\n    if (data) {\r\n      if (Array.isArray(data)) {\r\n        this.files = data.map(s => ({ ...s }));\r\n      } else {\r\n        this.files = [{ ...data }];\r\n      }\r\n    } else {\r\n      this.files = [];\r\n    }\r\n  }\r\n\r\n  @Input('allowedExtensions')\r\n  public set initAllowedExtensions(val: string[]) {\r\n    if (val) {\r\n      this.allowedExtensions = val;\r\n      this.extensions = val.join(', ');\r\n    } else {\r\n      this.allowedExtensions = [];\r\n      this.extensions = undefined;\r\n    }\r\n  }\r\n\r\n  @Output() public filesChanged: EventEmitter<InputFileModel[]> = new EventEmitter();\r\n  @Output() public checkDroppedFile: EventEmitter<InputFileModel> = new EventEmitter();\r\n\r\n  constructor(private fileUploadService: FileUploadService) {\r\n  }\r\n\r\n  get canAdd(): boolean {\r\n    if (this.showInputWithError) {\r\n      return this.maxFiles > this.files.filter(s => !s.error).length;\r\n    } \r\n    return this.maxFiles > this.files.length;\r\n  }\r\n\r\n  public get getTarget(): string {\r\n    return InputFileTargetTypesEnum[this.target]\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage.length;\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get isValid(): boolean {\r\n    return this.baseValidate();\r\n  }\r\n\r\n  public getTooltipValue(value: string | undefined): string {\r\n    return this.isTooltipValue && value ? value : ''\r\n  }\r\n\r\n  protected baseValidate(): boolean {\r\n    return true;\r\n  }\r\n\r\n  trackByFn(index: number, item: InputFileModel) {\r\n    return Boolean(item.uuid) ? item.uuid : item.tempUuid;\r\n  }\r\n\r\n  delete(file: UploadedFileModel): void {\r\n    if (this.deleteConfirm) {\r\n      this.deleteConfirm(file, (ok) => {\r\n        if (ok) {\r\n          const findFile = this.files.find(s => s.uuid === file.uuid);\r\n          if (findFile) {\r\n            if (this.deleteEndPoint) {\r\n              const formData = this.createFormData();\r\n              formData.append('Qquuid', file.uuid);\r\n              findFile.deleting = true;\r\n\r\n              if (this.autoUpload) {\r\n                this.fileUploadService.delete(this.deleteEndPoint, formData).subscribe(result => {\r\n                  this.files.splice(this.files.indexOf(findFile), 1);\r\n                  this.validateUploadedAllFiles();\r\n                  this.filesChanged.emit(this.files);\r\n                });\r\n              } else {\r\n                this.clear(file);\r\n              }\r\n\r\n            } else {\r\n              this.files.splice(this.files.indexOf(findFile), 1);\r\n              this.validateUploadedAllFiles();\r\n              this.filesChanged.emit(this.files);\r\n            }\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  canCancelUploading(file: InputFileModel): boolean {\r\n    return !!file.uploading && file.percentage ? file.percentage < 90 : false;\r\n  }\r\n\r\n  private validateUploadedAllFiles() {\r\n    for(let i=0; i < this.files.length; i++) {\r\n      const data = this.files[i];\r\n      data.error = undefined;\r\n      this.checkForUpload(data, true);      \r\n      if(this.maxFiles <= i) {\r\n        data.error = this.messageTooManyFiles; \r\n      } else if(!data.error) {\r\n        data.uuid = data.uuid || data.tempUuid || '';\r\n      }\r\n    }\r\n  }\r\n\r\n  clear(file: InputFileModel): void {\r\n    if (file.uploading) {\r\n      if (file.execution) {\r\n        file.execution.unsubscribe();\r\n      }\r\n    }\r\n\r\n    const findFileIdx = this.files.indexOf(file);\r\n    if (findFileIdx >= 0) {\r\n      this.files.splice(findFileIdx, 1);\r\n      this.filesChanged.emit(this.files);\r\n    }\r\n    this.validateUploadedAllFiles();\r\n\r\n  }\r\n\r\n  downloadUrl(file: UploadedFileModel): string {\r\n    if (file.url && !file.size) {\r\n      return file.url;\r\n    } else {\r\n      if (this.downloadEndPoint) {\r\n        return `${this.downloadEndPoint}?uuid=${file.uuid}`;\r\n      }\r\n      return '#';\r\n    }\r\n  }\r\n\r\n  public dropped(files: NgxFileDropEntry[]) {\r\n    for (const droppedFile of files) {\r\n      if (droppedFile.fileEntry.isFile) {\r\n        const fileEntry = droppedFile.fileEntry as FileSystemFileEntry;\r\n        fileEntry.file((file: File) => {\r\n          this.uploadFile(file);\r\n        });\r\n      } else {\r\n        // It was a directory (empty directories are added, otherwise only files)\r\n        const fileEntry = droppedFile.fileEntry as FileSystemDirectoryEntry;\r\n      }\r\n    }\r\n  }\r\n\r\n  private formDataKeys(): string[] {\r\n    return Object.keys(this.formData);\r\n  }\r\n\r\n  private createFormData(): FormData {\r\n    const form = new FormData();\r\n    if (this.maxFiles) {\r\n      form.append('MaxFiles', this.maxFiles.toString(10));\r\n    }\r\n    const keys = this.formDataKeys();\r\n    keys.forEach(key => form.append(key, this.formData[key]));\r\n    return form;\r\n  }\r\n\r\n  private uploadFile(file: File): void {\r\n    const data = {\r\n      uuid: '',\r\n      tempUuid: uuidv4(),\r\n      name: file.name,\r\n      size: file.size,\r\n      uploading: true,\r\n      percentage: 0,\r\n      file: file\r\n    } as InputFileModel;\r\n\r\n    if (!this.checkForUpload(data)) {\r\n      return;\r\n    }\r\n\r\n    const formData = this.createFormData();\r\n    formData.append('File', file);\r\n\r\n    if (this.uploadAdditionalData && Object.keys(this.uploadAdditionalData).length) {\r\n      Object.keys(this.uploadAdditionalData).forEach(key => {\r\n        formData.append(key, this.uploadAdditionalData[key]);\r\n      })\r\n    }\r\n\r\n    if (this.autoUpload) {\r\n      data.execution = this.fileUploadService.upload(this.uploadEndPoint, formData).pipe(\r\n        catchError((err) => {\r\n          data.uploading = false;\r\n          return EMPTY;\r\n        })\r\n      )\r\n        .subscribe((event: HttpEvent<UploadedResultModel>) => {\r\n          switch (event.type) {\r\n            case HttpEventType.Sent:\r\n              break;\r\n            case HttpEventType.ResponseHeader:\r\n              break;\r\n            case HttpEventType.UploadProgress:\r\n              if (event.total) {\r\n                data.percentage = Math.round(event.loaded / event.total * 100);\r\n              }\r\n              break;\r\n            case HttpEventType.Response:\r\n              if (event.body) {\r\n                data.uploading = false;\r\n                data.percentage = 0;\r\n                data.uuid = event.body.uuid;\r\n                data.file = undefined;\r\n                data.error = event.body.message;\r\n                if (data.execution) {\r\n                  data.execution.unsubscribe();\r\n                }\r\n\r\n                if (this.files.every(s => !s.uploading)) {\r\n                  const completedFiles = this.files.filter(s => !s.error);\r\n                  this.filesChanged.emit(completedFiles);\r\n                }\r\n              }\r\n          }\r\n        });\r\n    } else {\r\n      data.uploading = false;\r\n      data.uuid = data.tempUuid || '';\r\n\r\n      if (this.files.every(s => !s.uploading)) {\r\n        this.filesChanged.emit(this.files);\r\n      }\r\n    }\r\n  }\r\n\r\n  private checkForUpload(data: InputFileModel, existing?: boolean): boolean {\r\n    this.checkDroppedFile.emit(data)\r\n\r\n    if (!this.canAdd && !existing) {\r\n      data.error = this.messageTooManyFiles;\r\n      data.uploading = false;\r\n      this.files.push(data);\r\n      return false;\r\n    }\r\n\r\n    if(!existing) {\r\n      this.files.push(data);\r\n    }\r\n\r\n    if (data.file && data.file.size > this.maxSize) {\r\n      data.error = this.messageFileTooBig;\r\n      data.uploading = false;\r\n      return false;\r\n    }\r\n\r\n    if (data.file && data.file.size == 0) {\r\n      data.error = this.messageEmptyFile;\r\n      data.uploading = false;\r\n      return false;\r\n    }\r\n\r\n    if (this.allowedExtensions.length > 0 && !this.allowedExtensions.some(\r\n      s => data.file && data.file.name.toLowerCase().endsWith(s.toLowerCase()))) {\r\n\r\n      data.error = this.messageInvalidFileFormat;\r\n      data.uploading = false;\r\n      return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n}\r\n","<div\r\n  class=\"ng-form-file-input\"\r\n  [class]=\"getClasses\"\r\n  [class.mrx-input-error]=\"invalid\">\r\n  <div class=\"form-row\" *ngIf=\"readonly; else notReadonly\">\r\n    <div *ngIf=\"!files || files.length == 0\"\r\n         class=\"col-sm-12 col-md-6\"\r\n    >\r\n      <div class=\"d-flex align-items-center color-tertiary\">\r\n        <div class=\"mrx-icon icon-file icon-font-24 mr-2\"></div>\r\n        <span>Документов нет</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"col-12\">\r\n      <ul class=\"new-custom-file-input\" *ngIf=\"files.length\">\r\n        <li\r\n          class=\"new-custom-file-input__item\"\r\n          *ngFor=\"let file of files; trackBy: trackByFn\"\r\n        >\r\n          <div class=\"qq-file-info\">\r\n            <div class=\"d-flex align-items-center\">\r\n              <span class=\"mrx-icon icon-file icon-font-24 mr-2\"></span>\r\n              <a\r\n                class=\"qq-upload-file-selector qq-upload-file\"\r\n                [target]=\"getTarget\"\r\n                [href]=\"downloadUrl(file)\"\r\n                [title]=\"fileNamePlaceholder ? fileNamePlaceholder : file.name\"\r\n              >{{fileNamePlaceholder ? fileNamePlaceholder : file.name}}</a>\r\n            </div>\r\n            <div class=\"info\">\r\n              <span class=\"qq-upload-size-selector qq-upload-size\" *ngIf=\"!file.error\">{{formatBytes(file.size)}}</span>\r\n            </div>\r\n          </div>\r\n        </li>\r\n      </ul>\r\n    </div>\r\n    <ng-container *ngTemplateOutlet=\"innerTemplate; context:{}\"></ng-container>\r\n  </div>\r\n\r\n  <ng-template #notReadonly>\r\n    <ng-container *ngIf=\"!bottomFiles && !isHideListFiles\">\r\n      <ng-container *ngTemplateOutlet=\"fileListTemplate\"></ng-container>\r\n      <ng-container *ngTemplateOutlet=\"innerTemplate; context:{}\"></ng-container>\r\n    </ng-container>\r\n\r\n    <ngx-file-drop\r\n      *ngIf=\"canAdd\"\r\n      [className]=\"'ng-custom-file-input'\"\r\n      [accept]=\"extensions || ''\"\r\n      [disabled]=\"disabled\"\r\n      [ngClass]=\"{'ng-custom-file-input--disabled': disabled}\"\r\n      (onFileDrop)=\"dropped($event)\"\r\n    >\r\n      <ng-template ngx-file-drop-content-tmp let-openFileSelector=\"openFileSelector\">\r\n        <div\r\n          class=\"ng-custom-file-input-content\"\r\n          (click)=\"!disabled ? openFileSelector() : undefined\"\r\n        >\r\n          <div class=\"text-center\">\r\n            <div class=\"ng-custom-file-input-content--placeholder mb-2\">\r\n              {{placeholder}}\r\n            </div>\r\n            <div class=\"ng-custom-file-input-content--size mb-1\">\r\n              {{placeholderFileMaxSize}} {{formatBytes(maxSize)}}\r\n            </div>\r\n            <div class=\"ng-custom-file-input-content--extensions\" *ngIf=\"extensions\">\r\n              {{placeholderFileFormat}} {{extensions}}\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n    </ngx-file-drop>\r\n\r\n    <ng-container *ngIf=\"bottomFiles && !isHideListFiles\">\r\n      <ng-container *ngTemplateOutlet=\"fileListTemplate\"></ng-container>\r\n      <ng-container *ngTemplateOutlet=\"innerTemplate; context:{}\"></ng-container>\r\n    </ng-container>\r\n  </ng-template>\r\n</div>\r\n\r\n<mrx-error-message\r\n  *ngIf=\"(!isValid || invalid) && isInvalidMessage\"\r\n  [invalidMessage]=\"invalidMessage\"\r\n></mrx-error-message>\r\n\r\n<ng-template #fileListTemplate>\r\n  <ul class=\"new-custom-file-input\" *ngIf=\"files.length\">\r\n    <li\r\n      class=\"new-custom-file-input__item\"\r\n      *ngFor=\"let file of files; trackBy: trackByFn\"\r\n      [ngClass]=\"{'file-error': file.error}\"\r\n      [mrxCdkTooltip]=\"getTooltipValue(fileNamePlaceholder ? fileNamePlaceholder : file.name || '')\"\r\n      [tooltipPosition]=\"'top-start'\"\r\n    >\r\n      <ng-container *ngIf=\"autoUpload\">\r\n        <a class=\"qq-download-link\" [target]=\"getTarget\" [href]=\"downloadUrl(file)\" *ngIf=\"file.uuid && isDownloadingFile\"></a>\r\n      </ng-container>\r\n      <div class=\"qq-file-info\">\r\n        <div class=\"d-flex align-items-center\">\r\n          <span class=\"mrx-icon icon-file icon-font-24 mr-2\"></span>\r\n          <span\r\n            class=\"qq-upload-file-selector qq-upload-file\"\r\n            [title]=\"fileNamePlaceholder ? fileNamePlaceholder : file.name\"\r\n          >{{fileNamePlaceholder ? fileNamePlaceholder : file.name}}</span>\r\n        </div>\r\n        <div class=\"info\">\r\n          <div class=\"ng-custom-file-input_progress\" *ngIf=\"file.uploading\">\r\n            <span [ngStyle]=\"{width: file.percentage + '%'}\"></span>\r\n          </div>\r\n\r\n          <span class=\"qq-upload-size-selector qq-upload-size\" *ngIf=\"!file.error\">{{formatBytes(file.size)}}</span>\r\n          <span\r\n            *ngIf=\"!readonly && file.uuid && showDeleteButton && !viewOnly\"\r\n            (click)=\"delete(file)\"\r\n            class=\"mrx-icon icon-delete icon-font-24 cursor-pointer\"\r\n            aria-label=\"Удалить\"\r\n          ></span>\r\n\r\n          <div class=\"ng-custom-file-input-error\" *ngIf=\"file.error\">\r\n            <span class=\"mrx-icon icon-attention icon-color-red icon-font-16 mr-1\"></span>\r\n            <span class=\"color-negative\">{{file.error}}</span>\r\n          </div>\r\n\r\n          <div\r\n            class=\"mrx-icon icon-close icon-font-24 cursor-pointer ml-2\"\r\n            *ngIf=\"(file.error && !file.uuid) || canCancelUploading(file) && !viewOnly\"\r\n            (click)=\"clear(file)\"\r\n          ></div>\r\n        </div>\r\n      </div>\r\n    </li>\r\n  </ul>\r\n</ng-template>\r\n"]}
|
|
384
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-file.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-file/input-file.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-file/input-file.component.html"],"names":[],"mappings":"AAAA,OAAO,EAA2B,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAe,MAAM,eAAe,CAAC;AAE7G,OAAO,EAAa,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AAEpC,OAAO,EAAE,WAAW,EAAE,MAAM,iDAAiD,CAAC;AAE9E,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAwB,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;;;;;;;AAOnF,MAAM,OAAO,kBAAkB;IA2E7B,YAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;QA1ExD,gBAAW,GAAG,WAAW,CAAC;QAE1B,sBAAiB,GAAa,EAAE,CAAC;QACjC,UAAK,GAAqB,EAAE,CAAC;QAEb,eAAU,GAAG,IAAI,CAAC;QAClB,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,gBAAW,GAAG,KAAK,CAAC;QACpB,YAAO,GAAG,QAAQ,CAAC;QACnB,aAAQ,GAAG,CAAC,CAAC;QACb,aAAQ,GAAG,CAAC,CAAC;QACb,aAAQ,GAAQ,EAAE,CAAC,CAAC,gDAAgD;QAKpE,uBAAkB,GAAG,IAAI,CAAC;QAC1B,qBAAgB,GAAG,IAAI,CAAC;QACxB,mBAAc,GAAG,KAAK,CAAC;QACvB,sBAAiB,GAAG,IAAI,CAAC;QACzB,oBAAe,GAAG,KAAK,CAAC;QACxB,WAAM,GAAyB,OAAO,CAAC;QAKvC,yBAAoB,GAAQ,EAAE,CAAC;QAE/C,QAAQ;QACQ,YAAO,GAAG,KAAK,CAAC;QAChB,mBAAc,GAAsB,EAAE,CAAC;QACvC,iBAAY,GAAwB,IAAI,CAAC;QAEzD,iBAAiB;QACD,wBAAmB,GAAW,iBAAiB,CAAC,YAAY,CAAC;QAC7D,sBAAiB,GAAW,iBAAiB,CAAC,UAAU,CAAC;QACzD,qBAAgB,GAAW,iBAAiB,CAAC,SAAS,CAAC;QACvD,6BAAwB,GAAW,iBAAiB,CAAC,iBAAiB,CAAC;QAEvF,eAAe;QACC,gBAAW,GAAG,8EAA8E,CAAC;QAC7F,2BAAsB,GAAG,yBAAyB,CAAC;QACnD,0BAAqB,GAAG,eAAe,CAAC;QA0BvC,iBAAY,GAAmC,IAAI,YAAY,EAAE,CAAC;QAClE,qBAAgB,GAAiC,IAAI,YAAY,EAAE,CAAC;IAGrF,CAAC;IA5BD,IACI,SAAS,CAAC,IAA6C;QACzD,IAAI,IAAI,EAAE;YACR,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAC,CAAC,CAAC,CAAC;aACtC;iBAAM;gBACL,IAAI,CAAC,KAAK,GAAG,CAAC,EAAC,GAAG,IAAI,EAAC,CAAC,CAAC;aAC1B;SACF;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;SACjB;IACH,CAAC;IAED,IACW,qBAAqB,CAAC,GAAa;QAC5C,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC;YAC7B,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAClC;aAAM;YACL,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;YAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;SAC7B;IACH,CAAC;IAQD,IAAI,MAAM;QACR,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,OAAO,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC;SAChE;aAAM;YACL,OAAO,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;SAC1C;IACH,CAAC;IAED,IAAW,SAAS;QAClB,OAAO,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAC9C,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;IAC/D,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,YAAY,KAAK,KAAK,CAAC,CAAC;YAClC,2BAA2B,CAAC,CAAC;YAC7B,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,CAAC;IAChE,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;IACrC,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC;IAC7B,CAAC;IAEM,eAAe,CAAC,KAAyB;QAC9C,OAAO,IAAI,CAAC,cAAc,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAA;IAClD,CAAC;IAES,YAAY;QACpB,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,SAAS,CAAC,KAAa,EAAE,IAAoB;QAClD,OAAO,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;IACxD,CAAC;IAEM,MAAM,CAAC,IAAuB;QACnC,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,EAAE;gBAC9B,IAAI,EAAE,EAAE;oBACN,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC5D,IAAI,QAAQ,EAAE;wBACZ,IAAI,IAAI,CAAC,cAAc,EAAE;4BACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;4BACxC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;4BACrC,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC;4BAEzB,IAAI,IAAI,CAAC,UAAU,EAAE;gCACnB,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;oCAC9E,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;oCACnD,IAAI,CAAC,yBAAyB,EAAE,CAAC;oCACjC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gCACrC,CAAC,CAAC,CAAC;6BACJ;iCAAM;gCACL,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;6BAClB;yBAEF;6BAAM;4BACL,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;4BACnD,IAAI,CAAC,yBAAyB,EAAE,CAAC;4BACjC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;yBACpC;qBACF;iBACF;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEM,kBAAkB,CAAC,IAAoB;QAC5C,OAAO,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;IAC5E,CAAC;IAEM,KAAK,CAAC,IAAoB;QAC/B,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;aAC9B;SACF;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,WAAW,IAAI,CAAC,EAAE;YACpB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACpC;QACD,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAEM,WAAW,CAAC,IAAuB;QACxC,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YAC1B,OAAO,IAAI,CAAC,GAAG,CAAC;SACjB;aAAM;YACL,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACzB,OAAO,GAAG,IAAI,CAAC,gBAAgB,SAAS,IAAI,CAAC,IAAI,EAAE,CAAC;aACrD;YACD,OAAO,GAAG,CAAC;SACZ;IACH,CAAC;IAEM,OAAO,CAAC,KAAyB;QACtC,KAAK,MAAM,WAAW,IAAI,KAAK,EAAE;YAC/B,IAAI,WAAW,CAAC,SAAS,CAAC,MAAM,EAAE;gBAChC,MAAM,SAAS,GAAG,WAAW,CAAC,SAAgC,CAAC;gBAC/D,SAAS,CAAC,IAAI,CAAC,CAAC,IAAU,EAAE,EAAE;oBAC5B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBACzB,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,yEAAyE;gBACzE,MAAM,SAAS,GAAG,WAAW,CAAC,SAAqC,CAAC;aACrE;SACF;IACH,CAAC;IAEO,yBAAyB;QAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC1C,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC3B,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;YACvB,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACjC,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,EAAE;gBACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,mBAAmB,CAAC;aACvC;iBAAM,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;gBACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;aAC9C;SACF;IACH,CAAC;IAEO,aAAa;QACnB,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAEO,eAAe;QACrB,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAC;QAC5B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;SACrD;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC1D,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,WAAW,CAAC,IAAU;QAC5B,MAAM,IAAI,GAAG;YACX,IAAI,EAAE,EAAE;YACR,QAAQ,EAAE,MAAM,EAAE;YAClB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,SAAS,EAAE,IAAI;YACf,UAAU,EAAE,CAAC;YACb,IAAI,EAAE,IAAI;SACO,CAAC;QAEpB,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE;YAC/B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBACpB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACpC;YACD,OAAO;SACR;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACxC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAE9B,IAAI,IAAI,CAAC,oBAAoB,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,MAAM,EAAE;YAC9E,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACnD,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC;YACvD,CAAC,CAAC,CAAA;SACH;QAED,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC,IAAI,CAChF,UAAU,CAAC,CAAC,GAAG,EAAE,EAAE;gBACjB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CACH;iBACE,SAAS,CAAC,CAAC,KAAqC,EAAE,EAAE;gBACnD,QAAQ,KAAK,CAAC,IAAI,EAAE;oBAClB,KAAK,aAAa,CAAC,IAAI;wBACrB,MAAM;oBACR,KAAK,aAAa,CAAC,cAAc;wBAC/B,MAAM;oBACR,KAAK,aAAa,CAAC,cAAc;wBAC/B,IAAI,KAAK,CAAC,KAAK,EAAE;4BACf,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;yBAChE;wBACD,MAAM;oBACR,KAAK,aAAa,CAAC,QAAQ;wBACzB,IAAI,KAAK,CAAC,IAAI,EAAE;4BACd,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;4BACvB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;4BACpB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC;4BAC5B,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;4BACtB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC;4BAChC,IAAI,IAAI,CAAC,SAAS,EAAE;gCAClB,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;6BAC9B;4BAED,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;gCACvC,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gCACxD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;6BACxC;yBACF;iBACJ;YACH,CAAC,CAAC,CAAC;SACN;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;YAEhC,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;gBACvC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACpC;SACF;IACH,CAAC;IAEO,eAAe,CAAC,IAAoB,EAAE,QAAkB;QAC9D,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAEhC,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE;YAC7B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,mBAAmB,CAAC;YACtC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACtB,OAAO,KAAK,CAAC;SACd;QAED,IAAI,CAAC,QAAQ,EAAE;YACb,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACvB;QAED,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE;YAC9C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC;YACpC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,OAAO,KAAK,CAAC;SACd;QAED,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE;YACpC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC;YACnC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,OAAO,KAAK,CAAC;SACd;QAED,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CACnE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE;YAE3E,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,wBAAwB,CAAC;YAC3C,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,OAAO,KAAK,CAAC;SACd;QAED,OAAO,IAAI,CAAC;IACd,CAAC;;+GA3UU,kBAAkB;mGAAlB,kBAAkB,uzCCjB/B,gtLAsIA;2FDrHa,kBAAkB;kBAL9B,SAAS;+BACE,gBAAgB;wGAUV,UAAU;sBAAzB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBACU,kBAAkB;sBAAjC,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBACU,eAAe;sBAA9B,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBAEU,aAAa;sBAA5B,KAAK;gBAEU,oBAAoB;sBAAnC,KAAK;gBAGU,OAAO;sBAAtB,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBAGU,mBAAmB;sBAAlC,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,wBAAwB;sBAAvC,KAAK;gBAGU,WAAW;sBAA1B,KAAK;gBACU,sBAAsB;sBAArC,KAAK;gBACU,qBAAqB;sBAApC,KAAK;gBAGF,SAAS;sBADZ,KAAK;uBAAC,OAAO;gBAcH,qBAAqB;sBAD/B,KAAK;uBAAC,mBAAmB;gBAWT,YAAY;sBAA5B,MAAM;gBACU,gBAAgB;sBAAhC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\r\nimport { NgxFileDropEntry } from 'ngx-file-drop';\r\nimport { HttpEvent, HttpEventType } from '@angular/common/http';\r\nimport { catchError } from 'rxjs/operators';\r\nimport { EMPTY } from 'rxjs';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { InputFileModel, UploadedFileModel, UploadedResultModel } from '../../../models/input-file/input-file.model';\r\nimport { formatBytes } from '../../../helpers/extension/input-file.extension';\r\nimport { FileUploadService } from '../../../services/file-upload/file-upload.service';\r\nimport { ErrorMessagesEnum } from './enums/error-messages.enum';\r\nimport { InputFileTargetTypes, InputFileTargetTypesEnum } from './input-file.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-file',\r\n  templateUrl: './input-file.component.html',\r\n  styleUrls: ['./input-file.component.less'],\r\n})\r\nexport class InputFileComponent {\r\n  formatBytes = formatBytes;\r\n  extensions?: string;\r\n  allowedExtensions: string[] = [];\r\n  files: InputFileModel[] = [];\r\n\r\n  @Input() public autoUpload = true;\r\n  @Input() public required = false;\r\n  @Input() public readonly = false;\r\n  @Input() public viewOnly = false;\r\n  @Input() public disabled = false;\r\n  @Input() public bottomFiles = false;\r\n  @Input() public maxSize = 31457280;\r\n  @Input() public maxFiles = 5;\r\n  @Input() public minFiles = 0;\r\n  @Input() public formData: any = {}; // Параметры, которые будут передаваться в форме\r\n  @Input() public uploadEndPoint!: string;\r\n  @Input() public deleteEndPoint?: string;\r\n  @Input() public downloadEndPoint?: string;\r\n  @Input() public fileNamePlaceholder?: string;\r\n  @Input() public showInputWithError = true;\r\n  @Input() public showDeleteButton = true;\r\n  @Input() public isTooltipValue = false;\r\n  @Input() public isDownloadingFile = true;\r\n  @Input() public isHideListFiles = false;\r\n  @Input() public target: InputFileTargetTypes = '_self';\r\n  @Input() public deleteConfirm?: (file: UploadedFileModel, result: (ok: boolean) => void) => void;\r\n\r\n  @Input() public innerTemplate!: TemplateRef<any>;\r\n\r\n  @Input() public uploadAdditionalData: any = {};\r\n\r\n  // ERROR\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  // ERROR MESSAGES\r\n  @Input() public messageTooManyFiles: string = ErrorMessagesEnum.TooManyFiles;\r\n  @Input() public messageFileTooBig: string = ErrorMessagesEnum.FileTooBig;\r\n  @Input() public messageEmptyFile: string = ErrorMessagesEnum.EmptyFile;\r\n  @Input() public messageInvalidFileFormat: string = ErrorMessagesEnum.InvalidFileFormat;\r\n\r\n  // PLACEHOLDERS\r\n  @Input() public placeholder = 'Перенесите файл с устройства или нажмите на данное поле для добавления файла';\r\n  @Input() public placeholderFileMaxSize = 'Размер файла: не больше';\r\n  @Input() public placeholderFileFormat = 'Формат файла:';\r\n\r\n  @Input('files')\r\n  set initFiles(data: UploadedFileModel[] | UploadedFileModel) {\r\n    if (data) {\r\n      if (Array.isArray(data)) {\r\n        this.files = data.map(s => ({...s}));\r\n      } else {\r\n        this.files = [{...data}];\r\n      }\r\n    } else {\r\n      this.files = [];\r\n    }\r\n  }\r\n\r\n  @Input('allowedExtensions')\r\n  public set initAllowedExtensions(val: string[]) {\r\n    if (val) {\r\n      this.allowedExtensions = val;\r\n      this.extensions = val.join(', ');\r\n    } else {\r\n      this.allowedExtensions = [];\r\n      this.extensions = undefined;\r\n    }\r\n  }\r\n\r\n  @Output() public filesChanged: EventEmitter<InputFileModel[]> = new EventEmitter();\r\n  @Output() public checkDroppedFile: EventEmitter<InputFileModel> = new EventEmitter();\r\n\r\n  constructor(private fileUploadService: FileUploadService) {\r\n  }\r\n\r\n  get canAdd(): boolean {\r\n    if (this.showInputWithError) {\r\n      return this.maxFiles > this.files.filter(s => !s.error).length;\r\n    } else {\r\n      return this.maxFiles > this.files.length;\r\n    }\r\n  }\r\n\r\n  public get getTarget(): string {\r\n    return InputFileTargetTypesEnum[this.target]\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage.length;\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get isValid(): boolean {\r\n    return this.baseValidate();\r\n  }\r\n\r\n  public getTooltipValue(value: string | undefined): string {\r\n    return this.isTooltipValue && value ? value : ''\r\n  }\r\n\r\n  protected baseValidate(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public trackByFn(index: number, item: InputFileModel) {\r\n    return Boolean(item.uuid) ? item.uuid : item.tempUuid;\r\n  }\r\n\r\n  public delete(file: UploadedFileModel): void {\r\n    if (this.deleteConfirm) {\r\n      this.deleteConfirm(file, (ok) => {\r\n        if (ok) {\r\n          const findFile = this.files.find(s => s.uuid === file.uuid);\r\n          if (findFile) {\r\n            if (this.deleteEndPoint) {\r\n              const formData = this._createFormData();\r\n              formData.append('Qquuid', file.uuid);\r\n              findFile.deleting = true;\r\n\r\n              if (this.autoUpload) {\r\n                this.fileUploadService.delete(this.deleteEndPoint, formData).subscribe(result => {\r\n                  this.files.splice(this.files.indexOf(findFile), 1);\r\n                  this._validateUploadedAllFiles();\r\n                  this.filesChanged.emit(this.files);\r\n                });\r\n              } else {\r\n                this.clear(file);\r\n              }\r\n\r\n            } else {\r\n              this.files.splice(this.files.indexOf(findFile), 1);\r\n              this._validateUploadedAllFiles();\r\n              this.filesChanged.emit(this.files);\r\n            }\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public canCancelUploading(file: InputFileModel): boolean {\r\n    return !!file.uploading && file.percentage ? file.percentage < 90 : false;\r\n  }\r\n\r\n  public clear(file: InputFileModel): void {\r\n    if (file.uploading) {\r\n      if (file.execution) {\r\n        file.execution.unsubscribe();\r\n      }\r\n    }\r\n\r\n    const findFileIdx = this.files.indexOf(file);\r\n    if (findFileIdx >= 0) {\r\n      this.files.splice(findFileIdx, 1);\r\n      this.filesChanged.emit(this.files);\r\n    }\r\n    this._validateUploadedAllFiles();\r\n  }\r\n\r\n  public downloadUrl(file: UploadedFileModel): string {\r\n    if (file.url && !file.size) {\r\n      return file.url;\r\n    } else {\r\n      if (this.downloadEndPoint) {\r\n        return `${this.downloadEndPoint}?uuid=${file.uuid}`;\r\n      }\r\n      return '#';\r\n    }\r\n  }\r\n\r\n  public dropped(files: NgxFileDropEntry[]) {\r\n    for (const droppedFile of files) {\r\n      if (droppedFile.fileEntry.isFile) {\r\n        const fileEntry = droppedFile.fileEntry as FileSystemFileEntry;\r\n        fileEntry.file((file: File) => {\r\n          this._uploadFile(file);\r\n        });\r\n      } else {\r\n        // It was a directory (empty directories are added, otherwise only files)\r\n        const fileEntry = droppedFile.fileEntry as FileSystemDirectoryEntry;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _validateUploadedAllFiles() {\r\n    for (let i = 0; i < this.files.length; i++) {\r\n      const data = this.files[i];\r\n      data.error = undefined;\r\n      this._checkForUpload(data, true);\r\n      if (this.maxFiles <= i) {\r\n        data.error = this.messageTooManyFiles;\r\n      } else if (!data.error) {\r\n        data.uuid = data.uuid || data.tempUuid || '';\r\n      }\r\n    }\r\n  }\r\n\r\n  private _formDataKeys(): string[] {\r\n    return Object.keys(this.formData);\r\n  }\r\n\r\n  private _createFormData(): FormData {\r\n    const form = new FormData();\r\n    if (this.maxFiles) {\r\n      form.append('MaxFiles', this.maxFiles.toString(10));\r\n    }\r\n    const keys = this._formDataKeys();\r\n    keys.forEach(key => form.append(key, this.formData[key]));\r\n    return form;\r\n  }\r\n\r\n  private _uploadFile(file: File): void {\r\n    const data = {\r\n      uuid: '',\r\n      tempUuid: uuidv4(),\r\n      name: file.name,\r\n      size: file.size,\r\n      uploading: true,\r\n      percentage: 0,\r\n      file: file\r\n    } as InputFileModel;\r\n\r\n    if (!this._checkForUpload(data)) {\r\n      if (!this.autoUpload) {\r\n        this.filesChanged.emit(this.files);\r\n      }\r\n      return;\r\n    }\r\n\r\n    const formData = this._createFormData();\r\n    formData.append('File', file);\r\n\r\n    if (this.uploadAdditionalData && Object.keys(this.uploadAdditionalData).length) {\r\n      Object.keys(this.uploadAdditionalData).forEach(key => {\r\n        formData.append(key, this.uploadAdditionalData[key]);\r\n      })\r\n    }\r\n\r\n    if (this.autoUpload) {\r\n      data.execution = this.fileUploadService.upload(this.uploadEndPoint, formData).pipe(\r\n        catchError((err) => {\r\n          data.uploading = false;\r\n          return EMPTY;\r\n        })\r\n      )\r\n        .subscribe((event: HttpEvent<UploadedResultModel>) => {\r\n          switch (event.type) {\r\n            case HttpEventType.Sent:\r\n              break;\r\n            case HttpEventType.ResponseHeader:\r\n              break;\r\n            case HttpEventType.UploadProgress:\r\n              if (event.total) {\r\n                data.percentage = Math.round(event.loaded / event.total * 100);\r\n              }\r\n              break;\r\n            case HttpEventType.Response:\r\n              if (event.body) {\r\n                data.uploading = false;\r\n                data.percentage = 0;\r\n                data.uuid = event.body.uuid;\r\n                data.file = undefined;\r\n                data.error = event.body.message;\r\n                if (data.execution) {\r\n                  data.execution.unsubscribe();\r\n                }\r\n\r\n                if (this.files.every(s => !s.uploading)) {\r\n                  const completedFiles = this.files.filter(s => !s.error);\r\n                  this.filesChanged.emit(completedFiles);\r\n                }\r\n              }\r\n          }\r\n        });\r\n    } else {\r\n      data.uploading = false;\r\n      data.uuid = data.tempUuid || '';\r\n\r\n      if (this.files.every(s => !s.uploading)) {\r\n        this.filesChanged.emit(this.files);\r\n      }\r\n    }\r\n  }\r\n\r\n  private _checkForUpload(data: InputFileModel, existing?: boolean): boolean {\r\n    this.checkDroppedFile.emit(data)\r\n\r\n    if (!this.canAdd && !existing) {\r\n      data.error = this.messageTooManyFiles;\r\n      data.uploading = false;\r\n      this.files.push(data);\r\n      return false;\r\n    }\r\n\r\n    if (!existing) {\r\n      this.files.push(data);\r\n    }\r\n\r\n    if (data.file && data.file.size > this.maxSize) {\r\n      data.error = this.messageFileTooBig;\r\n      data.uploading = false;\r\n      return false;\r\n    }\r\n\r\n    if (data.file && data.file.size == 0) {\r\n      data.error = this.messageEmptyFile;\r\n      data.uploading = false;\r\n      return false;\r\n    }\r\n\r\n    if (this.allowedExtensions.length > 0 && !this.allowedExtensions.some(\r\n      s => data.file && data.file.name.toLowerCase().endsWith(s.toLowerCase()))) {\r\n\r\n      data.error = this.messageInvalidFileFormat;\r\n      data.uploading = false;\r\n      return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n}\r\n","<div\r\n  class=\"ng-form-file-input\"\r\n  [class]=\"getClasses\"\r\n  [class.mrx-input-error]=\"invalid\">\r\n  <div class=\"form-row\" *ngIf=\"readonly; else notReadonly\">\r\n    <div *ngIf=\"!files || files.length == 0\"\r\n         class=\"col-sm-12 col-md-6\"\r\n    >\r\n      <div class=\"d-flex align-items-center color-tertiary\">\r\n        <div class=\"mrx-icon icon-file icon-font-24 mr-2\"></div>\r\n        <span>Документов нет</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"col-12\">\r\n      <ul class=\"new-custom-file-input\" *ngIf=\"files.length\">\r\n        <li\r\n          class=\"new-custom-file-input__item\"\r\n          *ngFor=\"let file of files; trackBy: trackByFn\"\r\n        >\r\n          <div class=\"qq-file-info\">\r\n            <div class=\"d-flex align-items-center\">\r\n              <span class=\"mrx-icon icon-file icon-font-24 mr-2\"></span>\r\n              <a\r\n                class=\"qq-upload-file-selector qq-upload-file\"\r\n                [target]=\"getTarget\"\r\n                [href]=\"downloadUrl(file)\"\r\n                [title]=\"fileNamePlaceholder ? fileNamePlaceholder : file.name\"\r\n              >{{fileNamePlaceholder ? fileNamePlaceholder : file.name}}</a>\r\n            </div>\r\n            <div class=\"info\">\r\n              <span class=\"qq-upload-size-selector qq-upload-size\" *ngIf=\"!file.error\">{{formatBytes(file.size)}}</span>\r\n            </div>\r\n          </div>\r\n        </li>\r\n      </ul>\r\n    </div>\r\n    <ng-container *ngTemplateOutlet=\"innerTemplate; context:{}\"></ng-container>\r\n  </div>\r\n\r\n  <ng-template #notReadonly>\r\n    <ng-container *ngIf=\"!bottomFiles && !isHideListFiles\">\r\n      <ng-container *ngTemplateOutlet=\"fileListTemplate\"></ng-container>\r\n      <ng-container *ngTemplateOutlet=\"innerTemplate; context:{}\"></ng-container>\r\n    </ng-container>\r\n\r\n    <ngx-file-drop\r\n      *ngIf=\"canAdd\"\r\n      [className]=\"'ng-custom-file-input'\"\r\n      [accept]=\"extensions || ''\"\r\n      [disabled]=\"disabled\"\r\n      [ngClass]=\"{'ng-custom-file-input--disabled': disabled}\"\r\n      (onFileDrop)=\"dropped($event)\"\r\n    >\r\n      <ng-template ngx-file-drop-content-tmp let-openFileSelector=\"openFileSelector\">\r\n        <div\r\n          class=\"ng-custom-file-input-content\"\r\n          (click)=\"!disabled ? openFileSelector() : undefined\"\r\n        >\r\n          <div class=\"text-center\">\r\n            <div class=\"ng-custom-file-input-content--placeholder mb-2\">\r\n              {{placeholder}}\r\n            </div>\r\n            <div class=\"ng-custom-file-input-content--size mb-1\">\r\n              {{placeholderFileMaxSize}} {{formatBytes(maxSize)}}\r\n            </div>\r\n            <div class=\"ng-custom-file-input-content--extensions\" *ngIf=\"extensions\">\r\n              {{placeholderFileFormat}} {{extensions}}\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n    </ngx-file-drop>\r\n\r\n    <ng-container *ngIf=\"bottomFiles && !isHideListFiles\">\r\n      <ng-container *ngTemplateOutlet=\"fileListTemplate\"></ng-container>\r\n      <ng-container *ngTemplateOutlet=\"innerTemplate; context:{}\"></ng-container>\r\n    </ng-container>\r\n  </ng-template>\r\n</div>\r\n\r\n<mrx-error-message\r\n  *ngIf=\"(!isValid || invalid) && isInvalidMessage\"\r\n  [invalidMessage]=\"invalidMessage\"\r\n></mrx-error-message>\r\n\r\n<ng-template #fileListTemplate>\r\n  <ul class=\"new-custom-file-input\" *ngIf=\"files.length\">\r\n    <li\r\n      class=\"new-custom-file-input__item\"\r\n      *ngFor=\"let file of files; trackBy: trackByFn\"\r\n      [ngClass]=\"{'file-error': file.error}\"\r\n      [mrxCdkTooltip]=\"getTooltipValue(fileNamePlaceholder ? fileNamePlaceholder : file.name || '')\"\r\n      [tooltipPosition]=\"'top-start'\"\r\n    >\r\n      <ng-container *ngIf=\"autoUpload\">\r\n        <a class=\"qq-download-link\" [target]=\"getTarget\" [href]=\"downloadUrl(file)\" *ngIf=\"file.uuid && isDownloadingFile\"></a>\r\n      </ng-container>\r\n      <div class=\"qq-file-info\">\r\n        <div class=\"d-flex align-items-center\">\r\n          <span class=\"mrx-icon icon-file icon-font-24 mr-2\"></span>\r\n          <span\r\n            class=\"qq-upload-file-selector qq-upload-file\"\r\n            [title]=\"fileNamePlaceholder ? fileNamePlaceholder : file.name\"\r\n          >{{fileNamePlaceholder ? fileNamePlaceholder : file.name}}</span>\r\n        </div>\r\n        <div class=\"info\">\r\n          <div class=\"ng-custom-file-input_progress\" *ngIf=\"file.uploading\">\r\n            <span [ngStyle]=\"{width: file.percentage + '%'}\"></span>\r\n          </div>\r\n\r\n          <span class=\"qq-upload-size-selector qq-upload-size\" *ngIf=\"!file.error\">{{formatBytes(file.size)}}</span>\r\n          <span\r\n            *ngIf=\"!readonly && file.uuid && showDeleteButton && !viewOnly\"\r\n            (click)=\"delete(file)\"\r\n            class=\"mrx-icon icon-delete icon-font-24 cursor-pointer\"\r\n            aria-label=\"Удалить\"\r\n          ></span>\r\n\r\n          <div class=\"ng-custom-file-input-error\" *ngIf=\"file.error\">\r\n            <span class=\"mrx-icon icon-attention icon-color-red icon-font-16 mr-1\"></span>\r\n            <span class=\"color-negative\">{{file.error}}</span>\r\n          </div>\r\n\r\n          <div\r\n            class=\"mrx-icon icon-close icon-font-24 cursor-pointer ml-2\"\r\n            *ngIf=\"(file.error && !file.uuid) || canCancelUploading(file) && !viewOnly\"\r\n            (click)=\"clear(file)\"\r\n          ></div>\r\n        </div>\r\n      </div>\r\n    </li>\r\n  </ul>\r\n</ng-template>\r\n"]}
|
|
@@ -26,6 +26,7 @@ export class InputNumberComponent {
|
|
|
26
26
|
// SAVE STATE
|
|
27
27
|
this.uuid = uuidv4();
|
|
28
28
|
this.fields = [];
|
|
29
|
+
this.maxlength = null;
|
|
29
30
|
this.innerClass = '';
|
|
30
31
|
this.customClasses = '';
|
|
31
32
|
this.required = false;
|
|
@@ -223,18 +224,20 @@ export class InputNumberComponent {
|
|
|
223
224
|
}
|
|
224
225
|
InputNumberComponent._delimitersInitialised = false;
|
|
225
226
|
InputNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: InputNumberComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
226
|
-
InputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: InputNumberComponent, selector: "mrx-input-number", inputs: { fields: "fields", placeholder: "placeholder", innerClass: "innerClass", customClasses: "customClasses", required: "required", allowNegative: "allowNegative", size: "size", separator: "separator", decimalSeparator: "decimalSeparator", isNullableValue: "isNullableValue", isAutoCorrectingValue: "isAutoCorrectingValue", invalid: "invalid", checkInvalid: "checkInvalid", setNumberType: ["numberType", "setNumberType"], setInvalidMessage: ["invalidMessage", "setInvalidMessage"], setDisabled: ["disabled", "setDisabled"], setReadonly: ["readonly", "setReadonly"], setMin: ["minValue", "setMin"], setMax: ["maxValue", "setMax"] }, outputs: { changed: "changed", modelChange: "modelChange", blurred: "blurred" }, providers: [
|
|
227
|
+
InputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: InputNumberComponent, selector: "mrx-input-number", inputs: { fields: "fields", placeholder: "placeholder", maxlength: "maxlength", innerClass: "innerClass", customClasses: "customClasses", required: "required", allowNegative: "allowNegative", size: "size", separator: "separator", decimalSeparator: "decimalSeparator", isNullableValue: "isNullableValue", isAutoCorrectingValue: "isAutoCorrectingValue", invalid: "invalid", checkInvalid: "checkInvalid", setNumberType: ["numberType", "setNumberType"], setInvalidMessage: ["invalidMessage", "setInvalidMessage"], setDisabled: ["disabled", "setDisabled"], setReadonly: ["readonly", "setReadonly"], setMin: ["minValue", "setMin"], setMax: ["maxValue", "setMax"] }, outputs: { changed: "changed", modelChange: "modelChange", blurred: "blurred" }, providers: [
|
|
227
228
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true },
|
|
228
|
-
], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n (blur)=\"onBlur($event)\"\r\n (paste)=\"onPaste($event)\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-lg.mrx-input-number-with-icon input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-md input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-md:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-md.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-sm input{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-sm:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-sm.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-8)}.mrx-input-number.mrx-input-number.mrx-input-error input{border-color:var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input{border-color:var(--system-bg-controls-negative-default)!important;background-color:var(--system-bg-negative-secondary)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input{background-color:var(--system-bg-positive-secondary)!important;border-color:var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input:hover{border:var(--border-width-default) solid var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.-disabled input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-tertiary, #71767E);color:var(--neutral-text-tertiary, #71767E)}.mrx-input-number.mrx-input-number.-readonly input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-primary, #262626);color:var(--neutral-text-primary, #262626)}\n"], components: [{ type: i2.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalid", "invalidMessage", "customClasses"] }, { type: i3.SaveStateComponent, selector: "mrx-save-state", inputs: ["type", "fields", "id"] }], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "triggerOnMaskChange"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
229
|
+
], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [maxlength]=\"maxlength\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n (blur)=\"onBlur($event)\"\r\n (paste)=\"onPaste($event)\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-lg.mrx-input-number-with-icon input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-md input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-md:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-md.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-sm input{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-sm:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-sm.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-8)}.mrx-input-number.mrx-input-number.mrx-input-error input{border-color:var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input{border-color:var(--system-bg-controls-negative-default)!important;background-color:var(--system-bg-negative-secondary)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input{background-color:var(--system-bg-positive-secondary)!important;border-color:var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input:hover{border:var(--border-width-default) solid var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.-disabled input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-tertiary, #71767E);color:var(--neutral-text-tertiary, #71767E)}.mrx-input-number.mrx-input-number.-readonly input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-primary, #262626);color:var(--neutral-text-primary, #262626)}\n"], components: [{ type: i2.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalid", "invalidMessage", "customClasses"] }, { type: i3.SaveStateComponent, selector: "mrx-save-state", inputs: ["type", "fields", "id"] }], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "triggerOnMaskChange"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
229
230
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: InputNumberComponent, decorators: [{
|
|
230
231
|
type: Component,
|
|
231
232
|
args: [{ selector: 'mrx-input-number', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
232
233
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true },
|
|
233
|
-
], template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n (blur)=\"onBlur($event)\"\r\n (paste)=\"onPaste($event)\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-lg.mrx-input-number-with-icon input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-md input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-md:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-md.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-sm input{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-sm:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-sm.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-8)}.mrx-input-number.mrx-input-number.mrx-input-error input{border-color:var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input{border-color:var(--system-bg-controls-negative-default)!important;background-color:var(--system-bg-negative-secondary)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input{background-color:var(--system-bg-positive-secondary)!important;border-color:var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input:hover{border:var(--border-width-default) solid var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.-disabled input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-tertiary, #71767E);color:var(--neutral-text-tertiary, #71767E)}.mrx-input-number.mrx-input-number.-readonly input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-primary, #262626);color:var(--neutral-text-primary, #262626)}\n"] }]
|
|
234
|
+
], template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [maxlength]=\"maxlength\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n (blur)=\"onBlur($event)\"\r\n (paste)=\"onPaste($event)\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-lg.mrx-input-number-with-icon input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-md input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-md:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-md.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-sm input{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-sm:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-sm.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-8)}.mrx-input-number.mrx-input-number.mrx-input-error input{border-color:var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input{border-color:var(--system-bg-controls-negative-default)!important;background-color:var(--system-bg-negative-secondary)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-error input:hover{border:var(--border-width-default) solid var(--system-bg-controls-negative-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input{background-color:var(--system-bg-positive-secondary)!important;border-color:var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.mrx-input-checked-success input:hover{border:var(--border-width-default) solid var(--system-bg-controls-positive-default)!important}.mrx-input-number.mrx-input-number.-disabled input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-tertiary, #71767E);color:var(--neutral-text-tertiary, #71767E)}.mrx-input-number.mrx-input-number.-readonly input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-primary, #262626);color:var(--neutral-text-primary, #262626)}\n"] }]
|
|
234
235
|
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { fields: [{
|
|
235
236
|
type: Input
|
|
236
237
|
}], placeholder: [{
|
|
237
238
|
type: Input
|
|
239
|
+
}], maxlength: [{
|
|
240
|
+
type: Input
|
|
238
241
|
}], innerClass: [{
|
|
239
242
|
type: Input
|
|
240
243
|
}], customClasses: [{
|
|
@@ -285,4 +288,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
285
288
|
}], blurred: [{
|
|
286
289
|
type: Output
|
|
287
290
|
}] } });
|
|
288
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  Validators\r\n} from '@angular/forms';\r\nimport {\r\n  InputNumberSizesEnum,\r\n  InputNumberSizesTypes,\r\n  InputNumberType, InputNumberValueTypes,\r\n  InputNumberValueWithId\r\n} from './input-number.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { distinctUntilChanged, pairwise, startWith } from 'rxjs/operators';\r\n\r\nconst noop = () => {\r\n};\r\n\r\nexport type DecimalMarkerType = '.' | ',' | ['.', ','];\r\n\r\n@Component({\r\n  selector: 'mrx-input-number',\r\n  templateUrl: './input-number.component.html',\r\n  styleUrls: ['./input-number.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true},\r\n  ]\r\n})\r\nexport class InputNumberComponent implements ControlValueAccessor, OnInit {\r\n\r\n  public static decimalMarker?: DecimalMarkerType;\r\n  private static _delimitersInitialised = false;\r\n  public static thousandsSeparator: string;\r\n\r\n  public value: InputNumberValueTypes = null;\r\n  public disabled = false;\r\n  public readonly = false;\r\n\r\n  numberForm: FormGroup;\r\n  invalidMessageStart: string | undefined | null;\r\n  invalidMessageEnd: string | undefined | null;\r\n  decimals = 2;\r\n\r\n  private invokeChanged = true;\r\n  private onTouchedCallback: () => void = noop;\r\n  private propagateChange: (_: any) => void = noop;\r\n  private _min = -999999999.99;\r\n  private _max = 999999999.99;\r\n  private _isValid = true;\r\n\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public placeholder?: string;\r\n  @Input() public innerClass = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public required = false;\r\n  @Input() public allowNegative = false;\r\n  @Input() public size: InputNumberSizesTypes = 'large';\r\n  @Input() public separator?: string;\r\n  @Input() public decimalSeparator?: DecimalMarkerType;\r\n  @Input() public isNullableValue = false;\r\n  @Input() public isAutoCorrectingValue = false;\r\n\r\n  // ERROR\r\n  @Input() public invalid = false;\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Input('numberType')\r\n  public set setNumberType(value: InputNumberType) {\r\n    this.decimals = value === 'float' ? 2 : value === 'percent' ? 1 : 0;\r\n  }\r\n\r\n  @Input('invalidMessage')\r\n  public set setInvalidMessage(value: string) {\r\n    if (value) {\r\n      const para = value.split('{0}');\r\n      this.invalidMessageStart = para[0];\r\n      this.invalidMessageEnd = para[1];\r\n    } else {\r\n      this.invalidMessageStart = null;\r\n      this.invalidMessageEnd = null;\r\n    }\r\n  }\r\n\r\n  @Input('disabled')\r\n  public set setDisabled(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.disabled = value;\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('readonly')\r\n  public set setReadonly(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.readonly = value;\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('minValue')\r\n  public set setMin(val: number) {\r\n    if (val) {\r\n      this._min = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input('maxValue')\r\n  public set setMax(val: number) {\r\n    if (val) {\r\n      this._max = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Output() public changed: EventEmitter<InputNumberValueTypes> = new EventEmitter<InputNumberValueTypes>();\r\n  @Output() public modelChange: EventEmitter<InputNumberValueWithId> = new EventEmitter<InputNumberValueWithId>();\r\n  @Output() public blurred: EventEmitter<InputNumberValueWithId> = new EventEmitter<InputNumberValueWithId>();\r\n\r\n  constructor(fb: FormBuilder) {\r\n    this.numberForm = fb.group({\r\n      number: [''],\r\n    });\r\n\r\n    InputNumberComponent.initNumberFormat();\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : ''\r\n  }\r\n\r\n  get getClasses(): string {\r\n    return `${InputNumberSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  get decimalMarker(): '.' | ',' | ['.', ','] {\r\n    return this.decimalSeparator || InputNumberComponent.decimalMarker || ',';\r\n  }\r\n\r\n  get thousandsSeparator(): string {\r\n    return this.separator || InputNumberComponent.thousandsSeparator;\r\n  }\r\n\r\n  get isValid(): boolean {\r\n    return this._isValid;\r\n  }\r\n\r\n  get maxMessage(): string {\r\n    const dec = this.decimalMarker[0];\r\n    return this._max.toLocaleString('en').split(',').join(this.thousandsSeparator).replace('.', dec);\r\n  }\r\n\r\n  get isVerified(): boolean {\r\n    const f = this.getControl('number');\r\n    return !this.required ||\r\n      (this.required && f.value !== null && f.value !== undefined && this.isValid);\r\n  }\r\n\r\n  static initNumberFormat(): void {\r\n    if (this._delimitersInitialised) {\r\n      return;\r\n    }\r\n    // системный формат числа с дробной частью и группой разраядов (тысячи)\r\n    const c = Intl.NumberFormat().formatToParts(1234.5);\r\n\r\n    const t = c.find(x => x.type === 'group')?.value;\r\n\r\n    // разделитель групп\r\n    this.thousandsSeparator = t?.charCodeAt(0) === 160 ? ' ' : t || ' ';\r\n\r\n    // разделитель дробной части\r\n    this.decimalMarker = (c.find(x => x.type === 'decimal')?.value as (',' | '.'));\r\n\r\n    this._delimitersInitialised = true;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.numberForm.valueChanges.pipe(\r\n      startWith(null),\r\n      distinctUntilChanged(),\r\n      pairwise()\r\n    ).subscribe(([oldValue, newValue]) => {\r\n      this._formattingValue(newValue.number);\r\n    });\r\n    this.numberForm.statusChanges.subscribe(val => {\r\n      this.checkIsValid();\r\n    });\r\n  }\r\n\r\n  private _formattingValue(insideValue: InputNumberValueTypes) {\r\n    if (this.invokeChanged) {\r\n      if (this.numberForm.valid) {\r\n        if (!insideValue && insideValue !== 0) {\r\n          this.updateValue(null);\r\n        } else {\r\n          this.updateValue(insideValue);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  resetToMax(event: any) {\r\n    event.preventDefault();\r\n\r\n    const f = this.getControl('number');\r\n    f.setValue(this._max);\r\n  }\r\n\r\n  checkIsValid() {\r\n    if (!this.isAutoCorrectingValue) {\r\n      const f = this.getControl('number');\r\n      this._isValid = this.numberForm.disabled || (f && f.valid || (!f.dirty && !f.touched));\r\n    }\r\n  }\r\n\r\n  onPhoneInputBlur() {\r\n    if (this.isAutoCorrectingValue) {\r\n      const f = this.getControl('number');\r\n\r\n      if (f.value > this._max) {\r\n        f.setValue(this._max);\r\n      }\r\n\r\n      if (f.value < this._min) {\r\n        f.setValue(this._min);\r\n      }\r\n    }\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    const f = this.getControl('number');\r\n    f.setValue(value, {emitEvent: false, emitViewToModelChange: false});\r\n  }\r\n\r\n  getControl(name: string) {\r\n    return this.numberForm.get(name) as FormControl;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public updateValue(insideValue: InputNumberValueTypes) {\r\n    this.value = insideValue;\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.propagateChange(insideValue);\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.onPhoneInputBlur()\r\n    this.blurred.emit({value: this.value, id: this.uuid})\r\n  }\r\n\r\n  public onPaste(event: ClipboardEvent) {\r\n    event.preventDefault()\r\n\r\n    const f = this.getControl('number');\r\n    const clipboardData = event.clipboardData || (<any>window).clipboardData;\r\n    const pastedText = clipboardData.getData('text');\r\n\r\n    switch (this.decimals) {\r\n      case (2):\r\n      case (1):\r\n        f.setValue(parseInt(pastedText))\r\n        break\r\n      default:\r\n        f.setValue(parseInt(pastedText.split(/[,.]/)[0]))\r\n        break\r\n    }\r\n  }\r\n}\r\n","<div\r\n    class=\"mrx-input-number\"\r\n    [class]=\"getClasses\"\r\n    [class.mrx-input-error]=\"!isValid || invalid\"\r\n    [class.-disabled]=\"disabled\"\r\n    [class.-readonly]=\"readonly\"\r\n>\r\n  <div class=\"mrx-input-number__wrapper\">\r\n    <form [formGroup]=\"numberForm\">\r\n      <div>\r\n        <input\r\n            #inputElement\r\n            autocomplete=\"nope\"\r\n            formControlName=\"number\"\r\n            type=\"text\"\r\n            [thousandSeparator]=\"thousandsSeparator\"\r\n            [decimalMarker]=\"decimalMarker\"\r\n            [class]=\"innerClass\"\r\n            [mask]=\"'separator.' + decimals\"\r\n            [allowNegativeNumbers]=\"allowNegative\"\r\n            [placeholder]=\"placeholder ? placeholder : ''\"\r\n            (blur)=\"onBlur($event)\"\r\n            (paste)=\"onPaste($event)\"\r\n        />\r\n      </div>\r\n    </form>\r\n  </div>\r\n\r\n  <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n    {{invalidMessageStart}}\r\n    <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n    {{invalidMessageEnd}}\r\n  </mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  Validators\r\n} from '@angular/forms';\r\nimport {\r\n  InputNumberSizesEnum,\r\n  InputNumberSizesTypes,\r\n  InputNumberType, InputNumberValueTypes,\r\n  InputNumberValueWithId\r\n} from './input-number.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { distinctUntilChanged, pairwise, startWith } from 'rxjs/operators';\r\n\r\nconst noop = () => {\r\n};\r\n\r\nexport type DecimalMarkerType = '.' | ',' | ['.', ','];\r\n\r\n@Component({\r\n  selector: 'mrx-input-number',\r\n  templateUrl: './input-number.component.html',\r\n  styleUrls: ['./input-number.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true},\r\n  ]\r\n})\r\nexport class InputNumberComponent implements ControlValueAccessor, OnInit {\r\n\r\n  public static decimalMarker?: DecimalMarkerType;\r\n  private static _delimitersInitialised = false;\r\n  public static thousandsSeparator: string;\r\n\r\n  public value: InputNumberValueTypes = null;\r\n  public disabled = false;\r\n  public readonly = false;\r\n\r\n  numberForm: FormGroup;\r\n  invalidMessageStart: string | undefined | null;\r\n  invalidMessageEnd: string | undefined | null;\r\n  decimals = 2;\r\n\r\n  private invokeChanged = true;\r\n  private onTouchedCallback: () => void = noop;\r\n  private propagateChange: (_: any) => void = noop;\r\n  private _min = -999999999.99;\r\n  private _max = 999999999.99;\r\n  private _isValid = true;\r\n\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public placeholder?: string;\r\n  @Input() public maxlength: number | null = null;\r\n  @Input() public innerClass = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public required = false;\r\n  @Input() public allowNegative = false;\r\n  @Input() public size: InputNumberSizesTypes = 'large';\r\n  @Input() public separator?: string;\r\n  @Input() public decimalSeparator?: DecimalMarkerType;\r\n  @Input() public isNullableValue = false;\r\n  @Input() public isAutoCorrectingValue = false;\r\n\r\n  // ERROR\r\n  @Input() public invalid = false;\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Input('numberType')\r\n  public set setNumberType(value: InputNumberType) {\r\n    this.decimals = value === 'float' ? 2 : value === 'percent' ? 1 : 0;\r\n  }\r\n\r\n  @Input('invalidMessage')\r\n  public set setInvalidMessage(value: string) {\r\n    if (value) {\r\n      const para = value.split('{0}');\r\n      this.invalidMessageStart = para[0];\r\n      this.invalidMessageEnd = para[1];\r\n    } else {\r\n      this.invalidMessageStart = null;\r\n      this.invalidMessageEnd = null;\r\n    }\r\n  }\r\n\r\n  @Input('disabled')\r\n  public set setDisabled(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.disabled = value;\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('readonly')\r\n  public set setReadonly(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.readonly = value;\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('minValue')\r\n  public set setMin(val: number) {\r\n    if (val) {\r\n      this._min = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input('maxValue')\r\n  public set setMax(val: number) {\r\n    if (val) {\r\n      this._max = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Output() public changed: EventEmitter<InputNumberValueTypes> = new EventEmitter<InputNumberValueTypes>();\r\n  @Output() public modelChange: EventEmitter<InputNumberValueWithId> = new EventEmitter<InputNumberValueWithId>();\r\n  @Output() public blurred: EventEmitter<InputNumberValueWithId> = new EventEmitter<InputNumberValueWithId>();\r\n\r\n  constructor(fb: FormBuilder) {\r\n    this.numberForm = fb.group({\r\n      number: [''],\r\n    });\r\n\r\n    InputNumberComponent.initNumberFormat();\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : ''\r\n  }\r\n\r\n  get getClasses(): string {\r\n    return `${InputNumberSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  get decimalMarker(): '.' | ',' | ['.', ','] {\r\n    return this.decimalSeparator || InputNumberComponent.decimalMarker || ',';\r\n  }\r\n\r\n  get thousandsSeparator(): string {\r\n    return this.separator || InputNumberComponent.thousandsSeparator;\r\n  }\r\n\r\n  get isValid(): boolean {\r\n    return this._isValid;\r\n  }\r\n\r\n  get maxMessage(): string {\r\n    const dec = this.decimalMarker[0];\r\n    return this._max.toLocaleString('en').split(',').join(this.thousandsSeparator).replace('.', dec);\r\n  }\r\n\r\n  get isVerified(): boolean {\r\n    const f = this.getControl('number');\r\n    return !this.required ||\r\n      (this.required && f.value !== null && f.value !== undefined && this.isValid);\r\n  }\r\n\r\n  static initNumberFormat(): void {\r\n    if (this._delimitersInitialised) {\r\n      return;\r\n    }\r\n    // системный формат числа с дробной частью и группой разраядов (тысячи)\r\n    const c = Intl.NumberFormat().formatToParts(1234.5);\r\n\r\n    const t = c.find(x => x.type === 'group')?.value;\r\n\r\n    // разделитель групп\r\n    this.thousandsSeparator = t?.charCodeAt(0) === 160 ? ' ' : t || ' ';\r\n\r\n    // разделитель дробной части\r\n    this.decimalMarker = (c.find(x => x.type === 'decimal')?.value as (',' | '.'));\r\n\r\n    this._delimitersInitialised = true;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.numberForm.valueChanges.pipe(\r\n      startWith(null),\r\n      distinctUntilChanged(),\r\n      pairwise()\r\n    ).subscribe(([oldValue, newValue]) => {\r\n      this._formattingValue(newValue.number);\r\n    });\r\n    this.numberForm.statusChanges.subscribe(val => {\r\n      this.checkIsValid();\r\n    });\r\n  }\r\n\r\n  private _formattingValue(insideValue: InputNumberValueTypes) {\r\n    if (this.invokeChanged) {\r\n      if (this.numberForm.valid) {\r\n        if (!insideValue && insideValue !== 0) {\r\n          this.updateValue(null);\r\n        } else {\r\n          this.updateValue(insideValue);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  resetToMax(event: any) {\r\n    event.preventDefault();\r\n\r\n    const f = this.getControl('number');\r\n    f.setValue(this._max);\r\n  }\r\n\r\n  checkIsValid() {\r\n    if (!this.isAutoCorrectingValue) {\r\n      const f = this.getControl('number');\r\n      this._isValid = this.numberForm.disabled || (f && f.valid || (!f.dirty && !f.touched));\r\n    }\r\n  }\r\n\r\n  onPhoneInputBlur() {\r\n    if (this.isAutoCorrectingValue) {\r\n      const f = this.getControl('number');\r\n\r\n      if (f.value > this._max) {\r\n        f.setValue(this._max);\r\n      }\r\n\r\n      if (f.value < this._min) {\r\n        f.setValue(this._min);\r\n      }\r\n    }\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    const f = this.getControl('number');\r\n    f.setValue(value, {emitEvent: false, emitViewToModelChange: false});\r\n  }\r\n\r\n  getControl(name: string) {\r\n    return this.numberForm.get(name) as FormControl;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public updateValue(insideValue: InputNumberValueTypes) {\r\n    this.value = insideValue;\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.propagateChange(insideValue);\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.onPhoneInputBlur()\r\n    this.blurred.emit({value: this.value, id: this.uuid})\r\n  }\r\n\r\n  public onPaste(event: ClipboardEvent) {\r\n    event.preventDefault()\r\n\r\n    const f = this.getControl('number');\r\n    const clipboardData = event.clipboardData || (<any>window).clipboardData;\r\n    const pastedText = clipboardData.getData('text');\r\n\r\n    switch (this.decimals) {\r\n      case (2):\r\n      case (1):\r\n        f.setValue(parseInt(pastedText))\r\n        break\r\n      default:\r\n        f.setValue(parseInt(pastedText.split(/[,.]/)[0]))\r\n        break\r\n    }\r\n  }\r\n}\r\n","<div\r\n    class=\"mrx-input-number\"\r\n    [class]=\"getClasses\"\r\n    [class.mrx-input-error]=\"!isValid || invalid\"\r\n    [class.-disabled]=\"disabled\"\r\n    [class.-readonly]=\"readonly\"\r\n>\r\n  <div class=\"mrx-input-number__wrapper\">\r\n    <form [formGroup]=\"numberForm\">\r\n      <div>\r\n        <input\r\n            #inputElement\r\n            autocomplete=\"nope\"\r\n            formControlName=\"number\"\r\n            type=\"text\"\r\n            [thousandSeparator]=\"thousandsSeparator\"\r\n            [decimalMarker]=\"decimalMarker\"\r\n            [class]=\"innerClass\"\r\n            [mask]=\"'separator.' + decimals\"\r\n            [allowNegativeNumbers]=\"allowNegative\"\r\n            [maxlength]=\"maxlength\"\r\n            [placeholder]=\"placeholder ? placeholder : ''\"\r\n            (blur)=\"onBlur($event)\"\r\n            (paste)=\"onPaste($event)\"\r\n        />\r\n      </div>\r\n    </form>\r\n  </div>\r\n\r\n  <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n    {{invalidMessageStart}}\r\n    <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n    {{invalidMessageEnd}}\r\n  </mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|