myrta-ui 13.0.11 → 13.0.13
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 +30 -27
- package/fesm2015/myrta-ui.mjs +29 -26
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +29 -26
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/lib/components/form/input-file/input-file.component.d.ts +5 -5
- 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,11 @@ export class InputFileComponent {
|
|
|
213
215
|
percentage: 0,
|
|
214
216
|
file: file
|
|
215
217
|
};
|
|
216
|
-
if (!this.
|
|
218
|
+
if (!this._checkForUpload(data)) {
|
|
219
|
+
this.filesChanged.emit(this.files);
|
|
217
220
|
return;
|
|
218
221
|
}
|
|
219
|
-
const formData = this.
|
|
222
|
+
const formData = this._createFormData();
|
|
220
223
|
formData.append('File', file);
|
|
221
224
|
if (this.uploadAdditionalData && Object.keys(this.uploadAdditionalData).length) {
|
|
222
225
|
Object.keys(this.uploadAdditionalData).forEach(key => {
|
|
@@ -265,7 +268,7 @@ export class InputFileComponent {
|
|
|
265
268
|
}
|
|
266
269
|
}
|
|
267
270
|
}
|
|
268
|
-
|
|
271
|
+
_checkForUpload(data, existing) {
|
|
269
272
|
this.checkDroppedFile.emit(data);
|
|
270
273
|
if (!this.canAdd && !existing) {
|
|
271
274
|
data.error = this.messageTooManyFiles;
|
|
@@ -376,4 +379,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
376
379
|
}], checkDroppedFile: [{
|
|
377
380
|
type: Output
|
|
378
381
|
}] } });
|
|
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"]}
|
|
382
|
+
//# 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    } 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      this.filesChanged.emit(this.files);\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"]}
|
package/fesm2015/myrta-ui.mjs
CHANGED
|
@@ -13264,7 +13264,9 @@ class InputFileComponent {
|
|
|
13264
13264
|
if (this.showInputWithError) {
|
|
13265
13265
|
return this.maxFiles > this.files.filter(s => !s.error).length;
|
|
13266
13266
|
}
|
|
13267
|
-
|
|
13267
|
+
else {
|
|
13268
|
+
return this.maxFiles > this.files.length;
|
|
13269
|
+
}
|
|
13268
13270
|
}
|
|
13269
13271
|
get getTarget() {
|
|
13270
13272
|
return InputFileTargetTypesEnum[this.target];
|
|
@@ -13299,13 +13301,13 @@ class InputFileComponent {
|
|
|
13299
13301
|
const findFile = this.files.find(s => s.uuid === file.uuid);
|
|
13300
13302
|
if (findFile) {
|
|
13301
13303
|
if (this.deleteEndPoint) {
|
|
13302
|
-
const formData = this.
|
|
13304
|
+
const formData = this._createFormData();
|
|
13303
13305
|
formData.append('Qquuid', file.uuid);
|
|
13304
13306
|
findFile.deleting = true;
|
|
13305
13307
|
if (this.autoUpload) {
|
|
13306
13308
|
this.fileUploadService.delete(this.deleteEndPoint, formData).subscribe(result => {
|
|
13307
13309
|
this.files.splice(this.files.indexOf(findFile), 1);
|
|
13308
|
-
this.
|
|
13310
|
+
this._validateUploadedAllFiles();
|
|
13309
13311
|
this.filesChanged.emit(this.files);
|
|
13310
13312
|
});
|
|
13311
13313
|
}
|
|
@@ -13315,7 +13317,7 @@ class InputFileComponent {
|
|
|
13315
13317
|
}
|
|
13316
13318
|
else {
|
|
13317
13319
|
this.files.splice(this.files.indexOf(findFile), 1);
|
|
13318
|
-
this.
|
|
13320
|
+
this._validateUploadedAllFiles();
|
|
13319
13321
|
this.filesChanged.emit(this.files);
|
|
13320
13322
|
}
|
|
13321
13323
|
}
|
|
@@ -13326,19 +13328,6 @@ class InputFileComponent {
|
|
|
13326
13328
|
canCancelUploading(file) {
|
|
13327
13329
|
return !!file.uploading && file.percentage ? file.percentage < 90 : false;
|
|
13328
13330
|
}
|
|
13329
|
-
validateUploadedAllFiles() {
|
|
13330
|
-
for (let i = 0; i < this.files.length; i++) {
|
|
13331
|
-
const data = this.files[i];
|
|
13332
|
-
data.error = undefined;
|
|
13333
|
-
this.checkForUpload(data, true);
|
|
13334
|
-
if (this.maxFiles <= i) {
|
|
13335
|
-
data.error = this.messageTooManyFiles;
|
|
13336
|
-
}
|
|
13337
|
-
else if (!data.error) {
|
|
13338
|
-
data.uuid = data.uuid || data.tempUuid || '';
|
|
13339
|
-
}
|
|
13340
|
-
}
|
|
13341
|
-
}
|
|
13342
13331
|
clear(file) {
|
|
13343
13332
|
if (file.uploading) {
|
|
13344
13333
|
if (file.execution) {
|
|
@@ -13350,7 +13339,7 @@ class InputFileComponent {
|
|
|
13350
13339
|
this.files.splice(findFileIdx, 1);
|
|
13351
13340
|
this.filesChanged.emit(this.files);
|
|
13352
13341
|
}
|
|
13353
|
-
this.
|
|
13342
|
+
this._validateUploadedAllFiles();
|
|
13354
13343
|
}
|
|
13355
13344
|
downloadUrl(file) {
|
|
13356
13345
|
if (file.url && !file.size) {
|
|
@@ -13368,7 +13357,7 @@ class InputFileComponent {
|
|
|
13368
13357
|
if (droppedFile.fileEntry.isFile) {
|
|
13369
13358
|
const fileEntry = droppedFile.fileEntry;
|
|
13370
13359
|
fileEntry.file((file) => {
|
|
13371
|
-
this.
|
|
13360
|
+
this._uploadFile(file);
|
|
13372
13361
|
});
|
|
13373
13362
|
}
|
|
13374
13363
|
else {
|
|
@@ -13377,19 +13366,32 @@ class InputFileComponent {
|
|
|
13377
13366
|
}
|
|
13378
13367
|
}
|
|
13379
13368
|
}
|
|
13380
|
-
|
|
13369
|
+
_validateUploadedAllFiles() {
|
|
13370
|
+
for (let i = 0; i < this.files.length; i++) {
|
|
13371
|
+
const data = this.files[i];
|
|
13372
|
+
data.error = undefined;
|
|
13373
|
+
this._checkForUpload(data, true);
|
|
13374
|
+
if (this.maxFiles <= i) {
|
|
13375
|
+
data.error = this.messageTooManyFiles;
|
|
13376
|
+
}
|
|
13377
|
+
else if (!data.error) {
|
|
13378
|
+
data.uuid = data.uuid || data.tempUuid || '';
|
|
13379
|
+
}
|
|
13380
|
+
}
|
|
13381
|
+
}
|
|
13382
|
+
_formDataKeys() {
|
|
13381
13383
|
return Object.keys(this.formData);
|
|
13382
13384
|
}
|
|
13383
|
-
|
|
13385
|
+
_createFormData() {
|
|
13384
13386
|
const form = new FormData();
|
|
13385
13387
|
if (this.maxFiles) {
|
|
13386
13388
|
form.append('MaxFiles', this.maxFiles.toString(10));
|
|
13387
13389
|
}
|
|
13388
|
-
const keys = this.
|
|
13390
|
+
const keys = this._formDataKeys();
|
|
13389
13391
|
keys.forEach(key => form.append(key, this.formData[key]));
|
|
13390
13392
|
return form;
|
|
13391
13393
|
}
|
|
13392
|
-
|
|
13394
|
+
_uploadFile(file) {
|
|
13393
13395
|
const data = {
|
|
13394
13396
|
uuid: '',
|
|
13395
13397
|
tempUuid: v4(),
|
|
@@ -13399,10 +13401,11 @@ class InputFileComponent {
|
|
|
13399
13401
|
percentage: 0,
|
|
13400
13402
|
file: file
|
|
13401
13403
|
};
|
|
13402
|
-
if (!this.
|
|
13404
|
+
if (!this._checkForUpload(data)) {
|
|
13405
|
+
this.filesChanged.emit(this.files);
|
|
13403
13406
|
return;
|
|
13404
13407
|
}
|
|
13405
|
-
const formData = this.
|
|
13408
|
+
const formData = this._createFormData();
|
|
13406
13409
|
formData.append('File', file);
|
|
13407
13410
|
if (this.uploadAdditionalData && Object.keys(this.uploadAdditionalData).length) {
|
|
13408
13411
|
Object.keys(this.uploadAdditionalData).forEach(key => {
|
|
@@ -13451,7 +13454,7 @@ class InputFileComponent {
|
|
|
13451
13454
|
}
|
|
13452
13455
|
}
|
|
13453
13456
|
}
|
|
13454
|
-
|
|
13457
|
+
_checkForUpload(data, existing) {
|
|
13455
13458
|
this.checkDroppedFile.emit(data);
|
|
13456
13459
|
if (!this.canAdd && !existing) {
|
|
13457
13460
|
data.error = this.messageTooManyFiles;
|