myrta-ui 17.0.5 → 17.0.6

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.
@@ -202,7 +202,6 @@ export class InputFileComponent {
202
202
  percentage: 0,
203
203
  file: file
204
204
  };
205
- console.log(data);
206
205
  if (!this.checkForUpload(data)) {
207
206
  return;
208
207
  }
@@ -364,4 +363,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
364
363
  }], checkDroppedFile: [{
365
364
  type: Output
366
365
  }] } });
367
- //# 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 disabled = false;\r\n  @Input() public viewOnly = false;\r\n  @Input() public lightDisabled = 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() {\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  trackByFn(index: number, item: InputFileModel) {\r\n    return Boolean(item.id) ? item.id : item.tempUuid;\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  canCancelUploading(file: InputFileModel): boolean {\r\n    return !!file.uploading && file.percentage ? file.percentage < 90 : false;\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    }\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 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      }\r\n    }\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.fileUploadService.delete(this._transformUrl(this.deleteEndPoint, findFile)).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 _uploadFile(file: File): void {\r\n    const data = {\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    console.log(data)\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.id = 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.id = 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): boolean {\r\n    this.checkDroppedFile.emit(data)\r\n\r\n    if (!this.canAdd) {\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    this.files.push(data);\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=\"disabled; else notDisabled\">\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.length)}}</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 #notDisabled>\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]=\"lightDisabled\"\r\n      [ngClass]=\"{'ng-custom-file-input--disabled': lightDisabled}\"\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)=\"!lightDisabled ? 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\">\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.id && 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          <div class=\"ng-custom-file-input_progress\">\r\n            <span [ngStyle]=\"{width: 75 + '%'}\"></span>\r\n          </div>\r\n\r\n          <span class=\"qq-upload-size-selector qq-upload-size\" *ngIf=\"!file.error\">{{formatBytes(file.length)}}</span>\r\n          <span\r\n            *ngIf=\"!disabled && showDeleteButton && !viewOnly && !file.error\"\r\n            (click)=\"delete($event, 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.id) || 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"]}
366
+ //# 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 disabled = false;\r\n  @Input() public viewOnly = false;\r\n  @Input() public lightDisabled = 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() {\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  trackByFn(index: number, item: InputFileModel) {\r\n    return Boolean(item.id) ? item.id : item.tempUuid;\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  canCancelUploading(file: InputFileModel): boolean {\r\n    return !!file.uploading && file.percentage ? file.percentage < 90 : false;\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    }\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 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      }\r\n    }\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.fileUploadService.delete(this._transformUrl(this.deleteEndPoint, findFile)).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 _uploadFile(file: File): void {\r\n    const data = {\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.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.id = 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.id = 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): boolean {\r\n    this.checkDroppedFile.emit(data)\r\n\r\n    if (!this.canAdd) {\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    this.files.push(data);\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=\"disabled; else notDisabled\">\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.length)}}</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 #notDisabled>\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]=\"lightDisabled\"\r\n      [ngClass]=\"{'ng-custom-file-input--disabled': lightDisabled}\"\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)=\"!lightDisabled ? 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\">\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.id && 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          <div class=\"ng-custom-file-input_progress\">\r\n            <span [ngStyle]=\"{width: 75 + '%'}\"></span>\r\n          </div>\r\n\r\n          <span class=\"qq-upload-size-selector qq-upload-size\" *ngIf=\"!file.error\">{{formatBytes(file.length)}}</span>\r\n          <span\r\n            *ngIf=\"!disabled && showDeleteButton && !viewOnly && !file.error\"\r\n            (click)=\"delete($event, 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.id) || 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"]}
@@ -107,11 +107,11 @@ export class PaginatorComponent {
107
107
  return item.id;
108
108
  }
109
109
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
110
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}.mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}.mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}.mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}.mrx-paginator .mrx-paginator__item.dots,.mrx-paginator .mrx-paginator__item.disabled{cursor:default}.mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}.mrx-paginator .mrx-paginator__previous,.mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}.mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,.mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}.mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.InputSelectComponent, selector: "mrx-input-select", inputs: ["fields", "size", "selected", "bindValue", "bindLabel", "customClasses", "wrapperCustomClasses", "multiple", "loading", "addTag", "clearable", "items", "groupBy", "emptyValue", "virtualScroll", "trackByFn", "displayValue", "disabledFromDisplay", "maxLength", "customSearchFn", "isBottomLabel", "search", "required", "disabled", "readonly", "showEmptyFields", "placeholder", "searchable", "loadLabel", "notFoundText", "closeOnSelect", "multiCollapseCount", "invalid", "invalidMessage", "checkInvalid", "label", "labelRequiredHidden", "labelExtraClass", "tooltip", "tooltipHidden", "tooltipVisible", "maxSelectedItems"], outputs: ["changed", "modelChange", "searched"] }] });
110
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n size=\"medium\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.InputSelectComponent, selector: "mrx-input-select", inputs: ["fields", "size", "selected", "bindValue", "bindLabel", "customClasses", "wrapperCustomClasses", "multiple", "loading", "addTag", "clearable", "items", "groupBy", "emptyValue", "virtualScroll", "trackByFn", "displayValue", "disabledFromDisplay", "maxLength", "customSearchFn", "isBottomLabel", "search", "required", "disabled", "readonly", "showEmptyFields", "placeholder", "searchable", "loadLabel", "notFoundText", "closeOnSelect", "multiCollapseCount", "invalid", "invalidMessage", "checkInvalid", "label", "labelRequiredHidden", "labelExtraClass", "tooltip", "tooltipHidden", "tooltipVisible", "maxSelectedItems"], outputs: ["changed", "modelChange", "searched"] }] });
111
111
  }
112
112
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PaginatorComponent, decorators: [{
113
113
  type: Component,
114
- args: [{ selector: 'mrx-paginator', template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}.mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}.mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}.mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}.mrx-paginator .mrx-paginator__item.dots,.mrx-paginator .mrx-paginator__item.disabled{cursor:default}.mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}.mrx-paginator .mrx-paginator__previous,.mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}.mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,.mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}.mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"] }]
114
+ args: [{ selector: 'mrx-paginator', template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n size=\"medium\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"] }]
115
115
  }], propDecorators: { pageSizes: [{
116
116
  type: Input
117
117
  }], currentPage: [{
@@ -137,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
137
137
  }], dataStateChanged: [{
138
138
  type: Output
139
139
  }] } });
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.ts","../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport {\r\n  PaginateOutputObject,\r\n  PaginatorItem,\r\n  PaginatorPosition, PaginatorPositionCss,\r\n} from './paginator.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-paginator',\r\n  templateUrl: './paginator.component.html',\r\n  styleUrls: ['./paginator.component.less']\r\n})\r\nexport class PaginatorComponent {\r\n  public position: PaginatorPosition | undefined = 'centered';\r\n  public withPageSize: boolean | undefined = true;\r\n\r\n  @Input() pageSizes: number[] = [20, 50, 100];\r\n  @Input() currentPage = 1;\r\n  @Input() pageSize = 20;\r\n  @Input() total = 0;\r\n  @Input() customClasses = '';\r\n\r\n  @Input() isEmptyPaginator: boolean = false;\r\n  @Input() isPaginatorText: boolean = false;\r\n  @Input() paginatorText: string = 'записи';\r\n\r\n  @Input('position')\r\n  public set setPosition(value: PaginatorPosition | undefined) {\r\n    this.position = value || 'centered';\r\n  }\r\n\r\n  @Input('withPageSize')\r\n  public set setWithPageSize(value: boolean | undefined) {\r\n    this.withPageSize = value || false;\r\n  }\r\n\r\n  @Output() dataStateChanged: EventEmitter<PaginateOutputObject> = new EventEmitter<PaginateOutputObject>();\r\n\r\n  public get getClasses(): string {\r\n    return `${this.position && PaginatorPositionCss[this.position]} ${this.customClasses}`;\r\n  }\r\n\r\n  public get getItems(): number {\r\n    return Math.ceil(this.total / this.pageSize);\r\n  }\r\n\r\n  public get getNumbers(): PaginatorItem[] {\r\n    return Array(this.getItems)\r\n      .fill(1)\r\n      .map((item, index) => ({ index: index + 1, active: index + 1 === this.currentPage }));\r\n  }\r\n\r\n  public get getViewItems(): PaginatorItem[] {\r\n    return this.getNumbers.filter((item, index) => {\r\n      if (this.currentPage === 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2 ||\r\n          item.index === this.currentPage + 3 ||\r\n          item.index === this.currentPage + 4;\r\n      } else if (this.currentPage == 2 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2 ||\r\n          item.index === this.currentPage + 3;\r\n      } else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 3 ||\r\n          item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1;\r\n      } else if (this.currentPage > 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2;\r\n      } else {\r\n        return item.index === this.currentPage - 4 ||\r\n          item.index === this.currentPage - 3 ||\r\n          item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage;\r\n      }\r\n    });\r\n  }\r\n\r\n  public get getFirstNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage - this.pageSize + 1) {\r\n      return 1;\r\n    }\r\n\r\n    return (this.pageSize * this.currentPage - this.pageSize) + 1;\r\n  }\r\n\r\n  public get getLastNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage) {\r\n      return this.total;\r\n    }\r\n    return this.pageSize * this.currentPage;\r\n  }\r\n\r\n  public onChangeCurrentPage(value: number): void {\r\n    this.dataStateChanged.emit({\r\n      currentPage: value,\r\n      pageSize: this.pageSize\r\n    });\r\n  }\r\n\r\n  public onChangePageSize(value: number): void {\r\n    this.currentPage = 1;\r\n\r\n    this.dataStateChanged.emit({\r\n      currentPage: this.currentPage,\r\n      pageSize: value\r\n    });\r\n  }\r\n\r\n  public trackByFn(index: number, item: any) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n  <ul class=\"mrx-paginator__list\">\r\n    <li\r\n      class=\"mrx-paginator__previous\"\r\n      [class.disabled]=\"currentPage <= 1\"\r\n      (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n      <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n    </li>\r\n\r\n    <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item\">1</li>\r\n\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__item\"\r\n      *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n      (click)=\"onChangeCurrentPage(item.index)\"\r\n      [class.active]=\"currentPage === item.index\"\r\n    >\r\n      {{item.index}}\r\n    </li>\r\n\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n        (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__next\"\r\n      [class.disabled]=\"currentPage >= getItems\"\r\n      (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n      <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n    </li>\r\n  </ul>\r\n\r\n  <ng-template #select>\r\n    <mrx-input-select\r\n      *ngIf=\"withPageSize\"\r\n      [(ngModel)]=\"pageSize\"\r\n      [items]=\"pageSizes\"\r\n      [clearable]=\"false\"\r\n      [searchable]=\"false\"\r\n      (ngModelChange)=\"onChangePageSize($event)\"\r\n    ></mrx-input-select>\r\n<!--    <ng-select-->\r\n<!--      *ngIf=\"withPageSize\"-->\r\n<!--      [(ngModel)]=\"pageSize\"-->\r\n<!--      [items]=\"pageSizes\"-->\r\n<!--      [clearable]=\"false\"-->\r\n<!--      [searchable]=\"false\"-->\r\n<!--      (change)=\"onChangePageSize($event)\"-->\r\n<!--      class=\"ml-3\"-->\r\n<!--    ></ng-select>-->\r\n  </ng-template>\r\n\r\n  <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n  <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n    Отображены {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} из {{total}}\r\n  </div>\r\n</div>\r\n\r\n\r\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.ts","../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport {\r\n  PaginateOutputObject,\r\n  PaginatorItem,\r\n  PaginatorPosition, PaginatorPositionCss,\r\n} from './paginator.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-paginator',\r\n  templateUrl: './paginator.component.html',\r\n  styleUrls: ['./paginator.component.less']\r\n})\r\nexport class PaginatorComponent {\r\n  public position: PaginatorPosition | undefined = 'centered';\r\n  public withPageSize: boolean | undefined = true;\r\n\r\n  @Input() pageSizes: number[] = [20, 50, 100];\r\n  @Input() currentPage = 1;\r\n  @Input() pageSize = 20;\r\n  @Input() total = 0;\r\n  @Input() customClasses = '';\r\n\r\n  @Input() isEmptyPaginator: boolean = false;\r\n  @Input() isPaginatorText: boolean = false;\r\n  @Input() paginatorText: string = 'записи';\r\n\r\n  @Input('position')\r\n  public set setPosition(value: PaginatorPosition | undefined) {\r\n    this.position = value || 'centered';\r\n  }\r\n\r\n  @Input('withPageSize')\r\n  public set setWithPageSize(value: boolean | undefined) {\r\n    this.withPageSize = value || false;\r\n  }\r\n\r\n  @Output() dataStateChanged: EventEmitter<PaginateOutputObject> = new EventEmitter<PaginateOutputObject>();\r\n\r\n  public get getClasses(): string {\r\n    return `${this.position && PaginatorPositionCss[this.position]} ${this.customClasses}`;\r\n  }\r\n\r\n  public get getItems(): number {\r\n    return Math.ceil(this.total / this.pageSize);\r\n  }\r\n\r\n  public get getNumbers(): PaginatorItem[] {\r\n    return Array(this.getItems)\r\n      .fill(1)\r\n      .map((item, index) => ({ index: index + 1, active: index + 1 === this.currentPage }));\r\n  }\r\n\r\n  public get getViewItems(): PaginatorItem[] {\r\n    return this.getNumbers.filter((item, index) => {\r\n      if (this.currentPage === 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2 ||\r\n          item.index === this.currentPage + 3 ||\r\n          item.index === this.currentPage + 4;\r\n      } else if (this.currentPage == 2 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2 ||\r\n          item.index === this.currentPage + 3;\r\n      } else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 3 ||\r\n          item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1;\r\n      } else if (this.currentPage > 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2;\r\n      } else {\r\n        return item.index === this.currentPage - 4 ||\r\n          item.index === this.currentPage - 3 ||\r\n          item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage;\r\n      }\r\n    });\r\n  }\r\n\r\n  public get getFirstNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage - this.pageSize + 1) {\r\n      return 1;\r\n    }\r\n\r\n    return (this.pageSize * this.currentPage - this.pageSize) + 1;\r\n  }\r\n\r\n  public get getLastNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage) {\r\n      return this.total;\r\n    }\r\n    return this.pageSize * this.currentPage;\r\n  }\r\n\r\n  public onChangeCurrentPage(value: number): void {\r\n    this.dataStateChanged.emit({\r\n      currentPage: value,\r\n      pageSize: this.pageSize\r\n    });\r\n  }\r\n\r\n  public onChangePageSize(value: number): void {\r\n    this.currentPage = 1;\r\n\r\n    this.dataStateChanged.emit({\r\n      currentPage: this.currentPage,\r\n      pageSize: value\r\n    });\r\n  }\r\n\r\n  public trackByFn(index: number, item: any) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n  <ul class=\"mrx-paginator__list\">\r\n    <li\r\n      class=\"mrx-paginator__previous\"\r\n      [class.disabled]=\"currentPage <= 1\"\r\n      (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n      <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n    </li>\r\n\r\n    <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__item\"\r\n      *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n      (click)=\"onChangeCurrentPage(item.index)\"\r\n      [class.active]=\"currentPage === item.index\"\r\n    >\r\n      {{item.index}}\r\n    </li>\r\n\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n        (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__next\"\r\n      [class.disabled]=\"currentPage >= getItems\"\r\n      (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n      <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n    </li>\r\n  </ul>\r\n\r\n  <ng-template #select>\r\n    <mrx-input-select\r\n      *ngIf=\"withPageSize\"\r\n      size=\"medium\"\r\n      [(ngModel)]=\"pageSize\"\r\n      [items]=\"pageSizes\"\r\n      [clearable]=\"false\"\r\n      [searchable]=\"false\"\r\n      (ngModelChange)=\"onChangePageSize($event)\"\r\n    ></mrx-input-select>\r\n<!--    <ng-select-->\r\n<!--      *ngIf=\"withPageSize\"-->\r\n<!--      [(ngModel)]=\"pageSize\"-->\r\n<!--      [items]=\"pageSizes\"-->\r\n<!--      [clearable]=\"false\"-->\r\n<!--      [searchable]=\"false\"-->\r\n<!--      (change)=\"onChangePageSize($event)\"-->\r\n<!--      class=\"ml-3\"-->\r\n<!--    ></ng-select>-->\r\n  </ng-template>\r\n\r\n  <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n  <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n    Отображены {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} из {{total}}\r\n  </div>\r\n</div>\r\n\r\n\r\n"]}
@@ -2331,11 +2331,11 @@ class PaginatorComponent {
2331
2331
  return item.id;
2332
2332
  }
2333
2333
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2334
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}.mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}.mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}.mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}.mrx-paginator .mrx-paginator__item.dots,.mrx-paginator .mrx-paginator__item.disabled{cursor:default}.mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}.mrx-paginator .mrx-paginator__previous,.mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}.mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,.mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}.mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: InputSelectComponent, selector: "mrx-input-select", inputs: ["fields", "size", "selected", "bindValue", "bindLabel", "customClasses", "wrapperCustomClasses", "multiple", "loading", "addTag", "clearable", "items", "groupBy", "emptyValue", "virtualScroll", "trackByFn", "displayValue", "disabledFromDisplay", "maxLength", "customSearchFn", "isBottomLabel", "search", "required", "disabled", "readonly", "showEmptyFields", "placeholder", "searchable", "loadLabel", "notFoundText", "closeOnSelect", "multiCollapseCount", "invalid", "invalidMessage", "checkInvalid", "label", "labelRequiredHidden", "labelExtraClass", "tooltip", "tooltipHidden", "tooltipVisible", "maxSelectedItems"], outputs: ["changed", "modelChange", "searched"] }] });
2334
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n size=\"medium\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: InputSelectComponent, selector: "mrx-input-select", inputs: ["fields", "size", "selected", "bindValue", "bindLabel", "customClasses", "wrapperCustomClasses", "multiple", "loading", "addTag", "clearable", "items", "groupBy", "emptyValue", "virtualScroll", "trackByFn", "displayValue", "disabledFromDisplay", "maxLength", "customSearchFn", "isBottomLabel", "search", "required", "disabled", "readonly", "showEmptyFields", "placeholder", "searchable", "loadLabel", "notFoundText", "closeOnSelect", "multiCollapseCount", "invalid", "invalidMessage", "checkInvalid", "label", "labelRequiredHidden", "labelExtraClass", "tooltip", "tooltipHidden", "tooltipVisible", "maxSelectedItems"], outputs: ["changed", "modelChange", "searched"] }] });
2335
2335
  }
2336
2336
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PaginatorComponent, decorators: [{
2337
2337
  type: Component,
2338
- args: [{ selector: 'mrx-paginator', template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [".mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}.mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}.mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}.mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}.mrx-paginator .mrx-paginator__item.dots,.mrx-paginator .mrx-paginator__item.disabled{cursor:default}.mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}.mrx-paginator .mrx-paginator__previous,.mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}.mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,.mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}.mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"] }]
2338
+ args: [{ selector: 'mrx-paginator', template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n <ng-template #select>\r\n <mrx-input-select\r\n *ngIf=\"withPageSize\"\r\n size=\"medium\"\r\n [(ngModel)]=\"pageSize\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-input-select>\r\n<!-- <ng-select-->\r\n<!-- *ngIf=\"withPageSize\"-->\r\n<!-- [(ngModel)]=\"pageSize\"-->\r\n<!-- [items]=\"pageSizes\"-->\r\n<!-- [clearable]=\"false\"-->\r\n<!-- [searchable]=\"false\"-->\r\n<!-- (change)=\"onChangePageSize($event)\"-->\r\n<!-- class=\"ml-3\"-->\r\n<!-- ></ng-select>-->\r\n </ng-template>\r\n\r\n <ng-container *ngTemplateOutlet=\"select\"></ng-container>\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"] }]
2339
2339
  }], propDecorators: { pageSizes: [{
2340
2340
  type: Input
2341
2341
  }], currentPage: [{
@@ -10718,7 +10718,6 @@ class InputFileComponent {
10718
10718
  percentage: 0,
10719
10719
  file: file
10720
10720
  };
10721
- console.log(data);
10722
10721
  if (!this.checkForUpload(data)) {
10723
10722
  return;
10724
10723
  }