myrta-ui 17.0.98 → 17.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/form/input-file-image/input-file-image.component.mjs +6 -1
- package/esm2022/lib/services/save-store/store/reducer.mjs +16 -33
- package/fesm2022/myrta-ui.mjs +20 -31
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/lib/components/form/input-file-image/input-file-image.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -14,6 +14,7 @@ export class InputFileImageComponent {
|
|
|
14
14
|
imageUploadService;
|
|
15
15
|
_modalService;
|
|
16
16
|
_detector;
|
|
17
|
+
isProcessing = false;
|
|
17
18
|
formatBytes = formatBytes;
|
|
18
19
|
extensions;
|
|
19
20
|
allowedExtensions = [];
|
|
@@ -147,6 +148,9 @@ export class InputFileImageComponent {
|
|
|
147
148
|
}
|
|
148
149
|
changePreview(event, file) {
|
|
149
150
|
event.stopPropagation();
|
|
151
|
+
if (this.isProcessing)
|
|
152
|
+
return;
|
|
153
|
+
this.isProcessing = true;
|
|
150
154
|
getBase64FromUrl(this.downloadUrl(file)).then((base64Url) => {
|
|
151
155
|
this._modalService.open(FileImageEditModalComponent, {
|
|
152
156
|
title: 'РЕДАКТИРОВАНИЕ ИЗОБРАЖЕНИЯ',
|
|
@@ -161,6 +165,7 @@ export class InputFileImageComponent {
|
|
|
161
165
|
if (res.result && res.fileImage) {
|
|
162
166
|
this._updateFile(file, res.fileImage);
|
|
163
167
|
}
|
|
168
|
+
this.isProcessing = false;
|
|
164
169
|
});
|
|
165
170
|
});
|
|
166
171
|
}
|
|
@@ -353,4 +358,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
353
358
|
}], filesChanged: [{
|
|
354
359
|
type: Output
|
|
355
360
|
}] } });
|
|
356
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-file-image.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-file-image/input-file-image.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-file-image/input-file-image.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { InputFileModel, UploadedFileModel, UploadedResultModel } from '../../../models';\r\nimport { FileUploadService, ModalService } from '../../../services';\r\nimport { FileSystemFileEntry, NgxFileDropEntry } from 'ngx-file-drop';\r\nimport { convertBase64ToFile, formatBytes, getBase64FromUrl } from '../../../helpers';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { catchError } from 'rxjs/operators';\r\nimport { EMPTY } from 'rxjs';\r\nimport { HttpEvent, HttpEventType } from '@angular/common/http';\r\nimport { FileImageEditModalComponent } from './components/file-image-edit-modal/file-image-edit-modal.component';\r\nimport { InputFileImageTypeEnum, InputFileImageTypeTypes } from './input-file-image.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-file-image',\r\n  templateUrl: './input-file-image.component.html',\r\n  styleUrls: ['./input-file-image.component.less'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\n\r\nexport class InputFileImageComponent {\r\n  formatBytes = formatBytes;\r\n  extensions?: string;\r\n  allowedExtensions: string[] = [];\r\n  files: InputFileModel[] = [];\r\n\r\n  @Input() public type: InputFileImageTypeTypes = 'default';\r\n\r\n  @Input() public customClasses = '';\r\n  @Input() public placeholder?: string;\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public maxSize = 31457280;\r\n  @Input() public maxFiles = 5;\r\n  @Input() public minFiles = 0;\r\n\r\n  // Параметры, которые будут передаваться в форме\r\n  @Input() public formData: any = {};\r\n\r\n  // CROPPER\r\n  @Input() public cropperMaxWidth = 0;\r\n  @Input() public cropperMaxHeight = 0;\r\n  @Input() public aspectRatio = 1 / 1;\r\n  @Input() public maintainAspectRatio = false;\r\n\r\n  @Input() public uploadEndPoint!: string;\r\n  @Input() public deleteEndPoint?: string;\r\n  @Input() public downloadEndPoint?: string;\r\n\r\n  @Input() public deleteConfirm?: (file: UploadedFileModel, result: (ok: boolean) => void) => void;\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\r\n  constructor(\r\n    private imageUploadService: FileUploadService,\r\n    private _modalService: ModalService,\r\n    private _detector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  public get getDefaultPlaceholder(): string {\r\n    return this.type === 'avatar' ?\r\n      'Загрузите фотографию' :\r\n      'Перенесите файл с устройства или нажмите на данное поле для добавления файла';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${InputFileImageTypeEnum[this.type]} ${this.customClasses}`;\r\n  }\r\n\r\n  public get getDropZoneClasses(): string {\r\n    return `mrx-input-file-image-drop ${this.disabled ? 'mrx-input-file-picture-drop-disabled' : ''}`;\r\n  }\r\n\r\n  public get canAdd() {\r\n    if (this.type === 'avatar') {\r\n      return this.files.length < 1;\r\n    } else {\r\n      return this.maxFiles > this.files.filter(s => !s.error).length;\r\n    }\r\n  }\r\n\r\n  private _checkErrors() {\r\n\r\n  }\r\n\r\n  public dropped(files: NgxFileDropEntry[]) {\r\n    const droppedFile = files[0];\r\n\r\n    if (droppedFile.fileEntry.isFile) {\r\n      const fileEntry = droppedFile.fileEntry as FileSystemFileEntry;\r\n\r\n      fileEntry.file((file: File) => {\r\n        const data: InputFileModel = {\r\n          id: '',\r\n          tempUuid: uuidv4(),\r\n          name: file.name,\r\n          length: file.size,\r\n          uploading: true,\r\n          percentage: 0,\r\n          file: file,\r\n        } as InputFileModel;\r\n\r\n        if (!this.canAdd) {\r\n          data.error = 'Слишком много файлов';\r\n          data.uploading = false;\r\n          this.files.push(data);\r\n        }\r\n\r\n        this.files.push(data);\r\n\r\n        if (data.file && data.file.size > this.maxSize) {\r\n          data.error = 'Слишком большой файл';\r\n          data.uploading = false;\r\n        }\r\n\r\n        if (data.file && data.file.size == 0) {\r\n          data.error = 'Пустой файл';\r\n          data.uploading = false;\r\n        }\r\n\r\n        if (this.allowedExtensions.length > 0 && !this.allowedExtensions.some(\r\n          s => data.file?.name.toLowerCase().endsWith(s.toLowerCase()))) {\r\n          data.error = 'Неверный формат файла';\r\n          data.uploading = false;\r\n        }\r\n\r\n        if (!data.error) {\r\n          this._modalService.open(FileImageEditModalComponent, {\r\n            title: 'РЕДАКТИРОВАНИЕ ИЗОБРАЖЕНИЯ',\r\n            fileImage: file,\r\n            cropperMaxWidth: this.cropperMaxWidth,\r\n            cropperMaxHeight: this.cropperMaxHeight,\r\n            aspectRatio: this.aspectRatio,\r\n            maintainAspectRatio: this.maintainAspectRatio\r\n          }, {})\r\n            .afterClosed()\r\n            .subscribe((res) => {\r\n              if (res.result && res.fileImage) {\r\n                data.file = res.fileImage\r\n                this._uploadFile(data)\r\n              } else {\r\n                const findIdx = this.files.findIndex(d => d.tempUuid === data.tempUuid)\r\n\r\n                if (findIdx != -1) {\r\n                  this.files = this.files.filter((f, idx) => idx !== findIdx)\r\n                }\r\n              }\r\n            });\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public changePreview(event: any, file: InputFileModel) {\r\n    event.stopPropagation();\r\n\r\n    getBase64FromUrl(this.downloadUrl(file)).then((base64Url: any) => {\r\n      this._modalService.open(FileImageEditModalComponent, {\r\n        title: 'РЕДАКТИРОВАНИЕ ИЗОБРАЖЕНИЯ',\r\n        fileImage: convertBase64ToFile(base64Url, file.name || '', 'image/png'),\r\n        cropperMaxWidth: this.cropperMaxWidth,\r\n        cropperMaxHeight: this.cropperMaxHeight,\r\n        aspectRatio: this.aspectRatio,\r\n        maintainAspectRatio: this.maintainAspectRatio\r\n      }, {})\r\n        .afterClosed()\r\n        .subscribe((res) => {\r\n          if (res.result && res.fileImage) {\r\n            this._updateFile(file, res.fileImage);\r\n          }\r\n        });\r\n    });\r\n  }\r\n\r\n  public delete(event: any, file: InputFileModel): void {\r\n    event.stopPropagation();\r\n\r\n    if (this.deleteConfirm) {\r\n      this.deleteConfirm(file, (ok) => {\r\n        if (ok) {\r\n          this._deleteFile(file);\r\n        }\r\n      });\r\n    } else {\r\n      this._deleteFile(file);\r\n    }\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\r\n    if (findFileIdx >= 0) {\r\n      this.files.splice(findFileIdx, 1);\r\n    }\r\n  }\r\n\r\n  public downloadUrl(file: UploadedFileModel): string {\r\n    if (this.downloadEndPoint) {\r\n      return this._transformUrl(this.downloadEndPoint, file);\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  public fileOver(event: any) {\r\n  }\r\n\r\n  public fileLeave(event: any) {\r\n  }\r\n\r\n  private _transformUrl(url: string, file: UploadedFileModel): string {\r\n    return url.replace(/{id}/, file.id)\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 _deleteFile(file: InputFileModel) {\r\n    const findFile = this.files.find(s => s.id === file.id);\r\n\r\n    if (findFile) {\r\n      if (this.deleteEndPoint) {\r\n        findFile.deleting = true;\r\n\r\n        this.imageUploadService.delete(this.deleteEndPoint).subscribe(result => {\r\n          this.files.splice(this.files.indexOf(findFile), 1);\r\n          this.filesChanged.emit(this.files);\r\n        });\r\n\r\n      } else {\r\n        this.files.splice(this.files.indexOf(findFile), 1);\r\n        this.filesChanged.emit(this.files);\r\n      }\r\n    }\r\n  }\r\n\r\n  private _updateFile(oldFile: InputFileModel, newFile: File) {\r\n    const findFile = this.files.find((s: InputFileModel) => {\r\n      if (s.id !== '') {\r\n        return s.id === oldFile.id;\r\n      } else {\r\n        return s.tempUuid === oldFile.tempUuid;\r\n      }\r\n    });\r\n\r\n    if (findFile) {\r\n      const data: InputFileModel = {\r\n        id: '',\r\n        tempUuid: uuidv4(),\r\n        name: newFile.name,\r\n        length: newFile.size,\r\n        uploading: true,\r\n        percentage: 0,\r\n        file: newFile,\r\n      } as InputFileModel;\r\n\r\n      if (this.deleteEndPoint) {\r\n        findFile.deleting = true;\r\n\r\n        this.imageUploadService.delete(this.deleteEndPoint).subscribe(result => {\r\n          this.files.splice(this.files.indexOf(findFile), 1);\r\n          this.files.push(data);\r\n          this._uploadFile(data);\r\n\r\n          this._detector.detectChanges();\r\n        });\r\n\r\n      } else {\r\n        this.files.push(data);\r\n        this._uploadFile(data);\r\n\r\n        this._detector.detectChanges();\r\n      }\r\n    }\r\n  }\r\n\r\n  private _uploadFile(data: InputFileModel) {\r\n    const formData = this._createFormData();\r\n\r\n    if (data.file) {\r\n      formData.append('File', data.file);\r\n\r\n      data.execution = this.imageUploadService.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.id = event.body.uuid;\r\n                data.file = undefined;\r\n                data.error = event.body.message;\r\n\r\n                if (data.execution) {\r\n                  data.execution.unsubscribe();\r\n                }\r\n                if (this.files.every(s => !s.uploading)) {\r\n                  this.filesChanged.emit(this.files);\r\n                }\r\n\r\n                this._detector.detectChanges();\r\n              }\r\n          }\r\n        });\r\n    }\r\n  }\r\n}\r\n","<div class=\"mrx-input-file-image\" [class]=\"getClasses\">\r\n  @switch (type) {\r\n    @case ('avatar') {\r\n      <ngx-file-drop\r\n        [className]=\"getDropZoneClasses\"\r\n        [accept]=\"extensions || ''\"\r\n        [disabled]=\"disabled\"\r\n        (onFileDrop)=\"dropped($event)\"\r\n        (onFileOver)=\"fileOver($event)\" (onFileLeave)=\"fileLeave($event)\"\r\n      >\r\n        <ng-template ngx-file-drop-content-tmp let-openFileSelector=\"openFileSelector\">\r\n          @if (files.length) {\r\n            <div class=\"mrx-input-file-image-avatar\">\r\n\r\n              @for (file of files; track file.id) {\r\n                <div class=\"w-100 h-100\">\r\n                  <div class=\"mrx-input-file-image-avatar-item\" [class.mrx-input-file-image-error]=\"file.error\">\r\n\r\n                    @if (file.error) {\r\n\r\n                      <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"clear(file)\"></span>\r\n                      <div class=\"mrx-input-file-image-avatar-item-error\">\r\n                        <span class=\"mrx-icon icon-image icon-font-24 icon-filled-color-negative\"></span>\r\n                        {{ file.error }}\r\n                      </div>\r\n\r\n                    } @else if (file.uploading && !file.error) {\r\n\r\n                      <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"delete($event, file)\"></span>\r\n                      <div class=\"mrx-input-file-image-avatar-item-uploading\">\r\n                        <span class=\"mrx-input-file-image-avatar-item-uploading-text\">Загрузка...</span>\r\n                        <div class=\"mrx-input-file-image-avatar-item-uploading-progress\">\r\n                          <span [ngStyle]=\"{width: file.percentage + '%'}\"></span>\r\n                        </div>\r\n                      </div>\r\n\r\n                    } @else if (!file.uploading && !file.error) {\r\n\r\n                      <img [src]=\"downloadUrl(file)\" [alt]=\"file.name\" height=\"154\" width=\"154\">\r\n\r\n                      <div class=\"mrx-input-file-image-controls\">\r\n                        <div class=\"mrx-input-file-image-controls-item\" (click)=\"changePreview($event, file)\">\r\n                          <span class=\"mrx-icon icon-pen icon-font-16\"></span>\r\n                        </div>\r\n                        <div class=\"mrx-input-file-image-controls-item\" (click)=\"delete($event, file)\">\r\n                          <span class=\"mrx-icon icon-delete icon-font-16\"></span>\r\n                        </div>\r\n                      </div>\r\n\r\n                    }\r\n                  </div>\r\n                </div>\r\n              }\r\n            </div>\r\n          } @else {\r\n            <div\r\n              class=\"mrx-input-file-image-input\"\r\n              [class.mrx-input-file-image__disabled]=\"disabled\"\r\n              (click)=\"!disabled ? openFileSelector() : undefined\"\r\n            >\r\n              <span class=\"mrx-input-file-image-input-placeholder\">{{ placeholder || getDefaultPlaceholder }}</span>\r\n              <div class=\"mrx-input-file-image-input-info\">\r\n                <span>Размер: до {{ formatBytes(maxSize) }}</span>\r\n                <span *ngIf=\"extensions\">Формат: {{ extensions }}</span>\r\n              </div>\r\n            </div>\r\n          }\r\n        </ng-template>\r\n      </ngx-file-drop>\r\n    }\r\n    @default {\r\n      @if (canAdd) {\r\n        <ngx-file-drop\r\n          [className]=\"getDropZoneClasses\"\r\n          [accept]=\"extensions || ''\"\r\n          [disabled]=\"disabled\"\r\n          (onFileDrop)=\"dropped($event)\"\r\n          (onFileOver)=\"fileOver($event)\" (onFileLeave)=\"fileLeave($event)\"\r\n        >\r\n          <ng-template ngx-file-drop-content-tmp let-openFileSelector=\"openFileSelector\">\r\n            <div\r\n              class=\"mrx-input-file-image-input\"\r\n              (click)=\"!disabled ? openFileSelector() : undefined\"\r\n            >\r\n              <span class=\"mrx-input-file-image-input-placeholder\">\r\n                {{ placeholder || getDefaultPlaceholder }}\r\n              </span>\r\n              <div class=\"mrx-input-file-image-input-info\">\r\n                <span>Размер: до {{ formatBytes(maxSize) }}</span>\r\n                <span *ngIf=\"extensions\">Формат: {{ extensions }}</span>\r\n              </div>\r\n            </div>\r\n          </ng-template>\r\n        </ngx-file-drop>\r\n      }\r\n\r\n      <div class=\"mrx-input-file-image-preview\">\r\n        <div class=\"row\">\r\n          @for (file of files; track file.id) {\r\n\r\n            <div class=\"col col-12 col-sm-6 col-md-4 col-lg-3\">\r\n              <div class=\"mrx-input-file-image-preview-item\" [class.mrx-input-file-image-error]=\"file.error\">\r\n                @if (file.error) {\r\n\r\n                  <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"delete($event, file)\"></span>\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item-error\">\r\n                    <span class=\"mrx-icon icon-image icon-font-24 icon-filled-color-negative\"></span>\r\n                    {{ file.error }}\r\n                  </div>\r\n                  <div class=\"mrx-input-file-image-preview-item-name\">{{ file.name }}</div>\r\n                  <div class=\"mrx-input-file-image-preview-item-description\">{{ formatBytes(file.length) }}</div>\r\n\r\n                } @else if (file.uploading && !file.error) {\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item-uploading\">\r\n                    <span class=\"mrx-input-file-image-preview-item-uploading-text\">Загрузка...</span>\r\n                    <div class=\"mrx-input-file-image-preview-item-uploading-progress\">\r\n                      <span [ngStyle]=\"{width: file.percentage + '%'}\"></span>\r\n                    </div>\r\n                  </div>\r\n\r\n                } @else if (!file.uploading && !file.error) {\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item__image\">\r\n                    <img [src]=\"downloadUrl(file)\" [alt]=\"file.name\">\r\n                  </div>\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item-info\">\r\n                    <div class=\"mrx-input-file-image-preview-item-name\">{{ file.name }}</div>\r\n                    <div class=\"mrx-input-file-image-preview-item-description\">{{ formatBytes(file.length) }}</div>\r\n                  </div>\r\n\r\n                  <div class=\"mrx-input-file-image-controls\">\r\n                    <div class=\"mrx-input-file-image-controls-item\" (click)=\"changePreview($event, file)\">\r\n                      <span class=\"mrx-icon icon-pen icon-font-16\"></span>\r\n                    </div>\r\n                    <div class=\"mrx-input-file-image-controls-item\" (click)=\"delete($event, file)\">\r\n                      <span class=\"mrx-icon icon-delete icon-font-16\"></span>\r\n                    </div>\r\n                  </div>\r\n\r\n                }\r\n              </div>\r\n            </div>\r\n          }\r\n        </div>\r\n      </div>\r\n    }\r\n  }\r\n</div>\r\n"]}
|
|
361
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-file-image.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-file-image/input-file-image.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-file-image/input-file-image.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { InputFileModel, UploadedFileModel, UploadedResultModel } from '../../../models';\r\nimport { FileUploadService, ModalService } from '../../../services';\r\nimport { FileSystemFileEntry, NgxFileDropEntry } from 'ngx-file-drop';\r\nimport { convertBase64ToFile, formatBytes, getBase64FromUrl } from '../../../helpers';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { catchError } from 'rxjs/operators';\r\nimport { EMPTY } from 'rxjs';\r\nimport { HttpEvent, HttpEventType } from '@angular/common/http';\r\nimport { FileImageEditModalComponent } from './components/file-image-edit-modal/file-image-edit-modal.component';\r\nimport { InputFileImageTypeEnum, InputFileImageTypeTypes } from './input-file-image.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-file-image',\r\n  templateUrl: './input-file-image.component.html',\r\n  styleUrls: ['./input-file-image.component.less'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\n\r\nexport class InputFileImageComponent {\r\n  private isProcessing = false;\r\n\r\n  formatBytes = formatBytes;\r\n  extensions?: string;\r\n  allowedExtensions: string[] = [];\r\n  files: InputFileModel[] = [];\r\n\r\n  @Input() public type: InputFileImageTypeTypes = 'default';\r\n\r\n  @Input() public customClasses = '';\r\n  @Input() public placeholder?: string;\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public maxSize = 31457280;\r\n  @Input() public maxFiles = 5;\r\n  @Input() public minFiles = 0;\r\n\r\n  // Параметры, которые будут передаваться в форме\r\n  @Input() public formData: any = {};\r\n\r\n  // CROPPER\r\n  @Input() public cropperMaxWidth = 0;\r\n  @Input() public cropperMaxHeight = 0;\r\n  @Input() public aspectRatio = 1 / 1;\r\n  @Input() public maintainAspectRatio = false;\r\n\r\n  @Input() public uploadEndPoint!: string;\r\n  @Input() public deleteEndPoint?: string;\r\n  @Input() public downloadEndPoint?: string;\r\n\r\n  @Input() public deleteConfirm?: (file: UploadedFileModel, result: (ok: boolean) => void) => void;\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\r\n  constructor(\r\n    private imageUploadService: FileUploadService,\r\n    private _modalService: ModalService,\r\n    private _detector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  public get getDefaultPlaceholder(): string {\r\n    return this.type === 'avatar' ?\r\n      'Загрузите фотографию' :\r\n      'Перенесите файл с устройства или нажмите на данное поле для добавления файла';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${InputFileImageTypeEnum[this.type]} ${this.customClasses}`;\r\n  }\r\n\r\n  public get getDropZoneClasses(): string {\r\n    return `mrx-input-file-image-drop ${this.disabled ? 'mrx-input-file-picture-drop-disabled' : ''}`;\r\n  }\r\n\r\n  public get canAdd() {\r\n    if (this.type === 'avatar') {\r\n      return this.files.length < 1;\r\n    } else {\r\n      return this.maxFiles > this.files.filter(s => !s.error).length;\r\n    }\r\n  }\r\n\r\n  private _checkErrors() {\r\n\r\n  }\r\n\r\n  public dropped(files: NgxFileDropEntry[]) {\r\n    const droppedFile = files[0];\r\n\r\n    if (droppedFile.fileEntry.isFile) {\r\n      const fileEntry = droppedFile.fileEntry as FileSystemFileEntry;\r\n\r\n      fileEntry.file((file: File) => {\r\n        const data: InputFileModel = {\r\n          id: '',\r\n          tempUuid: uuidv4(),\r\n          name: file.name,\r\n          length: file.size,\r\n          uploading: true,\r\n          percentage: 0,\r\n          file: file,\r\n        } as InputFileModel;\r\n\r\n        if (!this.canAdd) {\r\n          data.error = 'Слишком много файлов';\r\n          data.uploading = false;\r\n          this.files.push(data);\r\n        }\r\n\r\n        this.files.push(data);\r\n\r\n        if (data.file && data.file.size > this.maxSize) {\r\n          data.error = 'Слишком большой файл';\r\n          data.uploading = false;\r\n        }\r\n\r\n        if (data.file && data.file.size == 0) {\r\n          data.error = 'Пустой файл';\r\n          data.uploading = false;\r\n        }\r\n\r\n        if (this.allowedExtensions.length > 0 && !this.allowedExtensions.some(\r\n          s => data.file?.name.toLowerCase().endsWith(s.toLowerCase()))) {\r\n          data.error = 'Неверный формат файла';\r\n          data.uploading = false;\r\n        }\r\n\r\n        if (!data.error) {\r\n          this._modalService.open(FileImageEditModalComponent, {\r\n            title: 'РЕДАКТИРОВАНИЕ ИЗОБРАЖЕНИЯ',\r\n            fileImage: file,\r\n            cropperMaxWidth: this.cropperMaxWidth,\r\n            cropperMaxHeight: this.cropperMaxHeight,\r\n            aspectRatio: this.aspectRatio,\r\n            maintainAspectRatio: this.maintainAspectRatio\r\n          }, {})\r\n            .afterClosed()\r\n            .subscribe((res) => {\r\n              if (res.result && res.fileImage) {\r\n                data.file = res.fileImage\r\n                this._uploadFile(data)\r\n              } else {\r\n                const findIdx = this.files.findIndex(d => d.tempUuid === data.tempUuid)\r\n\r\n                if (findIdx != -1) {\r\n                  this.files = this.files.filter((f, idx) => idx !== findIdx)\r\n                }\r\n              }\r\n            });\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public changePreview(event: any, file: InputFileModel) {\r\n    event.stopPropagation();\r\n\r\n    if (this.isProcessing) return;\r\n    \r\n    this.isProcessing = true;\r\n\r\n    getBase64FromUrl(this.downloadUrl(file)).then((base64Url: any) => {\r\n      this._modalService.open(FileImageEditModalComponent, {\r\n        title: 'РЕДАКТИРОВАНИЕ ИЗОБРАЖЕНИЯ',\r\n        fileImage: convertBase64ToFile(base64Url, file.name || '', 'image/png'),\r\n        cropperMaxWidth: this.cropperMaxWidth,\r\n        cropperMaxHeight: this.cropperMaxHeight,\r\n        aspectRatio: this.aspectRatio,\r\n        maintainAspectRatio: this.maintainAspectRatio\r\n      }, {})\r\n        .afterClosed()\r\n        .subscribe((res) => {\r\n          if (res.result && res.fileImage) {\r\n            this._updateFile(file, res.fileImage);\r\n          }\r\n\r\n          this.isProcessing = false;\r\n        });\r\n    });\r\n  }\r\n\r\n  public delete(event: any, file: InputFileModel): void {\r\n    event.stopPropagation();\r\n\r\n    if (this.deleteConfirm) {\r\n      this.deleteConfirm(file, (ok) => {\r\n        if (ok) {\r\n          this._deleteFile(file);\r\n        }\r\n      });\r\n    } else {\r\n      this._deleteFile(file);\r\n    }\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\r\n    if (findFileIdx >= 0) {\r\n      this.files.splice(findFileIdx, 1);\r\n    }\r\n  }\r\n\r\n  public downloadUrl(file: UploadedFileModel): string {\r\n    if (this.downloadEndPoint) {\r\n      return this._transformUrl(this.downloadEndPoint, file);\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  public fileOver(event: any) {\r\n  }\r\n\r\n  public fileLeave(event: any) {\r\n  }\r\n\r\n  private _transformUrl(url: string, file: UploadedFileModel): string {\r\n    return url.replace(/{id}/, file.id)\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 _deleteFile(file: InputFileModel) {\r\n    const findFile = this.files.find(s => s.id === file.id);\r\n\r\n    if (findFile) {\r\n      if (this.deleteEndPoint) {\r\n        findFile.deleting = true;\r\n\r\n        this.imageUploadService.delete(this.deleteEndPoint).subscribe(result => {\r\n          this.files.splice(this.files.indexOf(findFile), 1);\r\n          this.filesChanged.emit(this.files);\r\n        });\r\n\r\n      } else {\r\n        this.files.splice(this.files.indexOf(findFile), 1);\r\n        this.filesChanged.emit(this.files);\r\n      }\r\n    }\r\n  }\r\n\r\n  private _updateFile(oldFile: InputFileModel, newFile: File) {\r\n    const findFile = this.files.find((s: InputFileModel) => {\r\n      if (s.id !== '') {\r\n        return s.id === oldFile.id;\r\n      } else {\r\n        return s.tempUuid === oldFile.tempUuid;\r\n      }\r\n    });\r\n\r\n    if (findFile) {\r\n      const data: InputFileModel = {\r\n        id: '',\r\n        tempUuid: uuidv4(),\r\n        name: newFile.name,\r\n        length: newFile.size,\r\n        uploading: true,\r\n        percentage: 0,\r\n        file: newFile,\r\n      } as InputFileModel;\r\n\r\n      if (this.deleteEndPoint) {\r\n        findFile.deleting = true;\r\n\r\n        this.imageUploadService.delete(this.deleteEndPoint).subscribe(result => {\r\n          this.files.splice(this.files.indexOf(findFile), 1);\r\n          this.files.push(data);\r\n          this._uploadFile(data);\r\n\r\n          this._detector.detectChanges();\r\n        });\r\n\r\n      } else {\r\n        this.files.push(data);\r\n        this._uploadFile(data);\r\n\r\n        this._detector.detectChanges();\r\n      }\r\n    }\r\n  }\r\n\r\n  private _uploadFile(data: InputFileModel) {\r\n    const formData = this._createFormData();\r\n\r\n    if (data.file) {\r\n      formData.append('File', data.file);\r\n\r\n      data.execution = this.imageUploadService.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.id = event.body.uuid;\r\n                data.file = undefined;\r\n                data.error = event.body.message;\r\n\r\n                if (data.execution) {\r\n                  data.execution.unsubscribe();\r\n                }\r\n                if (this.files.every(s => !s.uploading)) {\r\n                  this.filesChanged.emit(this.files);\r\n                }\r\n\r\n                this._detector.detectChanges();\r\n              }\r\n          }\r\n        });\r\n    }\r\n  }\r\n}\r\n","<div class=\"mrx-input-file-image\" [class]=\"getClasses\">\r\n  @switch (type) {\r\n    @case ('avatar') {\r\n      <ngx-file-drop\r\n        [className]=\"getDropZoneClasses\"\r\n        [accept]=\"extensions || ''\"\r\n        [disabled]=\"disabled\"\r\n        (onFileDrop)=\"dropped($event)\"\r\n        (onFileOver)=\"fileOver($event)\" (onFileLeave)=\"fileLeave($event)\"\r\n      >\r\n        <ng-template ngx-file-drop-content-tmp let-openFileSelector=\"openFileSelector\">\r\n          @if (files.length) {\r\n            <div class=\"mrx-input-file-image-avatar\">\r\n\r\n              @for (file of files; track file.id) {\r\n                <div class=\"w-100 h-100\">\r\n                  <div class=\"mrx-input-file-image-avatar-item\" [class.mrx-input-file-image-error]=\"file.error\">\r\n\r\n                    @if (file.error) {\r\n\r\n                      <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"clear(file)\"></span>\r\n                      <div class=\"mrx-input-file-image-avatar-item-error\">\r\n                        <span class=\"mrx-icon icon-image icon-font-24 icon-filled-color-negative\"></span>\r\n                        {{ file.error }}\r\n                      </div>\r\n\r\n                    } @else if (file.uploading && !file.error) {\r\n\r\n                      <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"delete($event, file)\"></span>\r\n                      <div class=\"mrx-input-file-image-avatar-item-uploading\">\r\n                        <span class=\"mrx-input-file-image-avatar-item-uploading-text\">Загрузка...</span>\r\n                        <div class=\"mrx-input-file-image-avatar-item-uploading-progress\">\r\n                          <span [ngStyle]=\"{width: file.percentage + '%'}\"></span>\r\n                        </div>\r\n                      </div>\r\n\r\n                    } @else if (!file.uploading && !file.error) {\r\n\r\n                      <img [src]=\"downloadUrl(file)\" [alt]=\"file.name\" height=\"154\" width=\"154\">\r\n\r\n                      <div class=\"mrx-input-file-image-controls\">\r\n                        <div class=\"mrx-input-file-image-controls-item\" (click)=\"changePreview($event, file)\">\r\n                          <span class=\"mrx-icon icon-pen icon-font-16\"></span>\r\n                        </div>\r\n                        <div class=\"mrx-input-file-image-controls-item\" (click)=\"delete($event, file)\">\r\n                          <span class=\"mrx-icon icon-delete icon-font-16\"></span>\r\n                        </div>\r\n                      </div>\r\n\r\n                    }\r\n                  </div>\r\n                </div>\r\n              }\r\n            </div>\r\n          } @else {\r\n            <div\r\n              class=\"mrx-input-file-image-input\"\r\n              [class.mrx-input-file-image__disabled]=\"disabled\"\r\n              (click)=\"!disabled ? openFileSelector() : undefined\"\r\n            >\r\n              <span class=\"mrx-input-file-image-input-placeholder\">{{ placeholder || getDefaultPlaceholder }}</span>\r\n              <div class=\"mrx-input-file-image-input-info\">\r\n                <span>Размер: до {{ formatBytes(maxSize) }}</span>\r\n                <span *ngIf=\"extensions\">Формат: {{ extensions }}</span>\r\n              </div>\r\n            </div>\r\n          }\r\n        </ng-template>\r\n      </ngx-file-drop>\r\n    }\r\n    @default {\r\n      @if (canAdd) {\r\n        <ngx-file-drop\r\n          [className]=\"getDropZoneClasses\"\r\n          [accept]=\"extensions || ''\"\r\n          [disabled]=\"disabled\"\r\n          (onFileDrop)=\"dropped($event)\"\r\n          (onFileOver)=\"fileOver($event)\" (onFileLeave)=\"fileLeave($event)\"\r\n        >\r\n          <ng-template ngx-file-drop-content-tmp let-openFileSelector=\"openFileSelector\">\r\n            <div\r\n              class=\"mrx-input-file-image-input\"\r\n              (click)=\"!disabled ? openFileSelector() : undefined\"\r\n            >\r\n              <span class=\"mrx-input-file-image-input-placeholder\">\r\n                {{ placeholder || getDefaultPlaceholder }}\r\n              </span>\r\n              <div class=\"mrx-input-file-image-input-info\">\r\n                <span>Размер: до {{ formatBytes(maxSize) }}</span>\r\n                <span *ngIf=\"extensions\">Формат: {{ extensions }}</span>\r\n              </div>\r\n            </div>\r\n          </ng-template>\r\n        </ngx-file-drop>\r\n      }\r\n\r\n      <div class=\"mrx-input-file-image-preview\">\r\n        <div class=\"row\">\r\n          @for (file of files; track file.id) {\r\n\r\n            <div class=\"col col-12 col-sm-6 col-md-4 col-lg-3\">\r\n              <div class=\"mrx-input-file-image-preview-item\" [class.mrx-input-file-image-error]=\"file.error\">\r\n                @if (file.error) {\r\n\r\n                  <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"delete($event, file)\"></span>\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item-error\">\r\n                    <span class=\"mrx-icon icon-image icon-font-24 icon-filled-color-negative\"></span>\r\n                    {{ file.error }}\r\n                  </div>\r\n                  <div class=\"mrx-input-file-image-preview-item-name\">{{ file.name }}</div>\r\n                  <div class=\"mrx-input-file-image-preview-item-description\">{{ formatBytes(file.length) }}</div>\r\n\r\n                } @else if (file.uploading && !file.error) {\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item-uploading\">\r\n                    <span class=\"mrx-input-file-image-preview-item-uploading-text\">Загрузка...</span>\r\n                    <div class=\"mrx-input-file-image-preview-item-uploading-progress\">\r\n                      <span [ngStyle]=\"{width: file.percentage + '%'}\"></span>\r\n                    </div>\r\n                  </div>\r\n\r\n                } @else if (!file.uploading && !file.error) {\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item__image\">\r\n                    <img [src]=\"downloadUrl(file)\" [alt]=\"file.name\">\r\n                  </div>\r\n\r\n                  <div class=\"mrx-input-file-image-preview-item-info\">\r\n                    <div class=\"mrx-input-file-image-preview-item-name\">{{ file.name }}</div>\r\n                    <div class=\"mrx-input-file-image-preview-item-description\">{{ formatBytes(file.length) }}</div>\r\n                  </div>\r\n\r\n                  <div class=\"mrx-input-file-image-controls\">\r\n                    <div class=\"mrx-input-file-image-controls-item\" (click)=\"changePreview($event, file)\">\r\n                      <span class=\"mrx-icon icon-pen icon-font-16\"></span>\r\n                    </div>\r\n                    <div class=\"mrx-input-file-image-controls-item\" (click)=\"delete($event, file)\">\r\n                      <span class=\"mrx-icon icon-delete icon-font-16\"></span>\r\n                    </div>\r\n                  </div>\r\n\r\n                }\r\n              </div>\r\n            </div>\r\n          }\r\n        </div>\r\n      </div>\r\n    }\r\n  }\r\n</div>\r\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { initialMrxAutoSaveState } from './state';
|
|
2
2
|
import { createReducer, on } from '@ngrx/store';
|
|
3
3
|
import * as MrxAutoSaveActions from './actions';
|
|
4
|
-
import { cloneDeep } from 'lodash-es';
|
|
5
4
|
const reducerCreator = createReducer(initialMrxAutoSaveState, on(MrxAutoSaveActions.autosaveAddId, (state, { id, groupId = null }) => {
|
|
6
5
|
const isFind = state.fields.some((field) => field.id === id);
|
|
7
6
|
if (!isFind) {
|
|
@@ -12,16 +11,12 @@ const reducerCreator = createReducer(initialMrxAutoSaveState, on(MrxAutoSaveActi
|
|
|
12
11
|
return { ...state };
|
|
13
12
|
}
|
|
14
13
|
}), on(MrxAutoSaveActions.autosaveStart, (state) => {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
f.state = 'saving';
|
|
18
|
-
return { ...f };
|
|
19
|
-
})
|
|
20
|
-
};
|
|
14
|
+
const copied = structuredClone(state.fields);
|
|
15
|
+
return { ...state, fields: copied.map((f) => ({ ...f, state: 'saving' })) };
|
|
21
16
|
}), on(MrxAutoSaveActions.autosaveStartFor, (state, { id, groupId = null }) => {
|
|
22
|
-
const
|
|
17
|
+
const copied = structuredClone(state.fields);
|
|
23
18
|
return {
|
|
24
|
-
...state, fields:
|
|
19
|
+
...state, fields: copied.map(f => {
|
|
25
20
|
if (groupId && f.groupId === groupId) {
|
|
26
21
|
f.state = 'saving';
|
|
27
22
|
}
|
|
@@ -32,16 +27,12 @@ const reducerCreator = createReducer(initialMrxAutoSaveState, on(MrxAutoSaveActi
|
|
|
32
27
|
})
|
|
33
28
|
};
|
|
34
29
|
}), on(MrxAutoSaveActions.autosaveSuccess, (state) => {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
f.state = 'saved';
|
|
38
|
-
return { ...f };
|
|
39
|
-
})
|
|
40
|
-
};
|
|
30
|
+
const copied = structuredClone(state.fields);
|
|
31
|
+
return { ...state, fields: copied.map((f) => ({ ...f, state: 'saved' })) };
|
|
41
32
|
}), on(MrxAutoSaveActions.autosaveSuccessFor, (state, { id, groupId = null }) => {
|
|
42
|
-
const
|
|
33
|
+
const copied = structuredClone(state.fields);
|
|
43
34
|
return {
|
|
44
|
-
...state, fields:
|
|
35
|
+
...state, fields: copied.map(f => {
|
|
45
36
|
if (groupId && f.groupId === groupId) {
|
|
46
37
|
f.state = 'saved';
|
|
47
38
|
}
|
|
@@ -52,20 +43,12 @@ const reducerCreator = createReducer(initialMrxAutoSaveState, on(MrxAutoSaveActi
|
|
|
52
43
|
})
|
|
53
44
|
};
|
|
54
45
|
}), on(MrxAutoSaveActions.autosaveError, (state) => {
|
|
46
|
+
const copied = structuredClone(state.fields);
|
|
47
|
+
return { ...state, fields: copied.map((f) => ({ ...f, state: 'error' })) };
|
|
48
|
+
}), on(MrxAutoSaveActions.autosaveErrorFor, (state, { id, groupId = null }) => {
|
|
49
|
+
const copied = structuredClone(state.fields);
|
|
55
50
|
return {
|
|
56
|
-
...state, fields:
|
|
57
|
-
f.state = 'error';
|
|
58
|
-
return { ...f };
|
|
59
|
-
})
|
|
60
|
-
};
|
|
61
|
-
}),
|
|
62
|
-
// on(MrxAutoSaveActions.autosaveError, (state) => {
|
|
63
|
-
// return { ...state, fields: [...state.fields].map(f => ({ ...f, state: 'error' })) };
|
|
64
|
-
// }),
|
|
65
|
-
on(MrxAutoSaveActions.autosaveErrorFor, (state, { id, groupId = null }) => {
|
|
66
|
-
const fields = cloneDeep(state.fields);
|
|
67
|
-
return {
|
|
68
|
-
...state, fields: fields.map(f => {
|
|
51
|
+
...state, fields: copied.map(f => {
|
|
69
52
|
if (groupId && f.groupId === groupId) {
|
|
70
53
|
f.state = 'error';
|
|
71
54
|
}
|
|
@@ -78,9 +61,9 @@ on(MrxAutoSaveActions.autosaveErrorFor, (state, { id, groupId = null }) => {
|
|
|
78
61
|
}), on(MrxAutoSaveActions.autosaveStop, (state) => {
|
|
79
62
|
return { ...state, fields: [] };
|
|
80
63
|
}), on(MrxAutoSaveActions.autosaveStopFor, (state, { id, groupId = null }) => {
|
|
64
|
+
const copied = structuredClone(state.fields);
|
|
81
65
|
return {
|
|
82
|
-
...state,
|
|
83
|
-
fields: state.fields.filter((f) => {
|
|
66
|
+
...state, fields: copied.filter((f) => {
|
|
84
67
|
if (groupId) {
|
|
85
68
|
return f.groupId !== groupId;
|
|
86
69
|
}
|
|
@@ -93,4 +76,4 @@ on(MrxAutoSaveActions.autosaveErrorFor, (state, { id, groupId = null }) => {
|
|
|
93
76
|
export function mrxAutoSaveStateReducer(state, action) {
|
|
94
77
|
return reducerCreator(state, action);
|
|
95
78
|
}
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reducer.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/services/save-store/store/reducer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Field, initialMrxAutoSaveState, MrxAutoSaveState } from './state';\r\nimport { Action, createReducer, on } from '@ngrx/store';\r\nimport * as MrxAutoSaveActions from './actions';\r\n\r\nconst reducerCreator = createReducer(\r\n  initialMrxAutoSaveState,\r\n  on(MrxAutoSaveActions.autosaveAddId, (state, {id, groupId = null}) => {\r\n    const isFind = state.fields.some((field) => field.id === id);\r\n\r\n    if (!isFind) {\r\n      const field: Field = {id: id, state: 'stopped', groupId: groupId};\r\n      return {...state, fields: [...state.fields, field]};\r\n    } else {\r\n      return {...state};\r\n    }\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveStart, (state) => {\r\n    const copied = structuredClone(state.fields);\r\n    return {...state, fields: copied.map((f: Field): Field => ({...f, state: 'saving'}))};\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveStartFor, (state, {id, groupId = null}) => {\r\n    const copied = structuredClone(state.fields);\r\n\r\n    return {\r\n      ...state, fields: copied.map(f => {\r\n        if (groupId && f.groupId === groupId) {\r\n          f.state = 'saving';\r\n        } else if (f.id === id) {\r\n          f.state = 'saving';\r\n        }\r\n        return f;\r\n      })\r\n    };\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveSuccess, (state) => {\r\n    const copied = structuredClone(state.fields);\r\n    return {...state, fields: copied.map((f: Field): Field => ({...f, state: 'saved'}))};\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveSuccessFor, (state, {id, groupId = null}) => {\r\n    const copied = structuredClone(state.fields);\r\n    return {\r\n      ...state, fields: copied.map(f => {\r\n        if (groupId && f.groupId === groupId) {\r\n          f.state = 'saved';\r\n        } else if (f.id === id) {\r\n          f.state = 'saved';\r\n        }\r\n        return f;\r\n      })\r\n    };\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveError, (state) => {\r\n    const copied = structuredClone(state.fields);\r\n    return {...state, fields: copied.map((f: Field): Field => ({...f, state: 'error'}))};\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveErrorFor, (state, {id, groupId = null}) => {\r\n    const copied = structuredClone(state.fields);\r\n    return {\r\n      ...state, fields: copied.map(f => {\r\n        if (groupId && f.groupId === groupId) {\r\n          f.state = 'error';\r\n        } else if (f.id === id) {\r\n          f.state = 'error';\r\n        }\r\n        return f;\r\n      })\r\n    };\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveStop, (state) => {\r\n    return {...state, fields: []};\r\n  }),\r\n  on(MrxAutoSaveActions.autosaveStopFor, (state, {id, groupId = null}) => {\r\n    const copied = structuredClone(state.fields);\r\n    return {\r\n      ...state, fields: copied.filter((f) => {\r\n        if (groupId) {\r\n          return f.groupId !== groupId;\r\n        } else {\r\n          return f.id !== id;\r\n        }\r\n      })\r\n    };\r\n  }),\r\n);\r\n\r\nexport function mrxAutoSaveStateReducer(state: MrxAutoSaveState | undefined, action: Action) {\r\n  return reducerCreator(state, action);\r\n}\r\n"]}
|
package/fesm2022/myrta-ui.mjs
CHANGED
|
@@ -3153,16 +3153,12 @@ const reducerCreator = createReducer(initialMrxAutoSaveState, on(autosaveAddId,
|
|
|
3153
3153
|
return { ...state };
|
|
3154
3154
|
}
|
|
3155
3155
|
}), on(autosaveStart, (state) => {
|
|
3156
|
-
|
|
3157
|
-
|
|
3158
|
-
f.state = 'saving';
|
|
3159
|
-
return { ...f };
|
|
3160
|
-
})
|
|
3161
|
-
};
|
|
3156
|
+
const copied = structuredClone(state.fields);
|
|
3157
|
+
return { ...state, fields: copied.map((f) => ({ ...f, state: 'saving' })) };
|
|
3162
3158
|
}), on(autosaveStartFor, (state, { id, groupId = null }) => {
|
|
3163
|
-
const
|
|
3159
|
+
const copied = structuredClone(state.fields);
|
|
3164
3160
|
return {
|
|
3165
|
-
...state, fields:
|
|
3161
|
+
...state, fields: copied.map(f => {
|
|
3166
3162
|
if (groupId && f.groupId === groupId) {
|
|
3167
3163
|
f.state = 'saving';
|
|
3168
3164
|
}
|
|
@@ -3173,16 +3169,12 @@ const reducerCreator = createReducer(initialMrxAutoSaveState, on(autosaveAddId,
|
|
|
3173
3169
|
})
|
|
3174
3170
|
};
|
|
3175
3171
|
}), on(autosaveSuccess, (state) => {
|
|
3176
|
-
|
|
3177
|
-
|
|
3178
|
-
f.state = 'saved';
|
|
3179
|
-
return { ...f };
|
|
3180
|
-
})
|
|
3181
|
-
};
|
|
3172
|
+
const copied = structuredClone(state.fields);
|
|
3173
|
+
return { ...state, fields: copied.map((f) => ({ ...f, state: 'saved' })) };
|
|
3182
3174
|
}), on(autosaveSuccessFor, (state, { id, groupId = null }) => {
|
|
3183
|
-
const
|
|
3175
|
+
const copied = structuredClone(state.fields);
|
|
3184
3176
|
return {
|
|
3185
|
-
...state, fields:
|
|
3177
|
+
...state, fields: copied.map(f => {
|
|
3186
3178
|
if (groupId && f.groupId === groupId) {
|
|
3187
3179
|
f.state = 'saved';
|
|
3188
3180
|
}
|
|
@@ -3193,20 +3185,12 @@ const reducerCreator = createReducer(initialMrxAutoSaveState, on(autosaveAddId,
|
|
|
3193
3185
|
})
|
|
3194
3186
|
};
|
|
3195
3187
|
}), on(autosaveError, (state) => {
|
|
3188
|
+
const copied = structuredClone(state.fields);
|
|
3189
|
+
return { ...state, fields: copied.map((f) => ({ ...f, state: 'error' })) };
|
|
3190
|
+
}), on(autosaveErrorFor, (state, { id, groupId = null }) => {
|
|
3191
|
+
const copied = structuredClone(state.fields);
|
|
3196
3192
|
return {
|
|
3197
|
-
...state, fields:
|
|
3198
|
-
f.state = 'error';
|
|
3199
|
-
return { ...f };
|
|
3200
|
-
})
|
|
3201
|
-
};
|
|
3202
|
-
}),
|
|
3203
|
-
// on(MrxAutoSaveActions.autosaveError, (state) => {
|
|
3204
|
-
// return { ...state, fields: [...state.fields].map(f => ({ ...f, state: 'error' })) };
|
|
3205
|
-
// }),
|
|
3206
|
-
on(autosaveErrorFor, (state, { id, groupId = null }) => {
|
|
3207
|
-
const fields = cloneDeep(state.fields);
|
|
3208
|
-
return {
|
|
3209
|
-
...state, fields: fields.map(f => {
|
|
3193
|
+
...state, fields: copied.map(f => {
|
|
3210
3194
|
if (groupId && f.groupId === groupId) {
|
|
3211
3195
|
f.state = 'error';
|
|
3212
3196
|
}
|
|
@@ -3219,9 +3203,9 @@ on(autosaveErrorFor, (state, { id, groupId = null }) => {
|
|
|
3219
3203
|
}), on(autosaveStop, (state) => {
|
|
3220
3204
|
return { ...state, fields: [] };
|
|
3221
3205
|
}), on(autosaveStopFor, (state, { id, groupId = null }) => {
|
|
3206
|
+
const copied = structuredClone(state.fields);
|
|
3222
3207
|
return {
|
|
3223
|
-
...state,
|
|
3224
|
-
fields: state.fields.filter((f) => {
|
|
3208
|
+
...state, fields: copied.filter((f) => {
|
|
3225
3209
|
if (groupId) {
|
|
3226
3210
|
return f.groupId !== groupId;
|
|
3227
3211
|
}
|
|
@@ -10976,6 +10960,7 @@ class InputFileImageComponent {
|
|
|
10976
10960
|
imageUploadService;
|
|
10977
10961
|
_modalService;
|
|
10978
10962
|
_detector;
|
|
10963
|
+
isProcessing = false;
|
|
10979
10964
|
formatBytes = formatBytes;
|
|
10980
10965
|
extensions;
|
|
10981
10966
|
allowedExtensions = [];
|
|
@@ -11109,6 +11094,9 @@ class InputFileImageComponent {
|
|
|
11109
11094
|
}
|
|
11110
11095
|
changePreview(event, file) {
|
|
11111
11096
|
event.stopPropagation();
|
|
11097
|
+
if (this.isProcessing)
|
|
11098
|
+
return;
|
|
11099
|
+
this.isProcessing = true;
|
|
11112
11100
|
getBase64FromUrl(this.downloadUrl(file)).then((base64Url) => {
|
|
11113
11101
|
this._modalService.open(FileImageEditModalComponent, {
|
|
11114
11102
|
title: 'РЕДАКТИРОВАНИЕ ИЗОБРАЖЕНИЯ',
|
|
@@ -11123,6 +11111,7 @@ class InputFileImageComponent {
|
|
|
11123
11111
|
if (res.result && res.fileImage) {
|
|
11124
11112
|
this._updateFile(file, res.fileImage);
|
|
11125
11113
|
}
|
|
11114
|
+
this.isProcessing = false;
|
|
11126
11115
|
});
|
|
11127
11116
|
});
|
|
11128
11117
|
}
|