myrta-ui 17.1.59 → 17.1.60

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.
@@ -317,4 +317,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
317
317
  type: ViewChild,
318
318
  args: ['dateInput']
319
319
  }] } });
320
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/input-date.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  adjustInvalidDate,\r\n  clampDate,\r\n  getRangeErrorMessage,\r\n  isDateInRange,\r\n  isValidDate,\r\n  parseInputDate,\r\n  toOutputFormat,\r\n  formatDate\r\n} from './helpers/date-helpers';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { DateCalendarComponent } from './components/date-calendar/date-calendar.component';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { InputDateSizesEnum, InputDateSizesTypes, InputDateValueTypes, InputDateValueWithId } from './input-date.enum';\r\nimport { InputDateTimeSizesTypes } from '../input-date-time/input-date-time.enum';\r\nimport { dateModelConstant, timeModelConstant } from '../input-date-time/constants/value-models';\r\nimport { InputDateTimeValueTypes, InputDateTimeValueWithId } from '../input-date-time/models/input-date-time.model';\r\nimport { filter, fromEvent, Subscription } from 'rxjs';\r\nimport { PositionStrategyEnum, PositionType } from '../../../enums/overlay';\r\n\r\n@Component({\r\n  selector: 'mrx-input-date',\r\n  templateUrl: './input-date.component.html',\r\n  styleUrl: './input-date.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputDateComponent),\r\n      multi: true\r\n    }\r\n  ],\r\n})\r\nexport class InputDateComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n  private _clickSubscription!: Subscription;\r\n  private _overlayRef: OverlayRef | null = null;\r\n\r\n  displayValue: string = '';\r\n  selectedDate: Date | null = null;\r\n  mask: string = '';\r\n  errorMessage: string | null = null;\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public format: string = 'DD.MM.YYYY';\r\n  @Input() public minDate: string | null = null;\r\n  @Input() public maxDate: string | null = null;\r\n  @Input() public isSilentValidation: boolean = true;\r\n  @Input() public isManualInput = true;\r\n  @Input() public closeAfterSelect = true;\r\n  @Input() public required = false;\r\n  @Input() public size: InputDateSizesTypes = 'large';\r\n  @Input() public customClasses = '';\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public placeholder = 'дд.мм.гггг';\r\n  @Input() public popupPosition: PositionType = 'bottom-start';\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n  @Input() scrollStrategy: 'reposition' | 'close' = 'reposition';\r\n\r\n  @Output() public changed: EventEmitter<InputDateTimeValueTypes> = new EventEmitter();\r\n  @Output() public modelChange: EventEmitter<InputDateTimeValueWithId> = new EventEmitter<InputDateTimeValueWithId>();\r\n  @Output() public blurred: EventEmitter<InputDateTimeValueWithId> = new EventEmitter<InputDateTimeValueWithId>();\r\n\r\n  @ViewChild('dateInput') dateInput!: ElementRef;\r\n\r\n  private onChange: (value: string) => void = () => {};\r\n  private onTouched: () => void = () => {};\r\n\r\n  constructor(\r\n    private _overlay: Overlay,\r\n    private _detector: ChangeDetectorRef,\r\n    private _elementRef: ElementRef\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.mask = this.format.replace(/[DMY]/g, '0');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._clickSubscription?.unsubscribe();\r\n    this.closeCalendar();\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    if (!this.required) {\r\n      return '';\r\n    } else {\r\n      return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n    }\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${InputDateSizesEnum[this.size]} ${this.customClasses} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get isViewCleanIcon() {\r\n    return !!this.dateInput?.nativeElement.value;\r\n  }\r\n\r\n  writeValue(value: string): void {\r\n    const date = parseInputDate(value);\r\n\r\n    if (date && isDateInRange(date, this.minDate, this.maxDate)) {\r\n      this.selectedDate = date;\r\n      this.displayValue = formatDate(date, this.format);\r\n      this.errorMessage = null;\r\n    } else if (this.isSilentValidation && date) {\r\n      const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n      this.selectedDate = clampedDate;\r\n      this.displayValue = formatDate(clampedDate, this.format);\r\n      this.errorMessage = null;\r\n    } else {\r\n      this.selectedDate = null;\r\n      this.displayValue = date ? formatDate(date, this.format) : '';\r\n      this.errorMessage = date ? getRangeErrorMessage(date, this.minDate, this.maxDate) : null;\r\n    }\r\n\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  registerOnChange(fn: (value: string) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  set value(value: string) {\r\n    const date = parseInputDate(value);\r\n\r\n    if (date && isDateInRange(date, this.minDate, this.maxDate)) {\r\n      this.selectedDate = date;\r\n      this.displayValue = formatDate(date, this.format);\r\n      this.errorMessage = null;\r\n      this.updateValue(value);\r\n    } else if (this.isSilentValidation && date) {\r\n      const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n      this.selectedDate = clampedDate;\r\n      this.displayValue = formatDate(clampedDate, this.format);\r\n      this.errorMessage = null;\r\n      const clampedValue = toOutputFormat(clampedDate);\r\n      this.updateValue(clampedValue);\r\n    } else {\r\n      this.selectedDate = null;\r\n      this.displayValue = date ? formatDate(date, this.format) : '';\r\n      this.errorMessage = date ? getRangeErrorMessage(date, this.minDate, this.maxDate) : null;\r\n    }\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  onInput(event: Event) {\r\n    const inputElement = event.target as HTMLInputElement;\r\n    const inputValue = inputElement.value;\r\n    this.processInput(inputValue);\r\n  }\r\n\r\n  private processInput(inputValue: string) {\r\n    this.displayValue = inputValue;\r\n    this.errorMessage = null;\r\n\r\n    if (inputValue.length === this.format.length) {\r\n      const separator = this.format.match(/[^DMY]/)?.[0] || '.';\r\n      const regex = new RegExp(`^(\\\\d{2})${separator}(\\\\d{2})${separator}(\\\\d{4})$`);\r\n      const match = inputValue.match(regex);\r\n\r\n      if (!match) return;\r\n\r\n      let day, month, year;\r\n      if (this.format.startsWith('DD')) {\r\n        [day, month, year] = [match[1], match[2], match[3]].map(Number);\r\n      } else if (this.format.startsWith('MM')) {\r\n        [month, day, year] = [match[1], match[2], match[3]].map(Number);\r\n      } else {\r\n        [year, month, day] = [match[1], match[2], match[3]].map(Number);\r\n      }\r\n      month -= 1;\r\n\r\n      let date = new Date(year, month, day);\r\n\r\n      if (isValidDate(date) && isDateInRange(date, this.minDate, this.maxDate)) {\r\n        this.selectedDate = date;\r\n        this.updateValue(toOutputFormat(date));\r\n      } else {\r\n        const { year: adjYear, month: adjMonth, day: adjDay } = adjustInvalidDate(year, month, day);\r\n        date = new Date(adjYear, adjMonth, adjDay);\r\n\r\n        if (isDateInRange(date, this.minDate, this.maxDate)) {\r\n          this.selectedDate = date;\r\n          this.displayValue = formatDate(date, this.format);\r\n          this.updateValue(toOutputFormat(date));\r\n        } else if (this.isSilentValidation) {\r\n          const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n          this.selectedDate = clampedDate;\r\n          this.displayValue = formatDate(clampedDate, this.format);\r\n          this.updateValue(toOutputFormat(clampedDate));\r\n        } else {\r\n          this.selectedDate = null;\r\n          this.errorMessage = getRangeErrorMessage(date, this.minDate, this.maxDate);\r\n        }\r\n      }\r\n    }\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  onBlur() {\r\n    this.onTouched();\r\n\r\n    if (this.displayValue.length > 0 && this.displayValue.length < this.format.length) {\r\n      this.displayValue = '';\r\n      this.selectedDate = null;\r\n      this.updateValue('');\r\n      this.errorMessage = null;\r\n    }\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  openCalendar() {\r\n    if (this.disabled || this._overlayRef) return;\r\n\r\n    const positionStrategy = this._overlay\r\n      .position()\r\n      .flexibleConnectedTo(this.dateInput)\r\n      .withPositions(PositionStrategyEnum[this.popupPosition]);\r\n\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy,\r\n      hasBackdrop: false,\r\n      scrollStrategy: this.scrollStrategy === 'reposition' ? this._overlay.scrollStrategies.reposition() : this._overlay.scrollStrategies.close(),\r\n    });\r\n\r\n    const portal = new ComponentPortal(DateCalendarComponent);\r\n    const componentRef = this._overlayRef.attach(portal);\r\n\r\n    componentRef.instance.selectedDate = this.selectedDate;\r\n    componentRef.instance.minDate = this.minDate;\r\n    componentRef.instance.maxDate = this.maxDate;\r\n    componentRef.instance.dateSelected.subscribe((date: Date) => this.onDateSelected(date));\r\n    componentRef.instance.close.subscribe(() => this.closeCalendar());\r\n\r\n    this._clickSubscription = fromEvent(document, 'click')\r\n      .pipe(\r\n        filter((event: Event) => {\r\n          const clickTarget = event.target as HTMLElement;\r\n          return (\r\n            !!this._overlayRef &&\r\n            !this._overlayRef.overlayElement.contains(clickTarget) &&\r\n            !this._elementRef.nativeElement.contains(clickTarget)\r\n          );\r\n        })\r\n      )\r\n      .subscribe(() => this.closeCalendar());\r\n  }\r\n\r\n  onDateSelected(date: Date) {\r\n    const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n    this.selectedDate = clampedDate;\r\n    this.displayValue = formatDate(clampedDate, this.format);\r\n    this.errorMessage = null;\r\n    this.updateValue(toOutputFormat(clampedDate));\r\n\r\n    if (this.closeAfterSelect) {\r\n      this.closeCalendar();\r\n    }\r\n\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  closeCalendar() {\r\n    if (this._overlayRef) {\r\n      this._overlayRef.dispose();\r\n      this._overlayRef = null;\r\n    }\r\n    this.errorMessage = null;\r\n  }\r\n\r\n  public clickToIconCalendar(): void {\r\n    this.openCalendar();\r\n  }\r\n\r\n  public clickToIconClear(): void {\r\n    this.displayValue = '';\r\n    this.selectedDate = null;\r\n    this.errorMessage = null;\r\n\r\n    this.updateValue('');\r\n    this.closeCalendar();\r\n\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  public updateValue(insideValue: InputDateValueTypes) {\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({ value: insideValue, id: this.uuid });\r\n    this.onChange(insideValue);\r\n    this.onTouched();\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-date\"\r\n  [class.mrx-input-error]=\"invalid\"\r\n  [class.mrx-input-readonly]=\"readonly\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div class=\"mrx-input-date__wrapper\">\r\n    <input\r\n      #dateInput\r\n      type=\"text\"\r\n      autocomplete=\"nope\"\r\n      class=\"mrx-input-date__input mrx-input-date__date\"\r\n      [ngModel]=\"displayValue\"\r\n      [disabled]=\"disabled\"\r\n      [readOnly]=\"!isManualInput\"\r\n      [mask]=\"mask\"\r\n      [leadZeroDateTime]=\"true\"\r\n      [dropSpecialCharacters]=\"false\"\r\n      [placeholder]=\"placeholder\"\r\n      (click)=\"openCalendar()\"\r\n      (input)=\"onInput($event)\"\r\n      (blur)=\"onBlur()\"\r\n    />\r\n\r\n    @if (!disabled) {\r\n      <div class=\"mrx-input-date__icons\">\r\n        @if (isViewCleanIcon) {\r\n          <span\r\n            class=\"mrx-icon icon-close\"\r\n            (click)=\"clickToIconClear()\"\r\n            [class.icon-font-16]=\"size === 'small'\"\r\n            [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n          ></span>\r\n        }\r\n\r\n        <span\r\n          class=\"mrx-icon icon-calendar\"\r\n          (click)=\"clickToIconCalendar()\"\r\n          [class.icon-font-16]=\"size === 'small'\"\r\n          [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n        ></span>\r\n      </div>\r\n    }\r\n  </div>\r\n\r\n  @if (invalid) {\r\n    <mrx-error-message [invalidMessage]=\"invalidMessage\"></mrx-error-message>\r\n  } @else {\r\n    @if (errorMessage) {\r\n      <mrx-error-message [invalidMessage]=\"errorMessage\"></mrx-error-message>\r\n    }\r\n  }\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
320
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/input-date.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  adjustInvalidDate,\r\n  clampDate,\r\n  getRangeErrorMessage,\r\n  isDateInRange,\r\n  isValidDate,\r\n  parseInputDate,\r\n  toOutputFormat,\r\n  formatDate\r\n} from './helpers/date-helpers';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { DateCalendarComponent } from './components/date-calendar/date-calendar.component';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { InputDateSizesEnum, InputDateSizesTypes, InputDateValueTypes, InputDateValueWithId } from './input-date.enum';\r\nimport { InputDateTimeSizesTypes } from '../input-date-time/input-date-time.enum';\r\nimport { dateModelConstant, timeModelConstant } from '../input-date-time/constants/value-models';\r\nimport { InputDateTimeValueTypes, InputDateTimeValueWithId } from '../input-date-time/models/input-date-time.model';\r\nimport { filter, fromEvent, Subscription } from 'rxjs';\r\nimport { PositionStrategyEnum, PositionType } from '../../../enums/overlay';\r\n\r\n@Component({\r\n  selector: 'mrx-input-date',\r\n  templateUrl: './input-date.component.html',\r\n  styleUrl: './input-date.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputDateComponent),\r\n      multi: true\r\n    }\r\n  ],\r\n})\r\nexport class InputDateComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n  private _clickSubscription!: Subscription;\r\n  private _overlayRef: OverlayRef | null = null;\r\n\r\n  displayValue: string = '';\r\n  selectedDate: Date | null = null;\r\n  mask: string = '';\r\n  errorMessage: string | null = null;\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public format: string = 'DD.MM.YYYY';\r\n  @Input() public minDate: string | null = null;\r\n  @Input() public maxDate: string | null = null;\r\n  @Input() public isSilentValidation: boolean = true;\r\n  @Input() public isManualInput = true;\r\n  @Input() public closeAfterSelect = true;\r\n  @Input() public required = false;\r\n  @Input() public size: InputDateSizesTypes = 'large';\r\n  @Input() public customClasses = '';\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public placeholder = 'дд.мм.гггг';\r\n  @Input() public popupPosition: PositionType = 'bottom-start';\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n  @Input() public scrollStrategy: 'reposition' | 'close' = 'reposition';\r\n\r\n  @Output() public changed: EventEmitter<InputDateTimeValueTypes> = new EventEmitter();\r\n  @Output() public modelChange: EventEmitter<InputDateTimeValueWithId> = new EventEmitter<InputDateTimeValueWithId>();\r\n  @Output() public blurred: EventEmitter<InputDateTimeValueWithId> = new EventEmitter<InputDateTimeValueWithId>();\r\n\r\n  @ViewChild('dateInput') dateInput!: ElementRef;\r\n\r\n  private onChange: (value: string) => void = () => {};\r\n  private onTouched: () => void = () => {};\r\n\r\n  constructor(\r\n    private _overlay: Overlay,\r\n    private _detector: ChangeDetectorRef,\r\n    private _elementRef: ElementRef\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.mask = this.format.replace(/[DMY]/g, '0');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._clickSubscription?.unsubscribe();\r\n    this.closeCalendar();\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    if (!this.required) {\r\n      return '';\r\n    } else {\r\n      return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n    }\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${InputDateSizesEnum[this.size]} ${this.customClasses} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get isViewCleanIcon() {\r\n    return !!this.dateInput?.nativeElement.value;\r\n  }\r\n\r\n  writeValue(value: string): void {\r\n    const date = parseInputDate(value);\r\n\r\n    if (date && isDateInRange(date, this.minDate, this.maxDate)) {\r\n      this.selectedDate = date;\r\n      this.displayValue = formatDate(date, this.format);\r\n      this.errorMessage = null;\r\n    } else if (this.isSilentValidation && date) {\r\n      const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n      this.selectedDate = clampedDate;\r\n      this.displayValue = formatDate(clampedDate, this.format);\r\n      this.errorMessage = null;\r\n    } else {\r\n      this.selectedDate = null;\r\n      this.displayValue = date ? formatDate(date, this.format) : '';\r\n      this.errorMessage = date ? getRangeErrorMessage(date, this.minDate, this.maxDate) : null;\r\n    }\r\n\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  registerOnChange(fn: (value: string) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  set value(value: string) {\r\n    const date = parseInputDate(value);\r\n\r\n    if (date && isDateInRange(date, this.minDate, this.maxDate)) {\r\n      this.selectedDate = date;\r\n      this.displayValue = formatDate(date, this.format);\r\n      this.errorMessage = null;\r\n      this.updateValue(value);\r\n    } else if (this.isSilentValidation && date) {\r\n      const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n      this.selectedDate = clampedDate;\r\n      this.displayValue = formatDate(clampedDate, this.format);\r\n      this.errorMessage = null;\r\n      const clampedValue = toOutputFormat(clampedDate);\r\n      this.updateValue(clampedValue);\r\n    } else {\r\n      this.selectedDate = null;\r\n      this.displayValue = date ? formatDate(date, this.format) : '';\r\n      this.errorMessage = date ? getRangeErrorMessage(date, this.minDate, this.maxDate) : null;\r\n    }\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  onInput(event: Event) {\r\n    const inputElement = event.target as HTMLInputElement;\r\n    const inputValue = inputElement.value;\r\n    this.processInput(inputValue);\r\n  }\r\n\r\n  private processInput(inputValue: string) {\r\n    this.displayValue = inputValue;\r\n    this.errorMessage = null;\r\n\r\n    if (inputValue.length === this.format.length) {\r\n      const separator = this.format.match(/[^DMY]/)?.[0] || '.';\r\n      const regex = new RegExp(`^(\\\\d{2})${separator}(\\\\d{2})${separator}(\\\\d{4})$`);\r\n      const match = inputValue.match(regex);\r\n\r\n      if (!match) return;\r\n\r\n      let day, month, year;\r\n      if (this.format.startsWith('DD')) {\r\n        [day, month, year] = [match[1], match[2], match[3]].map(Number);\r\n      } else if (this.format.startsWith('MM')) {\r\n        [month, day, year] = [match[1], match[2], match[3]].map(Number);\r\n      } else {\r\n        [year, month, day] = [match[1], match[2], match[3]].map(Number);\r\n      }\r\n      month -= 1;\r\n\r\n      let date = new Date(year, month, day);\r\n\r\n      if (isValidDate(date) && isDateInRange(date, this.minDate, this.maxDate)) {\r\n        this.selectedDate = date;\r\n        this.updateValue(toOutputFormat(date));\r\n      } else {\r\n        const { year: adjYear, month: adjMonth, day: adjDay } = adjustInvalidDate(year, month, day);\r\n        date = new Date(adjYear, adjMonth, adjDay);\r\n\r\n        if (isDateInRange(date, this.minDate, this.maxDate)) {\r\n          this.selectedDate = date;\r\n          this.displayValue = formatDate(date, this.format);\r\n          this.updateValue(toOutputFormat(date));\r\n        } else if (this.isSilentValidation) {\r\n          const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n          this.selectedDate = clampedDate;\r\n          this.displayValue = formatDate(clampedDate, this.format);\r\n          this.updateValue(toOutputFormat(clampedDate));\r\n        } else {\r\n          this.selectedDate = null;\r\n          this.errorMessage = getRangeErrorMessage(date, this.minDate, this.maxDate);\r\n        }\r\n      }\r\n    }\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  onBlur() {\r\n    this.onTouched();\r\n\r\n    if (this.displayValue.length > 0 && this.displayValue.length < this.format.length) {\r\n      this.displayValue = '';\r\n      this.selectedDate = null;\r\n      this.updateValue('');\r\n      this.errorMessage = null;\r\n    }\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  openCalendar() {\r\n    if (this.disabled || this._overlayRef) return;\r\n\r\n    const positionStrategy = this._overlay\r\n      .position()\r\n      .flexibleConnectedTo(this.dateInput)\r\n      .withPositions(PositionStrategyEnum[this.popupPosition]);\r\n\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy,\r\n      hasBackdrop: false,\r\n      scrollStrategy: this.scrollStrategy === 'reposition' ? this._overlay.scrollStrategies.reposition() : this._overlay.scrollStrategies.close(),\r\n    });\r\n\r\n    const portal = new ComponentPortal(DateCalendarComponent);\r\n    const componentRef = this._overlayRef.attach(portal);\r\n\r\n    componentRef.instance.selectedDate = this.selectedDate;\r\n    componentRef.instance.minDate = this.minDate;\r\n    componentRef.instance.maxDate = this.maxDate;\r\n    componentRef.instance.dateSelected.subscribe((date: Date) => this.onDateSelected(date));\r\n    componentRef.instance.close.subscribe(() => this.closeCalendar());\r\n\r\n    this._clickSubscription = fromEvent(document, 'click')\r\n      .pipe(\r\n        filter((event: Event) => {\r\n          const clickTarget = event.target as HTMLElement;\r\n          return (\r\n            !!this._overlayRef &&\r\n            !this._overlayRef.overlayElement.contains(clickTarget) &&\r\n            !this._elementRef.nativeElement.contains(clickTarget)\r\n          );\r\n        })\r\n      )\r\n      .subscribe(() => this.closeCalendar());\r\n  }\r\n\r\n  onDateSelected(date: Date) {\r\n    const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n    this.selectedDate = clampedDate;\r\n    this.displayValue = formatDate(clampedDate, this.format);\r\n    this.errorMessage = null;\r\n    this.updateValue(toOutputFormat(clampedDate));\r\n\r\n    if (this.closeAfterSelect) {\r\n      this.closeCalendar();\r\n    }\r\n\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  closeCalendar() {\r\n    if (this._overlayRef) {\r\n      this._overlayRef.dispose();\r\n      this._overlayRef = null;\r\n    }\r\n    this.errorMessage = null;\r\n  }\r\n\r\n  public clickToIconCalendar(): void {\r\n    this.openCalendar();\r\n  }\r\n\r\n  public clickToIconClear(): void {\r\n    this.displayValue = '';\r\n    this.selectedDate = null;\r\n    this.errorMessage = null;\r\n\r\n    this.updateValue('');\r\n    this.closeCalendar();\r\n\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  public updateValue(insideValue: InputDateValueTypes) {\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({ value: insideValue, id: this.uuid });\r\n    this.onChange(insideValue);\r\n    this.onTouched();\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-date\"\r\n  [class.mrx-input-error]=\"invalid\"\r\n  [class.mrx-input-readonly]=\"readonly\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div class=\"mrx-input-date__wrapper\">\r\n    <input\r\n      #dateInput\r\n      type=\"text\"\r\n      autocomplete=\"nope\"\r\n      class=\"mrx-input-date__input mrx-input-date__date\"\r\n      [ngModel]=\"displayValue\"\r\n      [disabled]=\"disabled\"\r\n      [readOnly]=\"!isManualInput\"\r\n      [mask]=\"mask\"\r\n      [leadZeroDateTime]=\"true\"\r\n      [dropSpecialCharacters]=\"false\"\r\n      [placeholder]=\"placeholder\"\r\n      (click)=\"openCalendar()\"\r\n      (input)=\"onInput($event)\"\r\n      (blur)=\"onBlur()\"\r\n    />\r\n\r\n    @if (!disabled) {\r\n      <div class=\"mrx-input-date__icons\">\r\n        @if (isViewCleanIcon) {\r\n          <span\r\n            class=\"mrx-icon icon-close\"\r\n            (click)=\"clickToIconClear()\"\r\n            [class.icon-font-16]=\"size === 'small'\"\r\n            [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n          ></span>\r\n        }\r\n\r\n        <span\r\n          class=\"mrx-icon icon-calendar\"\r\n          (click)=\"clickToIconCalendar()\"\r\n          [class.icon-font-16]=\"size === 'small'\"\r\n          [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n        ></span>\r\n      </div>\r\n    }\r\n  </div>\r\n\r\n  @if (invalid) {\r\n    <mrx-error-message [invalidMessage]=\"invalidMessage\"></mrx-error-message>\r\n  } @else {\r\n    @if (errorMessage) {\r\n      <mrx-error-message [invalidMessage]=\"errorMessage\"></mrx-error-message>\r\n    }\r\n  }\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
@@ -83,9 +83,6 @@ export class TableComponent {
83
83
  get getClasses() {
84
84
  return `${TableTypeEnum[this.type]} ${this.customClasses}`;
85
85
  }
86
- trackByFn(index, item) {
87
- return item[this.trackById];
88
- }
89
86
  changeSort() {
90
87
  const newEventData = { page: this.currentPage, pageSize: this.pageSize };
91
88
  if (!this.colArray.length) {
@@ -138,6 +135,11 @@ export class TableComponent {
138
135
  dir: this.sort?.dir
139
136
  }
140
137
  };
138
+ this.colArray.forEach(item => {
139
+ if (this.sort && newEventData.sort && newEventData.sort.col === item.name) {
140
+ this.selectedSort = item.sortLabel || item.name;
141
+ }
142
+ });
141
143
  this.dataStateChanged.emit(newEventData);
142
144
  }
143
145
  onDataStatePaginatorChanged(pagination) {
@@ -189,7 +191,7 @@ export class TableComponent {
189
191
  this.isOpenSort = isOpen;
190
192
  }
191
193
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
192
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TableComponent, selector: "mrx-table", inputs: { type: "type", data: "data", pageSize: "pageSize", currentPage: "currentPage", total: "total", link: "link", isLoading: "isLoading", sort: "sort", trackById: "trackById", sortable: "sortable", striped: "striped", customClasses: "customClasses", emptyResultMsg: "emptyResultMsg", hovered: "hovered", popupPosition: "popupPosition", autoHeight: "autoHeight", headerSettings: "headerSettings", contentSettings: "contentSettings", paginatorSettings: "paginatorSettings", loaderSettings: "loaderSettings", setPageable: ["pageable", "setPageable"] }, outputs: { dataStateChanged: "dataStateChanged", downloadData: "downloadData", changeTypeTable: "changeTypeTable", change: "change" }, queries: [{ propertyName: "templateCard", first: true, predicate: ["templateCard"], descendants: true }, { propertyName: "emptyResultMsgTemplate", first: true, predicate: ["emptyResultMsgTemplate"], descendants: true }, { propertyName: "contentChildren", predicate: ColumnComponent }], ngImport: i0, template: "<div class=\"mrx-table\" [class]=\"getClasses\" [class.mb-3]=\"pageable\">\r\n @if (headerSettings) {\r\n @switch (headerSettings.type) {\r\n @case ('second') {\r\n <div class=\"mrx-table-card-header mb-3 pt-2 pb-2\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-sm-6 mb-1 mb-sm-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-sm-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"downloadTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table-card-header py-12px mb-3\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-md-6 mb-1 mb-md-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"counterTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-md-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n\r\n @if (headerSettings.toggle) {\r\n <div class=\"ml-4\">\r\n <ng-container [ngTemplateOutlet]=\"toggleTemplate\"></ng-container>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n }\r\n }\r\n\r\n @switch (type) {\r\n @case ('cards') {\r\n <div class=\"mrx-table__wrapper\">\r\n @for (item of data; let index = $index; let first = $first; let last = $last; track item[trackById] || index) {\r\n <ng-container [ngTemplateOutlet]=\"templateCard\" [ngTemplateOutletContext]=\"{item, index, first, last}\"></ng-container>\r\n }\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message--substrate\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table__wrapper\" [class.--substrate]=\"contentSettings.substrate\">\r\n <table\r\n [class.table-striped]=\"striped\"\r\n [class.table-solid]=\"!striped\"\r\n [class.mt-2]=\"contentSettings.substrate\"\r\n [class.mb-3]=\"contentSettings.substrate && data.length\"\r\n >\r\n <thead [class.table-head-gray]=\"!headerSettings || headerSettings.background\">\r\n <tr>\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <th [class]=\"col.customClasses\">\r\n @if (!col.templateHead) {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <span>{{ col.label }}</span>\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <div><span>{{ col.label }}</span></div>\r\n }\r\n } @else {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n }\r\n }\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n\r\n <tbody>\r\n @for (dataItem of data; let index = $index; let first = $first; let last = $last; track dataItem[trackById] || index) {\r\n <tr [class.-hovered]=\"hovered\">\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <td #tableTD class=\"p-0\" [class]=\"col.customClasses\">\r\n @if (link && col['isLink']) {\r\n <a class=\"link-wrapper td-content-wrapper\" [href]=\"getLinkForStroke(link, dataItem)\"></a>\r\n }\r\n\r\n @if (!col.templateCell) {\r\n <div class=\"td-content-wrapper p-2 h-100\">{{ dataItem[col.name] }}</div>\r\n } @else {\r\n <div class=\"td-content-wrapper h-100\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateCell\"\r\n [ngTemplateOutletContext]=\"{col, row: dataItem, index, first, last}\"\r\n ></ng-container>\r\n </div>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n }\r\n</div>\r\n\r\n@if (total) {\r\n <div class=\"mrx-table__paginator pt-2 pb-2\" [class.mrx-table__paginator--substrate]=\"paginatorSettings.substrate\">\r\n @if (pageable) {\r\n <mrx-paginator\r\n [total]=\"total\"\r\n [pageSize]=\"pageSize\"\r\n [position]=\"pageable.position\"\r\n [pageSizes]=\"pageable.pageSizes\"\r\n [currentPage]=\"currentPage\"\r\n [withPageSize]=\"pageable.withPageSize\"\r\n (dataStateChanged)=\"onDataStatePaginatorChanged($event)\">\r\n </mrx-paginator>\r\n }\r\n </div>\r\n}\r\n\r\n<ng-template #counterTemplate>\r\n @if (headerSettings && headerSettings.count) {\r\n <span class=\"mrx-table-counter\">\r\n {{ total }} {{ headerSettings && headerSettings.countText ? headerSettings.countText : '\u043D\u043E\u0432\u043E\u0441\u0442\u0435\u0439' }}\r\n </span>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #sortTemplate>\r\n @if (headerSettings && headerSettings.sort) {\r\n <div class=\"d-flex mrx-table-sort\">\r\n <div class=\"mrx-table-sort-scale\">\r\n <div class=\"mrx-table-sort-scale__title mr-2\" (click)=\"changeSort()\">\r\n <span>\u0421\u043E\u0440\u0442\u0438\u0440\u043E\u0432\u0430\u0442\u044C \u043F\u043E:</span>\r\n\r\n <div class=\"mrx-table-sort-scale__icon\">\r\n @if (sort && sort.dir === 'desc') {\r\n <span class=\"mrx-icon icon-sorting-down icon-font-16\"></span>\r\n }\r\n @if (sort && sort.dir === 'asc') {\r\n <span class=\"mrx-icon icon-sorting-up icon-font-16\"></span>\r\n }\r\n </div>\r\n </div>\r\n\r\n <div class=\"mrx-table-sort-scale__drop-trigger\" [mrxPopupTrigger]=\"sortDropdown\" [popupPosition]=\"popupPosition\">\r\n <span>{{ selectedSort }}</span>\r\n <span\r\n class=\"mrx-icon icon-font-16\"\r\n [class.icon-chevron-up]=\"isOpenSort\"\r\n [class.icon-chevron-down]=\"!isOpenSort\"\r\n ></span>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #sortDropdown [minWidth]=\"'250px'\" [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n @for (item of colArray; track item) {\r\n <mrx-popup-item [id]=\"item.sortLabel\" (clicked)=\"updateSortSelect(item)\">{{ item.sortLabel || item.name }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #downloadTemplate>\r\n @if (headerSettings && headerSettings.download) {\r\n <div class=\"mrx-table-download\" (click)=\"clickToDownload($event)\">\r\n <span class=\"desktop\">\u0421\u043A\u0430\u0447\u0430\u0442\u044C \u0434\u0430\u043D\u043D\u044B\u0435</span>\r\n <span class=\"mrx-icon icon-download icon-font-24\"></span>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #toggleTemplate>\r\n <div class=\"mrx-table-toggle\">\r\n <div class=\"mrx-table-toggle--item mr-1\" (click)=\"onChangeTypeTable('cards')\" [class.active]=\"type === 'cards'\">\r\n <span class=\"mrx-icon icon-cards-view icon-font-24\"></span>\r\n </div>\r\n <div class=\"mrx-table-toggle--item\" (click)=\"onChangeTypeTable('default')\" [class.active]=\"type === 'default'\">\r\n <span class=\"mrx-icon icon-table-view icon-font-24\"></span>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #emptyResultMsgTemplateDefault>\r\n {{ emptyResultMsg }}\r\n</ng-template>\r\n", styles: [".mrx-table.mrx-table{display:block;width:100%}.mrx-table.mrx-table .th-wrapper{display:flex;cursor:pointer;word-break:inherit;justify-content:space-between;align-items:flex-end}.mrx-table.mrx-table .th-wrapper span{word-break:inherit}.mrx-table.mrx-table .mrx-table__sort-icon.asc path:last-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table__sort-icon.desc path:first-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table__wrapper.mrx-table__wrapper{overflow-x:auto;overflow-y:hidden;position:relative}.mrx-table__wrapper.mrx-table__wrapper .mrx-table__wrapper--substrate{padding-top:8px}.mrx-table.mrx-table.type-default table{width:100%;text-align:left;background-color:transparent;border-spacing:0}.mrx-table.mrx-table.type-default table thead.table-head-gray{background:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table.type-default table thead .sort-asc .custom-table__sort path:nth-child(2){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table thead .sort-desc .custom-table__sort path:nth-child(1){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td{max-width:340px;vertical-align:top;position:relative;padding:0}.mrx-table.mrx-table.type-default table td .link-wrapper{display:block;color:initial;height:100%;position:absolute;inset:0;text-decoration:none}.mrx-table.mrx-table.type-default table td .link-wrapper:active{color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table.type-default table td .left-border{border-left:4px solid var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td .light-border{border-left:4px solid transparent}.mrx-table.mrx-table.type-default table td .warning-back{background-color:#ffece7}.mrx-table.mrx-table.type-default table td .disabled-back{background-color:#fafafa}.mrx-table.mrx-table.type-default table td .link-colored,.mrx-table.mrx-table.type-default table td .link-colored:active{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table th{padding:8px;vertical-align:bottom;word-break:inherit;font-weight:700}.mrx-table.mrx-table.type-default table th svg{margin-left:8px;cursor:pointer}.mrx-table.mrx-table .mrx-table-card-header{position:relative}.mrx-table.mrx-table .mrx-table-card-header.--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table__wrapper.--substrate{background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table-toggle{display:flex}.mrx-table.mrx-table .mrx-table-toggle--item{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-table.mrx-table .mrx-table-toggle--item .mrx-icon{color:#e5e5e5}.mrx-table.mrx-table .mrx-table-toggle--item.active .mrx-icon{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-card,.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-table{justify-content:flex-start}.mrx-table.mrx-table .mrx-table-sort-scale{display:flex;align-items:center;flex-wrap:wrap;cursor:pointer;gap:4px;font-family:var(--body-md-font-family, \"PT Sans\");font-weight:var(--body-md-font-weight, 400);font-size:var(--body-md-font-size, 14px);line-height:var(--body-md-line-height, 20px);color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table .mrx-table-sort-scale__title{display:flex;align-items:center;gap:8px}.mrx-table.mrx-table .mrx-table-sort-scale__icon{display:flex;align-items:center;justify-content:center}.mrx-table.mrx-table .mrx-table-sort-scale__drop-trigger{display:flex;align-items:center;gap:4px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select{max-width:215px;margin-bottom:0}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-select-container.ng-select-container{min-height:auto!important;border:none;cursor:pointer;align-items:center;height:100%!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-value-container.ng-value-container{padding-left:0!important;margin-right:8px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-arrow-wrapper.ng-arrow-wrapper{min-height:auto;width:auto!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-dropdown-panel.ng-dropdown-panel{width:100vw;max-width:215px;left:auto;right:0}.mrx-table__paginator.mrx-table__paginator.mrx-table__paginator--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .table-striped tbody tr:nth-child(2n){background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n){transition:.2s}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n).-hovered:hover{background-color:var(--brand-bg-tertiary-hover, #edf5ff)}.mrx-table.mrx-table .table-solid{border-collapse:collapse}.mrx-table.mrx-table .table-solid thead tr{border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr:not(:last-child){border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr.-hovered:hover{box-shadow:0 1px 4px #3a3a3a4d}.mrx-table.mrx-table .mrx-table__wrapper .mrx-table__overlay{position:absolute;inset:0;background:#ffffffb3;display:flex;align-items:flex-start;justify-content:center;padding-top:12px;border-radius:4px}.mrx-table .mrx-table__result-message{display:flex;justify-content:center;width:100%;padding:var(--spacing-4);font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message *{font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message--substrate{display:flex;justify-content:center;width:100%;font-weight:400;font-size:16px;line-height:24px;color:var(--neutral-text-primary, #262626);padding:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px;position:relative}.mrx-table.mrx-table .mrx-table-download{display:flex;align-items:center;justify-content:flex-end;cursor:pointer}.mrx-table.mrx-table .mrx-table-download span{margin-right:8px;color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-download svg path{stroke:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-counter{display:flex;align-items:center;font-family:var(--body-lg-font-family);font-size:var(--body-lg-font-size);font-weight:var(--body-lg-font-weight);line-height:var(--body-lg-line-height)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.PaginatorComponent, selector: "mrx-paginator", inputs: ["pageSizes", "currentPage", "pageSize", "total", "customClasses", "isEmptyPaginator", "isPaginatorText", "paginatorText", "dropdownPosition", "popupPosition", "position", "withPageSize"], outputs: ["dataStateChanged"] }, { kind: "component", type: i3.LoaderComponent, selector: "mrx-loader", inputs: ["size", "color", "customClasses"] }, { kind: "component", type: i4.PopupComponent, selector: "mrx-popup", inputs: ["closeAfterClick", "minWidth"], outputs: ["toggle", "_toggleInner", "_updateInner"] }, { kind: "component", type: i5.PopupItemComponent, selector: "mrx-popup-item", inputs: ["custom", "id", "disabled"], outputs: ["clicked"] }, { kind: "directive", type: i6.PopupTriggerDirective, selector: "[mrxPopupTrigger]", inputs: ["mrxPopupTrigger", "popupPosition", "isFullWidthDropdown", "minWidthDropdown", "maxWidthDropdown", "scrollContainerRef", "scrollStrategy"] }], animations: [
194
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TableComponent, selector: "mrx-table", inputs: { type: "type", data: "data", pageSize: "pageSize", currentPage: "currentPage", total: "total", link: "link", isLoading: "isLoading", sort: "sort", trackById: "trackById", sortable: "sortable", striped: "striped", customClasses: "customClasses", emptyResultMsg: "emptyResultMsg", hovered: "hovered", popupPosition: "popupPosition", autoHeight: "autoHeight", headerSettings: "headerSettings", contentSettings: "contentSettings", paginatorSettings: "paginatorSettings", loaderSettings: "loaderSettings", setPageable: ["pageable", "setPageable"] }, outputs: { dataStateChanged: "dataStateChanged", downloadData: "downloadData", changeTypeTable: "changeTypeTable", change: "change" }, queries: [{ propertyName: "templateCard", first: true, predicate: ["templateCard"], descendants: true }, { propertyName: "emptyResultMsgTemplate", first: true, predicate: ["emptyResultMsgTemplate"], descendants: true }, { propertyName: "contentChildren", predicate: ColumnComponent }], ngImport: i0, template: "<div class=\"mrx-table\" [class]=\"getClasses\" [class.mb-3]=\"pageable\">\r\n @if (headerSettings) {\r\n @switch (headerSettings.type) {\r\n @case ('second') {\r\n <div class=\"mrx-table-card-header mb-3 pt-2 pb-2\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-sm-6 mb-1 mb-sm-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-sm-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"downloadTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table-card-header py-12px mb-3\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-md-6 mb-1 mb-md-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"counterTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-md-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n\r\n @if (headerSettings.toggle) {\r\n <div class=\"ml-4\">\r\n <ng-container [ngTemplateOutlet]=\"toggleTemplate\"></ng-container>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n }\r\n }\r\n\r\n @switch (type) {\r\n @case ('cards') {\r\n <div class=\"mrx-table__wrapper\">\r\n @for (item of data; let index = $index; let first = $first; let last = $last; track item[trackById] || index) {\r\n <ng-container [ngTemplateOutlet]=\"templateCard\" [ngTemplateOutletContext]=\"{item, index, first, last}\"></ng-container>\r\n }\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message--substrate\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table__wrapper\" [class.--substrate]=\"contentSettings.substrate\">\r\n <table\r\n [class.table-striped]=\"striped\"\r\n [class.table-solid]=\"!striped\"\r\n [class.mt-2]=\"contentSettings.substrate\"\r\n [class.mb-3]=\"contentSettings.substrate && data.length\"\r\n >\r\n <thead [class.table-head-gray]=\"!headerSettings || headerSettings.background\">\r\n <tr>\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <th [class]=\"col.customClasses\">\r\n @if (!col.templateHead) {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <span>{{ col.label }}</span>\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <div><span>{{ col.label }}</span></div>\r\n }\r\n } @else {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n }\r\n }\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n\r\n <tbody>\r\n @for (dataItem of data; let index = $index; let first = $first; let last = $last; track dataItem[trackById] || index) {\r\n <tr [class.-hovered]=\"hovered\">\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <td #tableTD class=\"p-0\" [class]=\"col.customClasses\">\r\n @if (link && col['isLink']) {\r\n <a class=\"link-wrapper td-content-wrapper\" [href]=\"getLinkForStroke(link, dataItem)\"></a>\r\n }\r\n\r\n @if (!col.templateCell) {\r\n <div class=\"td-content-wrapper p-2 h-100\">{{ dataItem[col.name] }}</div>\r\n } @else {\r\n <div class=\"td-content-wrapper h-100\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateCell\"\r\n [ngTemplateOutletContext]=\"{col, row: dataItem, index, first, last}\"\r\n ></ng-container>\r\n </div>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n }\r\n</div>\r\n\r\n@if (total) {\r\n <div class=\"mrx-table__paginator pt-2 pb-2\" [class.mrx-table__paginator--substrate]=\"paginatorSettings.substrate\">\r\n @if (pageable) {\r\n <mrx-paginator\r\n [total]=\"total\"\r\n [pageSize]=\"pageSize\"\r\n [position]=\"pageable.position\"\r\n [pageSizes]=\"pageable.pageSizes\"\r\n [currentPage]=\"currentPage\"\r\n [withPageSize]=\"pageable.withPageSize\"\r\n (dataStateChanged)=\"onDataStatePaginatorChanged($event)\">\r\n </mrx-paginator>\r\n }\r\n </div>\r\n}\r\n\r\n<ng-template #counterTemplate>\r\n @if (headerSettings && headerSettings.count) {\r\n <span class=\"mrx-table-counter\">\r\n {{ total }} {{ headerSettings && headerSettings.countText ? headerSettings.countText : '\u043D\u043E\u0432\u043E\u0441\u0442\u0435\u0439' }}\r\n </span>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #sortTemplate>\r\n @if (headerSettings && headerSettings.sort) {\r\n <div class=\"d-flex mrx-table-sort\">\r\n <div class=\"mrx-table-sort-scale\">\r\n <div class=\"mrx-table-sort-scale__title mr-2\" (click)=\"changeSort()\">\r\n <span>\u0421\u043E\u0440\u0442\u0438\u0440\u043E\u0432\u0430\u0442\u044C \u043F\u043E:</span>\r\n\r\n <div class=\"mrx-table-sort-scale__icon\">\r\n @if (sort && sort.dir === 'desc') {\r\n <span class=\"mrx-icon icon-sorting-down icon-font-16\"></span>\r\n }\r\n @if (sort && sort.dir === 'asc') {\r\n <span class=\"mrx-icon icon-sorting-up icon-font-16\"></span>\r\n }\r\n </div>\r\n </div>\r\n\r\n <div class=\"mrx-table-sort-scale__drop-trigger\" [mrxPopupTrigger]=\"sortDropdown\" [popupPosition]=\"popupPosition\">\r\n <span>{{ selectedSort }}</span>\r\n <span\r\n class=\"mrx-icon icon-font-16\"\r\n [class.icon-chevron-up]=\"isOpenSort\"\r\n [class.icon-chevron-down]=\"!isOpenSort\"\r\n ></span>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #sortDropdown [minWidth]=\"'250px'\" [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n @for (item of colArray; track item) {\r\n <mrx-popup-item\r\n [id]=\"item.sortLabel\"\r\n (clicked)=\"updateSortSelect(item)\"\r\n >\r\n {{ item.sortLabel || item.name }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #downloadTemplate>\r\n @if (headerSettings && headerSettings.download) {\r\n <div class=\"mrx-table-download\" (click)=\"clickToDownload($event)\">\r\n <span class=\"desktop\">\u0421\u043A\u0430\u0447\u0430\u0442\u044C \u0434\u0430\u043D\u043D\u044B\u0435</span>\r\n <span class=\"mrx-icon icon-download icon-font-24\"></span>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #toggleTemplate>\r\n <div class=\"mrx-table-toggle\">\r\n <div class=\"mrx-table-toggle--item mr-1\" (click)=\"onChangeTypeTable('cards')\" [class.active]=\"type === 'cards'\">\r\n <span class=\"mrx-icon icon-cards-view icon-font-24\"></span>\r\n </div>\r\n <div class=\"mrx-table-toggle--item\" (click)=\"onChangeTypeTable('default')\" [class.active]=\"type === 'default'\">\r\n <span class=\"mrx-icon icon-table-view icon-font-24\"></span>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #emptyResultMsgTemplateDefault>\r\n {{ emptyResultMsg }}\r\n</ng-template>\r\n", styles: [".mrx-table.mrx-table{display:block;width:100%}.mrx-table.mrx-table .th-wrapper{display:flex;cursor:pointer;word-break:inherit;justify-content:space-between;align-items:flex-end}.mrx-table.mrx-table .th-wrapper span{word-break:inherit}.mrx-table.mrx-table .mrx-table__sort-icon.asc path:last-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table__sort-icon.desc path:first-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table__wrapper.mrx-table__wrapper{overflow-x:auto;overflow-y:hidden;position:relative}.mrx-table__wrapper.mrx-table__wrapper .mrx-table__wrapper--substrate{padding-top:8px}.mrx-table.mrx-table.type-default table{width:100%;text-align:left;background-color:transparent;border-spacing:0}.mrx-table.mrx-table.type-default table thead.table-head-gray{background:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table.type-default table thead .sort-asc .custom-table__sort path:nth-child(2){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table thead .sort-desc .custom-table__sort path:nth-child(1){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td{max-width:340px;vertical-align:top;position:relative;padding:0}.mrx-table.mrx-table.type-default table td .link-wrapper{display:block;color:initial;height:100%;position:absolute;inset:0;text-decoration:none}.mrx-table.mrx-table.type-default table td .link-wrapper:active{color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table.type-default table td .left-border{border-left:4px solid var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td .light-border{border-left:4px solid transparent}.mrx-table.mrx-table.type-default table td .warning-back{background-color:#ffece7}.mrx-table.mrx-table.type-default table td .disabled-back{background-color:#fafafa}.mrx-table.mrx-table.type-default table td .link-colored,.mrx-table.mrx-table.type-default table td .link-colored:active{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table th{padding:8px;vertical-align:bottom;word-break:inherit;font-weight:700}.mrx-table.mrx-table.type-default table th svg{margin-left:8px;cursor:pointer}.mrx-table.mrx-table .mrx-table-card-header{position:relative}.mrx-table.mrx-table .mrx-table-card-header.--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table__wrapper.--substrate{background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table-toggle{display:flex}.mrx-table.mrx-table .mrx-table-toggle--item{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-table.mrx-table .mrx-table-toggle--item .mrx-icon{color:#e5e5e5}.mrx-table.mrx-table .mrx-table-toggle--item.active .mrx-icon{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-card,.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-table{justify-content:flex-start}.mrx-table.mrx-table .mrx-table-sort-scale{display:flex;align-items:center;flex-wrap:wrap;cursor:pointer;gap:4px;font-family:var(--body-md-font-family, \"PT Sans\");font-weight:var(--body-md-font-weight, 400);font-size:var(--body-md-font-size, 14px);line-height:var(--body-md-line-height, 20px);color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table .mrx-table-sort-scale__title{display:flex;align-items:center;gap:8px}.mrx-table.mrx-table .mrx-table-sort-scale__icon{display:flex;align-items:center;justify-content:center}.mrx-table.mrx-table .mrx-table-sort-scale__drop-trigger{display:flex;align-items:center;gap:4px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select{max-width:215px;margin-bottom:0}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-select-container.ng-select-container{min-height:auto!important;border:none;cursor:pointer;align-items:center;height:100%!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-value-container.ng-value-container{padding-left:0!important;margin-right:8px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-arrow-wrapper.ng-arrow-wrapper{min-height:auto;width:auto!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-dropdown-panel.ng-dropdown-panel{width:100vw;max-width:215px;left:auto;right:0}.mrx-table__paginator.mrx-table__paginator.mrx-table__paginator--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .table-striped tbody tr:nth-child(2n){background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n){transition:.2s}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n).-hovered:hover{background-color:var(--brand-bg-tertiary-hover, #edf5ff)}.mrx-table.mrx-table .table-solid{border-collapse:collapse}.mrx-table.mrx-table .table-solid thead tr{border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr:not(:last-child){border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr.-hovered:hover{box-shadow:0 1px 4px #3a3a3a4d}.mrx-table.mrx-table .mrx-table__wrapper .mrx-table__overlay{position:absolute;inset:0;background:#ffffffb3;display:flex;align-items:flex-start;justify-content:center;padding-top:12px;border-radius:4px}.mrx-table .mrx-table__result-message{display:flex;justify-content:center;width:100%;padding:var(--spacing-4);font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message *{font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message--substrate{display:flex;justify-content:center;width:100%;font-weight:400;font-size:16px;line-height:24px;color:var(--neutral-text-primary, #262626);padding:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px;position:relative}.mrx-table.mrx-table .mrx-table-download{display:flex;align-items:center;justify-content:flex-end;cursor:pointer}.mrx-table.mrx-table .mrx-table-download span{margin-right:8px;color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-download svg path{stroke:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-counter{display:flex;align-items:center;font-family:var(--body-lg-font-family);font-size:var(--body-lg-font-size);font-weight:var(--body-lg-font-weight);line-height:var(--body-lg-line-height)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.PaginatorComponent, selector: "mrx-paginator", inputs: ["pageSizes", "currentPage", "pageSize", "total", "customClasses", "isEmptyPaginator", "isPaginatorText", "paginatorText", "dropdownPosition", "popupPosition", "position", "withPageSize"], outputs: ["dataStateChanged"] }, { kind: "component", type: i3.LoaderComponent, selector: "mrx-loader", inputs: ["size", "color", "customClasses"] }, { kind: "component", type: i4.PopupComponent, selector: "mrx-popup", inputs: ["closeAfterClick", "minWidth"], outputs: ["toggle", "_toggleInner", "_updateInner"] }, { kind: "component", type: i5.PopupItemComponent, selector: "mrx-popup-item", inputs: ["custom", "id", "disabled"], outputs: ["clicked"] }, { kind: "directive", type: i6.PopupTriggerDirective, selector: "[mrxPopupTrigger]", inputs: ["mrxPopupTrigger", "popupPosition", "isFullWidthDropdown", "minWidthDropdown", "maxWidthDropdown", "scrollContainerRef", "scrollStrategy"] }], animations: [
193
195
  trigger('visibleLoading', [
194
196
  state('in', style({ opacity: 1, visibility: 'visible' })),
195
197
  state('out', style({ opacity: 0, visibility: 'hidden' })),
@@ -219,7 +221,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
219
221
  animate('300ms ease-in-out', style({ opacity: 1 }))
220
222
  ])])
221
223
  ])
222
- ], template: "<div class=\"mrx-table\" [class]=\"getClasses\" [class.mb-3]=\"pageable\">\r\n @if (headerSettings) {\r\n @switch (headerSettings.type) {\r\n @case ('second') {\r\n <div class=\"mrx-table-card-header mb-3 pt-2 pb-2\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-sm-6 mb-1 mb-sm-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-sm-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"downloadTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table-card-header py-12px mb-3\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-md-6 mb-1 mb-md-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"counterTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-md-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n\r\n @if (headerSettings.toggle) {\r\n <div class=\"ml-4\">\r\n <ng-container [ngTemplateOutlet]=\"toggleTemplate\"></ng-container>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n }\r\n }\r\n\r\n @switch (type) {\r\n @case ('cards') {\r\n <div class=\"mrx-table__wrapper\">\r\n @for (item of data; let index = $index; let first = $first; let last = $last; track item[trackById] || index) {\r\n <ng-container [ngTemplateOutlet]=\"templateCard\" [ngTemplateOutletContext]=\"{item, index, first, last}\"></ng-container>\r\n }\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message--substrate\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table__wrapper\" [class.--substrate]=\"contentSettings.substrate\">\r\n <table\r\n [class.table-striped]=\"striped\"\r\n [class.table-solid]=\"!striped\"\r\n [class.mt-2]=\"contentSettings.substrate\"\r\n [class.mb-3]=\"contentSettings.substrate && data.length\"\r\n >\r\n <thead [class.table-head-gray]=\"!headerSettings || headerSettings.background\">\r\n <tr>\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <th [class]=\"col.customClasses\">\r\n @if (!col.templateHead) {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <span>{{ col.label }}</span>\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <div><span>{{ col.label }}</span></div>\r\n }\r\n } @else {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n }\r\n }\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n\r\n <tbody>\r\n @for (dataItem of data; let index = $index; let first = $first; let last = $last; track dataItem[trackById] || index) {\r\n <tr [class.-hovered]=\"hovered\">\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <td #tableTD class=\"p-0\" [class]=\"col.customClasses\">\r\n @if (link && col['isLink']) {\r\n <a class=\"link-wrapper td-content-wrapper\" [href]=\"getLinkForStroke(link, dataItem)\"></a>\r\n }\r\n\r\n @if (!col.templateCell) {\r\n <div class=\"td-content-wrapper p-2 h-100\">{{ dataItem[col.name] }}</div>\r\n } @else {\r\n <div class=\"td-content-wrapper h-100\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateCell\"\r\n [ngTemplateOutletContext]=\"{col, row: dataItem, index, first, last}\"\r\n ></ng-container>\r\n </div>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n }\r\n</div>\r\n\r\n@if (total) {\r\n <div class=\"mrx-table__paginator pt-2 pb-2\" [class.mrx-table__paginator--substrate]=\"paginatorSettings.substrate\">\r\n @if (pageable) {\r\n <mrx-paginator\r\n [total]=\"total\"\r\n [pageSize]=\"pageSize\"\r\n [position]=\"pageable.position\"\r\n [pageSizes]=\"pageable.pageSizes\"\r\n [currentPage]=\"currentPage\"\r\n [withPageSize]=\"pageable.withPageSize\"\r\n (dataStateChanged)=\"onDataStatePaginatorChanged($event)\">\r\n </mrx-paginator>\r\n }\r\n </div>\r\n}\r\n\r\n<ng-template #counterTemplate>\r\n @if (headerSettings && headerSettings.count) {\r\n <span class=\"mrx-table-counter\">\r\n {{ total }} {{ headerSettings && headerSettings.countText ? headerSettings.countText : '\u043D\u043E\u0432\u043E\u0441\u0442\u0435\u0439' }}\r\n </span>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #sortTemplate>\r\n @if (headerSettings && headerSettings.sort) {\r\n <div class=\"d-flex mrx-table-sort\">\r\n <div class=\"mrx-table-sort-scale\">\r\n <div class=\"mrx-table-sort-scale__title mr-2\" (click)=\"changeSort()\">\r\n <span>\u0421\u043E\u0440\u0442\u0438\u0440\u043E\u0432\u0430\u0442\u044C \u043F\u043E:</span>\r\n\r\n <div class=\"mrx-table-sort-scale__icon\">\r\n @if (sort && sort.dir === 'desc') {\r\n <span class=\"mrx-icon icon-sorting-down icon-font-16\"></span>\r\n }\r\n @if (sort && sort.dir === 'asc') {\r\n <span class=\"mrx-icon icon-sorting-up icon-font-16\"></span>\r\n }\r\n </div>\r\n </div>\r\n\r\n <div class=\"mrx-table-sort-scale__drop-trigger\" [mrxPopupTrigger]=\"sortDropdown\" [popupPosition]=\"popupPosition\">\r\n <span>{{ selectedSort }}</span>\r\n <span\r\n class=\"mrx-icon icon-font-16\"\r\n [class.icon-chevron-up]=\"isOpenSort\"\r\n [class.icon-chevron-down]=\"!isOpenSort\"\r\n ></span>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #sortDropdown [minWidth]=\"'250px'\" [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n @for (item of colArray; track item) {\r\n <mrx-popup-item [id]=\"item.sortLabel\" (clicked)=\"updateSortSelect(item)\">{{ item.sortLabel || item.name }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #downloadTemplate>\r\n @if (headerSettings && headerSettings.download) {\r\n <div class=\"mrx-table-download\" (click)=\"clickToDownload($event)\">\r\n <span class=\"desktop\">\u0421\u043A\u0430\u0447\u0430\u0442\u044C \u0434\u0430\u043D\u043D\u044B\u0435</span>\r\n <span class=\"mrx-icon icon-download icon-font-24\"></span>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #toggleTemplate>\r\n <div class=\"mrx-table-toggle\">\r\n <div class=\"mrx-table-toggle--item mr-1\" (click)=\"onChangeTypeTable('cards')\" [class.active]=\"type === 'cards'\">\r\n <span class=\"mrx-icon icon-cards-view icon-font-24\"></span>\r\n </div>\r\n <div class=\"mrx-table-toggle--item\" (click)=\"onChangeTypeTable('default')\" [class.active]=\"type === 'default'\">\r\n <span class=\"mrx-icon icon-table-view icon-font-24\"></span>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #emptyResultMsgTemplateDefault>\r\n {{ emptyResultMsg }}\r\n</ng-template>\r\n", styles: [".mrx-table.mrx-table{display:block;width:100%}.mrx-table.mrx-table .th-wrapper{display:flex;cursor:pointer;word-break:inherit;justify-content:space-between;align-items:flex-end}.mrx-table.mrx-table .th-wrapper span{word-break:inherit}.mrx-table.mrx-table .mrx-table__sort-icon.asc path:last-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table__sort-icon.desc path:first-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table__wrapper.mrx-table__wrapper{overflow-x:auto;overflow-y:hidden;position:relative}.mrx-table__wrapper.mrx-table__wrapper .mrx-table__wrapper--substrate{padding-top:8px}.mrx-table.mrx-table.type-default table{width:100%;text-align:left;background-color:transparent;border-spacing:0}.mrx-table.mrx-table.type-default table thead.table-head-gray{background:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table.type-default table thead .sort-asc .custom-table__sort path:nth-child(2){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table thead .sort-desc .custom-table__sort path:nth-child(1){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td{max-width:340px;vertical-align:top;position:relative;padding:0}.mrx-table.mrx-table.type-default table td .link-wrapper{display:block;color:initial;height:100%;position:absolute;inset:0;text-decoration:none}.mrx-table.mrx-table.type-default table td .link-wrapper:active{color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table.type-default table td .left-border{border-left:4px solid var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td .light-border{border-left:4px solid transparent}.mrx-table.mrx-table.type-default table td .warning-back{background-color:#ffece7}.mrx-table.mrx-table.type-default table td .disabled-back{background-color:#fafafa}.mrx-table.mrx-table.type-default table td .link-colored,.mrx-table.mrx-table.type-default table td .link-colored:active{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table th{padding:8px;vertical-align:bottom;word-break:inherit;font-weight:700}.mrx-table.mrx-table.type-default table th svg{margin-left:8px;cursor:pointer}.mrx-table.mrx-table .mrx-table-card-header{position:relative}.mrx-table.mrx-table .mrx-table-card-header.--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table__wrapper.--substrate{background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table-toggle{display:flex}.mrx-table.mrx-table .mrx-table-toggle--item{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-table.mrx-table .mrx-table-toggle--item .mrx-icon{color:#e5e5e5}.mrx-table.mrx-table .mrx-table-toggle--item.active .mrx-icon{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-card,.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-table{justify-content:flex-start}.mrx-table.mrx-table .mrx-table-sort-scale{display:flex;align-items:center;flex-wrap:wrap;cursor:pointer;gap:4px;font-family:var(--body-md-font-family, \"PT Sans\");font-weight:var(--body-md-font-weight, 400);font-size:var(--body-md-font-size, 14px);line-height:var(--body-md-line-height, 20px);color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table .mrx-table-sort-scale__title{display:flex;align-items:center;gap:8px}.mrx-table.mrx-table .mrx-table-sort-scale__icon{display:flex;align-items:center;justify-content:center}.mrx-table.mrx-table .mrx-table-sort-scale__drop-trigger{display:flex;align-items:center;gap:4px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select{max-width:215px;margin-bottom:0}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-select-container.ng-select-container{min-height:auto!important;border:none;cursor:pointer;align-items:center;height:100%!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-value-container.ng-value-container{padding-left:0!important;margin-right:8px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-arrow-wrapper.ng-arrow-wrapper{min-height:auto;width:auto!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-dropdown-panel.ng-dropdown-panel{width:100vw;max-width:215px;left:auto;right:0}.mrx-table__paginator.mrx-table__paginator.mrx-table__paginator--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .table-striped tbody tr:nth-child(2n){background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n){transition:.2s}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n).-hovered:hover{background-color:var(--brand-bg-tertiary-hover, #edf5ff)}.mrx-table.mrx-table .table-solid{border-collapse:collapse}.mrx-table.mrx-table .table-solid thead tr{border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr:not(:last-child){border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr.-hovered:hover{box-shadow:0 1px 4px #3a3a3a4d}.mrx-table.mrx-table .mrx-table__wrapper .mrx-table__overlay{position:absolute;inset:0;background:#ffffffb3;display:flex;align-items:flex-start;justify-content:center;padding-top:12px;border-radius:4px}.mrx-table .mrx-table__result-message{display:flex;justify-content:center;width:100%;padding:var(--spacing-4);font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message *{font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message--substrate{display:flex;justify-content:center;width:100%;font-weight:400;font-size:16px;line-height:24px;color:var(--neutral-text-primary, #262626);padding:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px;position:relative}.mrx-table.mrx-table .mrx-table-download{display:flex;align-items:center;justify-content:flex-end;cursor:pointer}.mrx-table.mrx-table .mrx-table-download span{margin-right:8px;color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-download svg path{stroke:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-counter{display:flex;align-items:center;font-family:var(--body-lg-font-family);font-size:var(--body-lg-font-size);font-weight:var(--body-lg-font-weight);line-height:var(--body-lg-line-height)}\n"] }]
224
+ ], template: "<div class=\"mrx-table\" [class]=\"getClasses\" [class.mb-3]=\"pageable\">\r\n @if (headerSettings) {\r\n @switch (headerSettings.type) {\r\n @case ('second') {\r\n <div class=\"mrx-table-card-header mb-3 pt-2 pb-2\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-sm-6 mb-1 mb-sm-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-sm-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"downloadTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table-card-header py-12px mb-3\" [class.--substrate]=\"headerSettings.substrate\">\r\n <div class=\"row\">\r\n <div\r\n class=\"mrx-table-card-header--left col col-12 col-md-6 mb-1 mb-md-0 d-flex justify-content-start align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"counterTemplate\"></ng-container>\r\n </div>\r\n\r\n <div class=\"mrx-table-card-header--right col col-12 col-md-6 d-flex justify-content-end align-content-center\">\r\n <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n\r\n @if (headerSettings.toggle) {\r\n <div class=\"ml-4\">\r\n <ng-container [ngTemplateOutlet]=\"toggleTemplate\"></ng-container>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n }\r\n }\r\n\r\n @switch (type) {\r\n @case ('cards') {\r\n <div class=\"mrx-table__wrapper\">\r\n @for (item of data; let index = $index; let first = $first; let last = $last; track item[trackById] || index) {\r\n <ng-container [ngTemplateOutlet]=\"templateCard\" [ngTemplateOutletContext]=\"{item, index, first, last}\"></ng-container>\r\n }\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message--substrate\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n @default {\r\n <div class=\"mrx-table__wrapper\" [class.--substrate]=\"contentSettings.substrate\">\r\n <table\r\n [class.table-striped]=\"striped\"\r\n [class.table-solid]=\"!striped\"\r\n [class.mt-2]=\"contentSettings.substrate\"\r\n [class.mb-3]=\"contentSettings.substrate && data.length\"\r\n >\r\n <thead [class.table-head-gray]=\"!headerSettings || headerSettings.background\">\r\n <tr>\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <th [class]=\"col.customClasses\">\r\n @if (!col.templateHead) {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <span>{{ col.label }}</span>\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <div><span>{{ col.label }}</span></div>\r\n }\r\n } @else {\r\n @if (col.sortable) {\r\n <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n\r\n <svg\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n [class]=\"columnSortedDir(col.name)\"\r\n class=\"mrx-table__sort-icon\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n </svg>\r\n </div>\r\n } @else {\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateHead\"\r\n [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n ></ng-container>\r\n }\r\n }\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n\r\n <tbody>\r\n @for (dataItem of data; let index = $index; let first = $first; let last = $last; track dataItem[trackById] || index) {\r\n <tr [class.-hovered]=\"hovered\">\r\n @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n <td #tableTD class=\"p-0\" [class]=\"col.customClasses\">\r\n @if (link && col['isLink']) {\r\n <a class=\"link-wrapper td-content-wrapper\" [href]=\"getLinkForStroke(link, dataItem)\"></a>\r\n }\r\n\r\n @if (!col.templateCell) {\r\n <div class=\"td-content-wrapper p-2 h-100\">{{ dataItem[col.name] }}</div>\r\n } @else {\r\n <div class=\"td-content-wrapper h-100\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"col.templateCell\"\r\n [ngTemplateOutletContext]=\"{col, row: dataItem, index, first, last}\"\r\n ></ng-container>\r\n </div>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n\r\n @if (!data.length) {\r\n <div class=\"mrx-table__result-message\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n ></ng-container>\r\n </div>\r\n }\r\n\r\n <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n </div>\r\n </div>\r\n }\r\n }\r\n</div>\r\n\r\n@if (total) {\r\n <div class=\"mrx-table__paginator pt-2 pb-2\" [class.mrx-table__paginator--substrate]=\"paginatorSettings.substrate\">\r\n @if (pageable) {\r\n <mrx-paginator\r\n [total]=\"total\"\r\n [pageSize]=\"pageSize\"\r\n [position]=\"pageable.position\"\r\n [pageSizes]=\"pageable.pageSizes\"\r\n [currentPage]=\"currentPage\"\r\n [withPageSize]=\"pageable.withPageSize\"\r\n (dataStateChanged)=\"onDataStatePaginatorChanged($event)\">\r\n </mrx-paginator>\r\n }\r\n </div>\r\n}\r\n\r\n<ng-template #counterTemplate>\r\n @if (headerSettings && headerSettings.count) {\r\n <span class=\"mrx-table-counter\">\r\n {{ total }} {{ headerSettings && headerSettings.countText ? headerSettings.countText : '\u043D\u043E\u0432\u043E\u0441\u0442\u0435\u0439' }}\r\n </span>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #sortTemplate>\r\n @if (headerSettings && headerSettings.sort) {\r\n <div class=\"d-flex mrx-table-sort\">\r\n <div class=\"mrx-table-sort-scale\">\r\n <div class=\"mrx-table-sort-scale__title mr-2\" (click)=\"changeSort()\">\r\n <span>\u0421\u043E\u0440\u0442\u0438\u0440\u043E\u0432\u0430\u0442\u044C \u043F\u043E:</span>\r\n\r\n <div class=\"mrx-table-sort-scale__icon\">\r\n @if (sort && sort.dir === 'desc') {\r\n <span class=\"mrx-icon icon-sorting-down icon-font-16\"></span>\r\n }\r\n @if (sort && sort.dir === 'asc') {\r\n <span class=\"mrx-icon icon-sorting-up icon-font-16\"></span>\r\n }\r\n </div>\r\n </div>\r\n\r\n <div class=\"mrx-table-sort-scale__drop-trigger\" [mrxPopupTrigger]=\"sortDropdown\" [popupPosition]=\"popupPosition\">\r\n <span>{{ selectedSort }}</span>\r\n <span\r\n class=\"mrx-icon icon-font-16\"\r\n [class.icon-chevron-up]=\"isOpenSort\"\r\n [class.icon-chevron-down]=\"!isOpenSort\"\r\n ></span>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #sortDropdown [minWidth]=\"'250px'\" [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n @for (item of colArray; track item) {\r\n <mrx-popup-item\r\n [id]=\"item.sortLabel\"\r\n (clicked)=\"updateSortSelect(item)\"\r\n >\r\n {{ item.sortLabel || item.name }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #downloadTemplate>\r\n @if (headerSettings && headerSettings.download) {\r\n <div class=\"mrx-table-download\" (click)=\"clickToDownload($event)\">\r\n <span class=\"desktop\">\u0421\u043A\u0430\u0447\u0430\u0442\u044C \u0434\u0430\u043D\u043D\u044B\u0435</span>\r\n <span class=\"mrx-icon icon-download icon-font-24\"></span>\r\n </div>\r\n }\r\n</ng-template>\r\n\r\n<ng-template #toggleTemplate>\r\n <div class=\"mrx-table-toggle\">\r\n <div class=\"mrx-table-toggle--item mr-1\" (click)=\"onChangeTypeTable('cards')\" [class.active]=\"type === 'cards'\">\r\n <span class=\"mrx-icon icon-cards-view icon-font-24\"></span>\r\n </div>\r\n <div class=\"mrx-table-toggle--item\" (click)=\"onChangeTypeTable('default')\" [class.active]=\"type === 'default'\">\r\n <span class=\"mrx-icon icon-table-view icon-font-24\"></span>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #emptyResultMsgTemplateDefault>\r\n {{ emptyResultMsg }}\r\n</ng-template>\r\n", styles: [".mrx-table.mrx-table{display:block;width:100%}.mrx-table.mrx-table .th-wrapper{display:flex;cursor:pointer;word-break:inherit;justify-content:space-between;align-items:flex-end}.mrx-table.mrx-table .th-wrapper span{word-break:inherit}.mrx-table.mrx-table .mrx-table__sort-icon.asc path:last-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table__sort-icon.desc path:first-child{fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table__wrapper.mrx-table__wrapper{overflow-x:auto;overflow-y:hidden;position:relative}.mrx-table__wrapper.mrx-table__wrapper .mrx-table__wrapper--substrate{padding-top:8px}.mrx-table.mrx-table.type-default table{width:100%;text-align:left;background-color:transparent;border-spacing:0}.mrx-table.mrx-table.type-default table thead.table-head-gray{background:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table.type-default table thead .sort-asc .custom-table__sort path:nth-child(2){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table thead .sort-desc .custom-table__sort path:nth-child(1){fill:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td{max-width:340px;vertical-align:top;position:relative;padding:0}.mrx-table.mrx-table.type-default table td .link-wrapper{display:block;color:initial;height:100%;position:absolute;inset:0;text-decoration:none}.mrx-table.mrx-table.type-default table td .link-wrapper:active{color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table.type-default table td .left-border{border-left:4px solid var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table td .light-border{border-left:4px solid transparent}.mrx-table.mrx-table.type-default table td .warning-back{background-color:#ffece7}.mrx-table.mrx-table.type-default table td .disabled-back{background-color:#fafafa}.mrx-table.mrx-table.type-default table td .link-colored,.mrx-table.mrx-table.type-default table td .link-colored:active{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table.type-default table th{padding:8px;vertical-align:bottom;word-break:inherit;font-weight:700}.mrx-table.mrx-table.type-default table th svg{margin-left:8px;cursor:pointer}.mrx-table.mrx-table .mrx-table-card-header{position:relative}.mrx-table.mrx-table .mrx-table-card-header.--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table__wrapper.--substrate{background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .mrx-table-toggle{display:flex}.mrx-table.mrx-table .mrx-table-toggle--item{display:flex;align-items:center;justify-content:center;cursor:pointer}.mrx-table.mrx-table .mrx-table-toggle--item .mrx-icon{color:#e5e5e5}.mrx-table.mrx-table .mrx-table-toggle--item.active .mrx-icon{color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-card,.mrx-table.mrx-table .mrx-table-sort.mrx-table-sort--is-table{justify-content:flex-start}.mrx-table.mrx-table .mrx-table-sort-scale{display:flex;align-items:center;flex-wrap:wrap;cursor:pointer;gap:4px;font-family:var(--body-md-font-family, \"PT Sans\");font-weight:var(--body-md-font-weight, 400);font-size:var(--body-md-font-size, 14px);line-height:var(--body-md-line-height, 20px);color:var(--neutral-text-primary, #262626)}.mrx-table.mrx-table .mrx-table-sort-scale__title{display:flex;align-items:center;gap:8px}.mrx-table.mrx-table .mrx-table-sort-scale__icon{display:flex;align-items:center;justify-content:center}.mrx-table.mrx-table .mrx-table-sort-scale__drop-trigger{display:flex;align-items:center;gap:4px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select{max-width:215px;margin-bottom:0}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-select-container.ng-select-container{min-height:auto!important;border:none;cursor:pointer;align-items:center;height:100%!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-value-container.ng-value-container{padding-left:0!important;margin-right:8px}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-arrow-wrapper.ng-arrow-wrapper{min-height:auto;width:auto!important}:host::ng-deep .mrx-table.mrx-table .mrx-table-sort .ng-select .ng-dropdown-panel.ng-dropdown-panel{width:100vw;max-width:215px;left:auto;right:0}.mrx-table__paginator.mrx-table__paginator.mrx-table__paginator--substrate{padding-left:24px;padding-right:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px}.mrx-table.mrx-table .table-striped tbody tr:nth-child(2n){background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n){transition:.2s}.mrx-table.mrx-table .table-striped tbody tr:nth-child(n).-hovered:hover{background-color:var(--brand-bg-tertiary-hover, #edf5ff)}.mrx-table.mrx-table .table-solid{border-collapse:collapse}.mrx-table.mrx-table .table-solid thead tr{border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr:not(:last-child){border-bottom:1px solid #f2f2f2}.mrx-table.mrx-table .table-solid tbody tr.-hovered:hover{box-shadow:0 1px 4px #3a3a3a4d}.mrx-table.mrx-table .mrx-table__wrapper .mrx-table__overlay{position:absolute;inset:0;background:#ffffffb3;display:flex;align-items:flex-start;justify-content:center;padding-top:12px;border-radius:4px}.mrx-table .mrx-table__result-message{display:flex;justify-content:center;width:100%;padding:var(--spacing-4);font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message *{font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);font-size:var(--body-md-font-size);line-height:var(--body-md-line-height);color:var(--neutral-text-secondary)}.mrx-table .mrx-table__result-message--substrate{display:flex;justify-content:center;width:100%;font-weight:400;font-size:16px;line-height:24px;color:var(--neutral-text-primary, #262626);padding:24px;background:#fff;box-shadow:0 1px 4px #3b43571a;border-radius:4px;position:relative}.mrx-table.mrx-table .mrx-table-download{display:flex;align-items:center;justify-content:flex-end;cursor:pointer}.mrx-table.mrx-table .mrx-table-download span{margin-right:8px;color:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-download svg path{stroke:var(--brand-bg-primary-default, #2a6ab8)}.mrx-table.mrx-table .mrx-table-counter{display:flex;align-items:center;font-family:var(--body-lg-font-family);font-size:var(--body-lg-font-size);font-weight:var(--body-lg-font-weight);line-height:var(--body-lg-line-height)}\n"] }]
223
225
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { contentChildren: [{
224
226
  type: ContentChildren,
225
227
  args: [ColumnComponent]
@@ -281,4 +283,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
281
283
  }], change: [{
282
284
  type: Output
283
285
  }] } });
284
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/table/table.component.ts","../../../../../../projects/myrta-ui/src/lib/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChild,\r\n  ContentChildren,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  QueryList,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport { ContentSettings, HeaderSettings, PaginatorSettings, SortDescriptor, TableBodyItem, TableType, TableTypeEnum, LoaderSettings } from './table.enum';\r\nimport { ColumnComponent } from './components/column/column.component';\r\nimport { PagerSettings, DataStateChangeEvent } from './models';\r\nimport { DefaultPagerSettings } from './default/default-pager-settings';\r\nimport { PaginateOutputObject } from '../paginator/paginator.enum';\r\nimport { animate, group, state, style, transition, trigger } from '@angular/animations';\r\nimport { PositionType } from '../../enums/overlay';\r\n\r\n@Component({\r\n  selector: 'mrx-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.less'],\r\n  animations: [\r\n    trigger('visibleLoading', [\r\n      state('in', style({ opacity: 1, visibility: 'visible' })),\r\n      state('out', style({ opacity: 0, visibility: 'hidden' })),\r\n      transition('in => out', [group([\r\n        animate('300ms ease-in-out', style({ opacity: 0 })),\r\n        animate('300ms ease-in-out', style({ visibility: 'hidden' }))\r\n      ]\r\n      )]),\r\n      transition('out => in', [group([\r\n        animate('1ms ease-in-out', style({ visibility: 'visible' })),\r\n        animate('300ms ease-in-out', style({ opacity: 1 }))\r\n      ]\r\n      )])\r\n    ])\r\n  ]\r\n})\r\nexport class TableComponent implements AfterViewInit {\r\n  public colArray: ColumnComponent[] = [];\r\n  public pageable: PagerSettings | null = DefaultPagerSettings;\r\n  public selectedSort = ''\r\n  public init = false\r\n  public isOpenSort: boolean = false;\r\n\r\n  @ContentChildren(ColumnComponent) contentChildren!: QueryList<ColumnComponent>;\r\n  @ContentChild('templateCard') templateCard!: TemplateRef<any>;\r\n  @ContentChild('emptyResultMsgTemplate') emptyResultMsgTemplate!: TemplateRef<any>;\r\n\r\n  @Input() type: TableType = 'default';\r\n  @Input() data!: TableBodyItem[];\r\n  @Input() pageSize = 20;\r\n  @Input() currentPage = 1;\r\n  @Input() total = 0;\r\n  @Input() link = '';\r\n  @Input() isLoading = false;\r\n\r\n  @Input() sort: SortDescriptor | undefined;\r\n  @Input() trackById = 'id';\r\n  @Input() sortable = true;\r\n  @Input() striped = true;\r\n  @Input() customClasses = ''\r\n  @Input() emptyResultMsg = ''\r\n  @Input() hovered = true;\r\n  @Input() popupPosition: PositionType = 'bottom-end';\r\n\r\n  @Input() autoHeight = true // deprecated\r\n\r\n  @Input() headerSettings: HeaderSettings | undefined\r\n\r\n  @Input() contentSettings: ContentSettings = {\r\n    substrate: false\r\n  }\r\n\r\n  @Input() paginatorSettings: PaginatorSettings = {\r\n    substrate: false\r\n  }\r\n\r\n  @Input() loaderSettings: LoaderSettings = {\r\n    size: 'large',\r\n    color: 'brand'\r\n  }\r\n\r\n  // Проверить и вырезать\r\n  public selectedItem = 1\r\n\r\n  @Input('pageable')\r\n  public set setPageable(value: PagerSettings | boolean) {\r\n    if (value === true) {\r\n      this.pageable = DefaultPagerSettings;\r\n    } else if (value === false) {\r\n      this.pageable = null;\r\n    } else {\r\n      this.pageable = value;\r\n    }\r\n  }\r\n\r\n  @Output() dataStateChanged: EventEmitter<DataStateChangeEvent> =\r\n    new EventEmitter<DataStateChangeEvent>();\r\n  @Output() downloadData: EventEmitter<Event> = new EventEmitter<Event>()\r\n  @Output() changeTypeTable: EventEmitter<TableType> = new EventEmitter<TableType>()\r\n  @Output() change: EventEmitter<Event> = new EventEmitter<Event>()\r\n\r\n  constructor(private changeDetector: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.colArray = this.contentChildren.toArray();\r\n\r\n    this.colArray.forEach(item => {\r\n      if (this.sort && this.sort.col === item.name) {\r\n        this.selectedSort = item.sortLabel || item.name\r\n      }\r\n    })\r\n\r\n    this.colArray = this.colArray.filter(item => {\r\n      return item.name !== '' && item.sortLabel\r\n    })\r\n\r\n    this.changeDetector.detectChanges()\r\n    this.init = true\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${ TableTypeEnum[this.type] } ${ this.customClasses }`;\r\n  }\r\n\r\n  trackByFn(index: number, item: any): string {\r\n    return item[this.trackById];\r\n  }\r\n\r\n  public changeSort() {\r\n    const newEventData: DataStateChangeEvent = { page: this.currentPage, pageSize: this.pageSize };\r\n\r\n    if (!this.colArray.length) {\r\n      return\r\n    }\r\n\r\n    if (this.sort) {\r\n      newEventData.sort = {\r\n        dir: this.sort.dir === 'desc' ? 'asc' : 'desc',\r\n        col: this.sort.col\r\n      };\r\n    } else {\r\n      newEventData.sort = {\r\n        dir: 'asc',\r\n        col: this.colArray[0].name\r\n      };\r\n    }\r\n\r\n    this.dataStateChanged.emit(newEventData);\r\n  }\r\n\r\n  public columnSortedDir(column: string): string {\r\n    if (this.sort && this.sort.col == column && this.sort.dir) {\r\n      return this.sort.dir;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  public onSortColumn(column: string, sortable: boolean): void {\r\n    if (!sortable) {\r\n      return;\r\n    }\r\n\r\n    const newEventData: DataStateChangeEvent = { page: this.currentPage, pageSize: this.pageSize };\r\n\r\n    if (this.sort && this.sort.col == column) {\r\n      if (this.sort.dir && this.sort.dir === 'asc') {\r\n        newEventData.sort = { dir: 'desc', col: column };\r\n      }\r\n    } else {\r\n      newEventData.sort = { dir: 'asc', col: column };\r\n    }\r\n\r\n    this.dataStateChanged.emit(newEventData);\r\n  }\r\n\r\n  public clickToDownload(event: Event): void {\r\n    this.downloadData.emit(event)\r\n  }\r\n\r\n  public updateSortSelect(value: any): void {\r\n    const newEventData: DataStateChangeEvent = {\r\n      page: this.currentPage,\r\n      pageSize: this.pageSize,\r\n      sort: {\r\n        col: value.name,\r\n        dir: this.sort?.dir\r\n      }\r\n    };\r\n\r\n    this.dataStateChanged.emit(newEventData)\r\n  }\r\n\r\n  public onDataStatePaginatorChanged(pagination: PaginateOutputObject): void {\r\n    const newEventData: DataStateChangeEvent = {\r\n      page: pagination.currentPage,\r\n      pageSize: pagination.pageSize\r\n    };\r\n\r\n    if (this.sort && this.sort.col && this.sort.dir) {\r\n      newEventData.sort = { dir: this.sort.dir, col: this.sort.col };\r\n    }\r\n\r\n    this.dataStateChanged.emit(newEventData);\r\n  }\r\n\r\n  public getLinkForStroke(link: string, dataItem: TableBodyItem) {\r\n    // регулярки\r\n    const regExpParams = /(?<=\\[)[^\\s\\[\\]]+(?=])/gi;\r\n    // основной массив\r\n    const linkArray = link.split('?')\r\n    // массивы строк url и параметров\r\n    const arrayUrl = linkArray[0]?.split('/')\r\n    const searchParams = linkArray[1]?.split('&')\r\n    const searchParamsObj = searchParams?.map((str) => {\r\n      const strParamData = str.split('=')[1].match(regExpParams)\r\n      return {\r\n        name: str.split('=')[0],\r\n        data: strParamData ? strParamData[0] : str.split('=')[0],\r\n      }\r\n    })\r\n\r\n    // обработка тела url\r\n    const strUrl = arrayUrl.map((str) => {\r\n      if (str.match(regExpParams)) {\r\n        // @ts-ignore\r\n        return dataItem[str.match(regExpParams)[0]]\r\n      } else {\r\n        return str\r\n      }\r\n    }).join('/')\r\n    // обработка параметров\r\n    // если есть параметры - возвращаем их строкой с динамическими параметрами\r\n\r\n    const strParams = searchParamsObj ? searchParamsObj.map((param, index: number) => {\r\n      return `${ index > 0 ? '' : '?' }${ param.name }=${ dataItem[param.data] }`\r\n    }).join('&') : ''\r\n\r\n    return `${ strUrl }${ strParams }`\r\n  }\r\n\r\n  public onChangeTypeTable(type: TableType): void {\r\n    this.changeTypeTable.emit(type)\r\n  }\r\n\r\n  togglePopup(isOpen: boolean) {\r\n    this.isOpenSort = isOpen\r\n  }\r\n}\r\n","<div class=\"mrx-table\" [class]=\"getClasses\" [class.mb-3]=\"pageable\">\r\n  @if (headerSettings) {\r\n    @switch (headerSettings.type) {\r\n      @case ('second') {\r\n        <div class=\"mrx-table-card-header mb-3 pt-2 pb-2\" [class.--substrate]=\"headerSettings.substrate\">\r\n          <div class=\"row\">\r\n            <div\r\n              class=\"mrx-table-card-header--left col col-12 col-sm-6 mb-1 mb-sm-0 d-flex justify-content-start align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n            </div>\r\n\r\n            <div class=\"mrx-table-card-header--right col col-12 col-sm-6 d-flex justify-content-end align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"downloadTemplate\"></ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      }\r\n      @default {\r\n        <div class=\"mrx-table-card-header py-12px mb-3\" [class.--substrate]=\"headerSettings.substrate\">\r\n          <div class=\"row\">\r\n            <div\r\n              class=\"mrx-table-card-header--left col col-12 col-md-6 mb-1 mb-md-0 d-flex justify-content-start align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"counterTemplate\"></ng-container>\r\n            </div>\r\n\r\n            <div class=\"mrx-table-card-header--right col col-12 col-md-6 d-flex justify-content-end align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n\r\n              @if (headerSettings.toggle) {\r\n                <div class=\"ml-4\">\r\n                  <ng-container [ngTemplateOutlet]=\"toggleTemplate\"></ng-container>\r\n                </div>\r\n              }\r\n            </div>\r\n          </div>\r\n        </div>\r\n      }\r\n    }\r\n  }\r\n\r\n  @switch (type) {\r\n    @case ('cards') {\r\n      <div class=\"mrx-table__wrapper\">\r\n        @for (item of data; let index = $index; let first = $first; let last = $last; track item[trackById] || index) {\r\n          <ng-container [ngTemplateOutlet]=\"templateCard\" [ngTemplateOutletContext]=\"{item, index, first, last}\"></ng-container>\r\n        }\r\n\r\n        @if (!data.length) {\r\n          <div class=\"mrx-table__result-message--substrate\">\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n            ></ng-container>\r\n          </div>\r\n        }\r\n\r\n        <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n          <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n        </div>\r\n      </div>\r\n    }\r\n    @default {\r\n      <div class=\"mrx-table__wrapper\" [class.--substrate]=\"contentSettings.substrate\">\r\n        <table\r\n          [class.table-striped]=\"striped\"\r\n          [class.table-solid]=\"!striped\"\r\n          [class.mt-2]=\"contentSettings.substrate\"\r\n          [class.mb-3]=\"contentSettings.substrate && data.length\"\r\n        >\r\n          <thead [class.table-head-gray]=\"!headerSettings || headerSettings.background\">\r\n            <tr>\r\n              @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n                <th [class]=\"col.customClasses\">\r\n                  @if (!col.templateHead) {\r\n                    @if (col.sortable) {\r\n                      <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n                        <span>{{ col.label }}</span>\r\n                        <svg\r\n                          width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                          [class]=\"columnSortedDir(col.name)\"\r\n                          class=\"mrx-table__sort-icon\">\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n                        </svg>\r\n                      </div>\r\n                    } @else {\r\n                      <div><span>{{ col.label }}</span></div>\r\n                    }\r\n                  } @else {\r\n                    @if (col.sortable) {\r\n                      <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n                        <ng-container\r\n                          [ngTemplateOutlet]=\"col.templateHead\"\r\n                          [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n                        ></ng-container>\r\n\r\n                        <svg\r\n                          width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                          [class]=\"columnSortedDir(col.name)\"\r\n                          class=\"mrx-table__sort-icon\">\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n                        </svg>\r\n                      </div>\r\n                    } @else {\r\n                      <ng-container\r\n                        [ngTemplateOutlet]=\"col.templateHead\"\r\n                        [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n                      ></ng-container>\r\n                    }\r\n                  }\r\n                </th>\r\n              }\r\n            </tr>\r\n          </thead>\r\n\r\n          <tbody>\r\n            @for (dataItem of data; let index = $index; let first = $first; let last = $last; track dataItem[trackById] || index) {\r\n              <tr [class.-hovered]=\"hovered\">\r\n                @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n                  <td #tableTD class=\"p-0\" [class]=\"col.customClasses\">\r\n                    @if (link && col['isLink']) {\r\n                      <a class=\"link-wrapper td-content-wrapper\" [href]=\"getLinkForStroke(link, dataItem)\"></a>\r\n                    }\r\n\r\n                    @if (!col.templateCell) {\r\n                      <div class=\"td-content-wrapper p-2 h-100\">{{ dataItem[col.name] }}</div>\r\n                    } @else {\r\n                      <div class=\"td-content-wrapper h-100\">\r\n                        <ng-container\r\n                          [ngTemplateOutlet]=\"col.templateCell\"\r\n                          [ngTemplateOutletContext]=\"{col, row: dataItem, index, first, last}\"\r\n                        ></ng-container>\r\n                      </div>\r\n                    }\r\n                  </td>\r\n                }\r\n              </tr>\r\n            }\r\n          </tbody>\r\n        </table>\r\n\r\n        @if (!data.length) {\r\n          <div class=\"mrx-table__result-message\">\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n            ></ng-container>\r\n          </div>\r\n        }\r\n\r\n        <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n          <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n        </div>\r\n      </div>\r\n    }\r\n  }\r\n</div>\r\n\r\n@if (total) {\r\n  <div class=\"mrx-table__paginator pt-2 pb-2\" [class.mrx-table__paginator--substrate]=\"paginatorSettings.substrate\">\r\n    @if (pageable) {\r\n      <mrx-paginator\r\n        [total]=\"total\"\r\n        [pageSize]=\"pageSize\"\r\n        [position]=\"pageable.position\"\r\n        [pageSizes]=\"pageable.pageSizes\"\r\n        [currentPage]=\"currentPage\"\r\n        [withPageSize]=\"pageable.withPageSize\"\r\n        (dataStateChanged)=\"onDataStatePaginatorChanged($event)\">\r\n      </mrx-paginator>\r\n    }\r\n  </div>\r\n}\r\n\r\n<ng-template #counterTemplate>\r\n  @if (headerSettings && headerSettings.count) {\r\n    <span class=\"mrx-table-counter\">\r\n    {{ total }} {{ headerSettings && headerSettings.countText ? headerSettings.countText : 'новостей' }}\r\n  </span>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #sortTemplate>\r\n  @if (headerSettings && headerSettings.sort) {\r\n    <div class=\"d-flex mrx-table-sort\">\r\n      <div class=\"mrx-table-sort-scale\">\r\n        <div class=\"mrx-table-sort-scale__title mr-2\" (click)=\"changeSort()\">\r\n          <span>Сортировать по:</span>\r\n\r\n          <div class=\"mrx-table-sort-scale__icon\">\r\n            @if (sort && sort.dir === 'desc') {\r\n              <span class=\"mrx-icon icon-sorting-down icon-font-16\"></span>\r\n            }\r\n            @if (sort && sort.dir === 'asc') {\r\n              <span class=\"mrx-icon icon-sorting-up icon-font-16\"></span>\r\n            }\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"mrx-table-sort-scale__drop-trigger\" [mrxPopupTrigger]=\"sortDropdown\" [popupPosition]=\"popupPosition\">\r\n          <span>{{ selectedSort }}</span>\r\n          <span\r\n            class=\"mrx-icon icon-font-16\"\r\n            [class.icon-chevron-up]=\"isOpenSort\"\r\n            [class.icon-chevron-down]=\"!isOpenSort\"\r\n          ></span>\r\n        </div>\r\n      </div>\r\n\r\n      <mrx-popup #sortDropdown [minWidth]=\"'250px'\" [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n        @for (item of colArray; track item) {\r\n          <mrx-popup-item [id]=\"item.sortLabel\" (clicked)=\"updateSortSelect(item)\">{{ item.sortLabel || item.name }}\r\n          </mrx-popup-item>\r\n        }\r\n      </mrx-popup>\r\n    </div>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #downloadTemplate>\r\n  @if (headerSettings && headerSettings.download) {\r\n    <div class=\"mrx-table-download\" (click)=\"clickToDownload($event)\">\r\n      <span class=\"desktop\">Скачать данные</span>\r\n      <span class=\"mrx-icon icon-download icon-font-24\"></span>\r\n    </div>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #toggleTemplate>\r\n  <div class=\"mrx-table-toggle\">\r\n    <div class=\"mrx-table-toggle--item mr-1\" (click)=\"onChangeTypeTable('cards')\" [class.active]=\"type === 'cards'\">\r\n      <span class=\"mrx-icon icon-cards-view icon-font-24\"></span>\r\n    </div>\r\n    <div class=\"mrx-table-toggle--item\" (click)=\"onChangeTypeTable('default')\" [class.active]=\"type === 'default'\">\r\n      <span class=\"mrx-icon icon-table-view icon-font-24\"></span>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #emptyResultMsgTemplateDefault>\r\n  {{ emptyResultMsg }}\r\n</ng-template>\r\n"]}
286
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/table/table.component.ts","../../../../../../projects/myrta-ui/src/lib/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChild,\r\n  ContentChildren,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  QueryList,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport { ContentSettings, HeaderSettings, PaginatorSettings, SortDescriptor, TableBodyItem, TableType, TableTypeEnum, LoaderSettings } from './table.enum';\r\nimport { ColumnComponent } from './components/column/column.component';\r\nimport { PagerSettings, DataStateChangeEvent } from './models';\r\nimport { DefaultPagerSettings } from './default/default-pager-settings';\r\nimport { PaginateOutputObject } from '../paginator/paginator.enum';\r\nimport { animate, group, state, style, transition, trigger } from '@angular/animations';\r\nimport { PositionType } from '../../enums/overlay';\r\n\r\n@Component({\r\n  selector: 'mrx-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.less'],\r\n  animations: [\r\n    trigger('visibleLoading', [\r\n      state('in', style({ opacity: 1, visibility: 'visible' })),\r\n      state('out', style({ opacity: 0, visibility: 'hidden' })),\r\n      transition('in => out', [group([\r\n        animate('300ms ease-in-out', style({ opacity: 0 })),\r\n        animate('300ms ease-in-out', style({ visibility: 'hidden' }))\r\n      ]\r\n      )]),\r\n      transition('out => in', [group([\r\n        animate('1ms ease-in-out', style({ visibility: 'visible' })),\r\n        animate('300ms ease-in-out', style({ opacity: 1 }))\r\n      ]\r\n      )])\r\n    ])\r\n  ]\r\n})\r\nexport class TableComponent implements AfterViewInit {\r\n  public colArray: ColumnComponent[] = [];\r\n  public pageable: PagerSettings | null = DefaultPagerSettings;\r\n  public selectedSort = ''\r\n  public init = false\r\n  public isOpenSort: boolean = false;\r\n\r\n  @ContentChildren(ColumnComponent) contentChildren!: QueryList<ColumnComponent>;\r\n  @ContentChild('templateCard') templateCard!: TemplateRef<any>;\r\n  @ContentChild('emptyResultMsgTemplate') emptyResultMsgTemplate!: TemplateRef<any>;\r\n\r\n  @Input() type: TableType = 'default';\r\n  @Input() data!: TableBodyItem[];\r\n  @Input() pageSize = 20;\r\n  @Input() currentPage = 1;\r\n  @Input() total = 0;\r\n  @Input() link = '';\r\n  @Input() isLoading = false;\r\n\r\n  @Input() sort: SortDescriptor | undefined;\r\n  @Input() trackById = 'id';\r\n  @Input() sortable = true;\r\n  @Input() striped = true;\r\n  @Input() customClasses = ''\r\n  @Input() emptyResultMsg = ''\r\n  @Input() hovered = true;\r\n  @Input() popupPosition: PositionType = 'bottom-end';\r\n\r\n  @Input() autoHeight = true // deprecated\r\n\r\n  @Input() headerSettings: HeaderSettings | undefined\r\n\r\n  @Input() contentSettings: ContentSettings = {\r\n    substrate: false\r\n  }\r\n\r\n  @Input() paginatorSettings: PaginatorSettings = {\r\n    substrate: false\r\n  }\r\n\r\n  @Input() loaderSettings: LoaderSettings = {\r\n    size: 'large',\r\n    color: 'brand'\r\n  }\r\n\r\n  // Проверить и вырезать\r\n  public selectedItem = 1\r\n\r\n  @Input('pageable')\r\n  public set setPageable(value: PagerSettings | boolean) {\r\n    if (value === true) {\r\n      this.pageable = DefaultPagerSettings;\r\n    } else if (value === false) {\r\n      this.pageable = null;\r\n    } else {\r\n      this.pageable = value;\r\n    }\r\n  }\r\n\r\n  @Output() dataStateChanged: EventEmitter<DataStateChangeEvent> =\r\n    new EventEmitter<DataStateChangeEvent>();\r\n  @Output() downloadData: EventEmitter<Event> = new EventEmitter<Event>()\r\n  @Output() changeTypeTable: EventEmitter<TableType> = new EventEmitter<TableType>()\r\n  @Output() change: EventEmitter<Event> = new EventEmitter<Event>()\r\n\r\n  constructor(private changeDetector: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.colArray = this.contentChildren.toArray();\r\n\r\n    this.colArray.forEach(item => {\r\n      if (this.sort && this.sort.col === item.name) {\r\n        this.selectedSort = item.sortLabel || item.name\r\n      }\r\n    })\r\n\r\n    this.colArray = this.colArray.filter(item => {\r\n      return item.name !== '' && item.sortLabel\r\n    })\r\n\r\n    this.changeDetector.detectChanges()\r\n    this.init = true\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${ TableTypeEnum[this.type] } ${ this.customClasses }`;\r\n  }\r\n\r\n  public changeSort() {\r\n    const newEventData: DataStateChangeEvent = { page: this.currentPage, pageSize: this.pageSize };\r\n\r\n    if (!this.colArray.length) {\r\n      return\r\n    }\r\n\r\n    if (this.sort) {\r\n      newEventData.sort = {\r\n        dir: this.sort.dir === 'desc' ? 'asc' : 'desc',\r\n        col: this.sort.col\r\n      };\r\n    } else {\r\n      newEventData.sort = {\r\n        dir: 'asc',\r\n        col: this.colArray[0].name\r\n      };\r\n    }\r\n\r\n    this.dataStateChanged.emit(newEventData);\r\n  }\r\n\r\n  public columnSortedDir(column: string): string {\r\n    if (this.sort && this.sort.col == column && this.sort.dir) {\r\n      return this.sort.dir;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  public onSortColumn(column: string, sortable: boolean): void {\r\n    if (!sortable) {\r\n      return;\r\n    }\r\n\r\n    const newEventData: DataStateChangeEvent = { page: this.currentPage, pageSize: this.pageSize };\r\n\r\n    if (this.sort && this.sort.col == column) {\r\n      if (this.sort.dir && this.sort.dir === 'asc') {\r\n        newEventData.sort = { dir: 'desc', col: column };\r\n      }\r\n    } else {\r\n      newEventData.sort = { dir: 'asc', col: column };\r\n    }\r\n\r\n    this.dataStateChanged.emit(newEventData);\r\n  }\r\n\r\n  public clickToDownload(event: Event): void {\r\n    this.downloadData.emit(event)\r\n  }\r\n\r\n  public updateSortSelect(value: any): void {\r\n    const newEventData: DataStateChangeEvent = {\r\n      page: this.currentPage,\r\n      pageSize: this.pageSize,\r\n      sort: {\r\n        col: value.name,\r\n        dir: this.sort?.dir\r\n      }\r\n    };\r\n\r\n    this.colArray.forEach(item => {\r\n      if (this.sort && newEventData.sort && newEventData.sort.col === item.name) {\r\n        this.selectedSort = item.sortLabel || item.name\r\n      }\r\n    })\r\n\r\n    this.dataStateChanged.emit(newEventData)\r\n  }\r\n\r\n  public onDataStatePaginatorChanged(pagination: PaginateOutputObject): void {\r\n    const newEventData: DataStateChangeEvent = {\r\n      page: pagination.currentPage,\r\n      pageSize: pagination.pageSize\r\n    };\r\n\r\n    if (this.sort && this.sort.col && this.sort.dir) {\r\n      newEventData.sort = { dir: this.sort.dir, col: this.sort.col };\r\n    }\r\n\r\n    this.dataStateChanged.emit(newEventData);\r\n  }\r\n\r\n  public getLinkForStroke(link: string, dataItem: TableBodyItem) {\r\n    // регулярки\r\n    const regExpParams = /(?<=\\[)[^\\s\\[\\]]+(?=])/gi;\r\n    // основной массив\r\n    const linkArray = link.split('?')\r\n    // массивы строк url и параметров\r\n    const arrayUrl = linkArray[0]?.split('/')\r\n    const searchParams = linkArray[1]?.split('&')\r\n    const searchParamsObj = searchParams?.map((str) => {\r\n      const strParamData = str.split('=')[1].match(regExpParams)\r\n      return {\r\n        name: str.split('=')[0],\r\n        data: strParamData ? strParamData[0] : str.split('=')[0],\r\n      }\r\n    })\r\n\r\n    // обработка тела url\r\n    const strUrl = arrayUrl.map((str) => {\r\n      if (str.match(regExpParams)) {\r\n        // @ts-ignore\r\n        return dataItem[str.match(regExpParams)[0]]\r\n      } else {\r\n        return str\r\n      }\r\n    }).join('/')\r\n    // обработка параметров\r\n    // если есть параметры - возвращаем их строкой с динамическими параметрами\r\n\r\n    const strParams = searchParamsObj ? searchParamsObj.map((param, index: number) => {\r\n      return `${ index > 0 ? '' : '?' }${ param.name }=${ dataItem[param.data] }`\r\n    }).join('&') : ''\r\n\r\n    return `${ strUrl }${ strParams }`\r\n  }\r\n\r\n  public onChangeTypeTable(type: TableType): void {\r\n    this.changeTypeTable.emit(type)\r\n  }\r\n\r\n  togglePopup(isOpen: boolean) {\r\n    this.isOpenSort = isOpen\r\n  }\r\n}\r\n","<div class=\"mrx-table\" [class]=\"getClasses\" [class.mb-3]=\"pageable\">\r\n  @if (headerSettings) {\r\n    @switch (headerSettings.type) {\r\n      @case ('second') {\r\n        <div class=\"mrx-table-card-header mb-3 pt-2 pb-2\" [class.--substrate]=\"headerSettings.substrate\">\r\n          <div class=\"row\">\r\n            <div\r\n              class=\"mrx-table-card-header--left col col-12 col-sm-6 mb-1 mb-sm-0 d-flex justify-content-start align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n            </div>\r\n\r\n            <div class=\"mrx-table-card-header--right col col-12 col-sm-6 d-flex justify-content-end align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"downloadTemplate\"></ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      }\r\n      @default {\r\n        <div class=\"mrx-table-card-header py-12px mb-3\" [class.--substrate]=\"headerSettings.substrate\">\r\n          <div class=\"row\">\r\n            <div\r\n              class=\"mrx-table-card-header--left col col-12 col-md-6 mb-1 mb-md-0 d-flex justify-content-start align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"counterTemplate\"></ng-container>\r\n            </div>\r\n\r\n            <div class=\"mrx-table-card-header--right col col-12 col-md-6 d-flex justify-content-end align-content-center\">\r\n              <ng-container [ngTemplateOutlet]=\"sortTemplate\"></ng-container>\r\n\r\n              @if (headerSettings.toggle) {\r\n                <div class=\"ml-4\">\r\n                  <ng-container [ngTemplateOutlet]=\"toggleTemplate\"></ng-container>\r\n                </div>\r\n              }\r\n            </div>\r\n          </div>\r\n        </div>\r\n      }\r\n    }\r\n  }\r\n\r\n  @switch (type) {\r\n    @case ('cards') {\r\n      <div class=\"mrx-table__wrapper\">\r\n        @for (item of data; let index = $index; let first = $first; let last = $last; track item[trackById] || index) {\r\n          <ng-container [ngTemplateOutlet]=\"templateCard\" [ngTemplateOutletContext]=\"{item, index, first, last}\"></ng-container>\r\n        }\r\n\r\n        @if (!data.length) {\r\n          <div class=\"mrx-table__result-message--substrate\">\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n            ></ng-container>\r\n          </div>\r\n        }\r\n\r\n        <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n          <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n        </div>\r\n      </div>\r\n    }\r\n    @default {\r\n      <div class=\"mrx-table__wrapper\" [class.--substrate]=\"contentSettings.substrate\">\r\n        <table\r\n          [class.table-striped]=\"striped\"\r\n          [class.table-solid]=\"!striped\"\r\n          [class.mt-2]=\"contentSettings.substrate\"\r\n          [class.mb-3]=\"contentSettings.substrate && data.length\"\r\n        >\r\n          <thead [class.table-head-gray]=\"!headerSettings || headerSettings.background\">\r\n            <tr>\r\n              @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n                <th [class]=\"col.customClasses\">\r\n                  @if (!col.templateHead) {\r\n                    @if (col.sortable) {\r\n                      <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n                        <span>{{ col.label }}</span>\r\n                        <svg\r\n                          width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                          [class]=\"columnSortedDir(col.name)\"\r\n                          class=\"mrx-table__sort-icon\">\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n                        </svg>\r\n                      </div>\r\n                    } @else {\r\n                      <div><span>{{ col.label }}</span></div>\r\n                    }\r\n                  } @else {\r\n                    @if (col.sortable) {\r\n                      <div [class.th-wrapper]=\"sortable\" (click)=\"onSortColumn(col.name, col.sortable)\">\r\n                        <ng-container\r\n                          [ngTemplateOutlet]=\"col.templateHead\"\r\n                          [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n                        ></ng-container>\r\n\r\n                        <svg\r\n                          width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                          [class]=\"columnSortedDir(col.name)\"\r\n                          class=\"mrx-table__sort-icon\">\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M4 9L8 13L12 9\" fill=\"#DAD5CE\"/>\r\n                          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 7L8 3L4 7\" fill=\"#DAD5CE\"/>\r\n                        </svg>\r\n                      </div>\r\n                    } @else {\r\n                      <ng-container\r\n                        [ngTemplateOutlet]=\"col.templateHead\"\r\n                        [ngTemplateOutletContext]=\"{col, index, first, last}\"\r\n                      ></ng-container>\r\n                    }\r\n                  }\r\n                </th>\r\n              }\r\n            </tr>\r\n          </thead>\r\n\r\n          <tbody>\r\n            @for (dataItem of data; let index = $index; let first = $first; let last = $last; track dataItem[trackById] || index) {\r\n              <tr [class.-hovered]=\"hovered\">\r\n                @for (col of contentChildren; let index = $index; let first = $first; let last = $last; track index) {\r\n                  <td #tableTD class=\"p-0\" [class]=\"col.customClasses\">\r\n                    @if (link && col['isLink']) {\r\n                      <a class=\"link-wrapper td-content-wrapper\" [href]=\"getLinkForStroke(link, dataItem)\"></a>\r\n                    }\r\n\r\n                    @if (!col.templateCell) {\r\n                      <div class=\"td-content-wrapper p-2 h-100\">{{ dataItem[col.name] }}</div>\r\n                    } @else {\r\n                      <div class=\"td-content-wrapper h-100\">\r\n                        <ng-container\r\n                          [ngTemplateOutlet]=\"col.templateCell\"\r\n                          [ngTemplateOutletContext]=\"{col, row: dataItem, index, first, last}\"\r\n                        ></ng-container>\r\n                      </div>\r\n                    }\r\n                  </td>\r\n                }\r\n              </tr>\r\n            }\r\n          </tbody>\r\n        </table>\r\n\r\n        @if (!data.length) {\r\n          <div class=\"mrx-table__result-message\">\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"emptyResultMsg ? emptyResultMsgTemplateDefault : emptyResultMsgTemplate\"\r\n            ></ng-container>\r\n          </div>\r\n        }\r\n\r\n        <div class=\"mrx-table__overlay\" [@visibleLoading]=\"isLoading ? 'in' : 'out'\" [ngClass]=\"{'open': isLoading}\">\r\n          <mrx-loader [size]=\"loaderSettings.size\" [color]=\"loaderSettings.color\"></mrx-loader>\r\n        </div>\r\n      </div>\r\n    }\r\n  }\r\n</div>\r\n\r\n@if (total) {\r\n  <div class=\"mrx-table__paginator pt-2 pb-2\" [class.mrx-table__paginator--substrate]=\"paginatorSettings.substrate\">\r\n    @if (pageable) {\r\n      <mrx-paginator\r\n        [total]=\"total\"\r\n        [pageSize]=\"pageSize\"\r\n        [position]=\"pageable.position\"\r\n        [pageSizes]=\"pageable.pageSizes\"\r\n        [currentPage]=\"currentPage\"\r\n        [withPageSize]=\"pageable.withPageSize\"\r\n        (dataStateChanged)=\"onDataStatePaginatorChanged($event)\">\r\n      </mrx-paginator>\r\n    }\r\n  </div>\r\n}\r\n\r\n<ng-template #counterTemplate>\r\n  @if (headerSettings && headerSettings.count) {\r\n    <span class=\"mrx-table-counter\">\r\n    {{ total }} {{ headerSettings && headerSettings.countText ? headerSettings.countText : 'новостей' }}\r\n  </span>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #sortTemplate>\r\n  @if (headerSettings && headerSettings.sort) {\r\n    <div class=\"d-flex mrx-table-sort\">\r\n      <div class=\"mrx-table-sort-scale\">\r\n        <div class=\"mrx-table-sort-scale__title mr-2\" (click)=\"changeSort()\">\r\n          <span>Сортировать по:</span>\r\n\r\n          <div class=\"mrx-table-sort-scale__icon\">\r\n            @if (sort && sort.dir === 'desc') {\r\n              <span class=\"mrx-icon icon-sorting-down icon-font-16\"></span>\r\n            }\r\n            @if (sort && sort.dir === 'asc') {\r\n              <span class=\"mrx-icon icon-sorting-up icon-font-16\"></span>\r\n            }\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"mrx-table-sort-scale__drop-trigger\" [mrxPopupTrigger]=\"sortDropdown\" [popupPosition]=\"popupPosition\">\r\n          <span>{{ selectedSort }}</span>\r\n          <span\r\n            class=\"mrx-icon icon-font-16\"\r\n            [class.icon-chevron-up]=\"isOpenSort\"\r\n            [class.icon-chevron-down]=\"!isOpenSort\"\r\n          ></span>\r\n        </div>\r\n      </div>\r\n\r\n      <mrx-popup #sortDropdown [minWidth]=\"'250px'\" [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n        @for (item of colArray; track item) {\r\n          <mrx-popup-item\r\n            [id]=\"item.sortLabel\"\r\n            (clicked)=\"updateSortSelect(item)\"\r\n          >\r\n            {{ item.sortLabel || item.name }}\r\n          </mrx-popup-item>\r\n        }\r\n      </mrx-popup>\r\n    </div>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #downloadTemplate>\r\n  @if (headerSettings && headerSettings.download) {\r\n    <div class=\"mrx-table-download\" (click)=\"clickToDownload($event)\">\r\n      <span class=\"desktop\">Скачать данные</span>\r\n      <span class=\"mrx-icon icon-download icon-font-24\"></span>\r\n    </div>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #toggleTemplate>\r\n  <div class=\"mrx-table-toggle\">\r\n    <div class=\"mrx-table-toggle--item mr-1\" (click)=\"onChangeTypeTable('cards')\" [class.active]=\"type === 'cards'\">\r\n      <span class=\"mrx-icon icon-cards-view icon-font-24\"></span>\r\n    </div>\r\n    <div class=\"mrx-table-toggle--item\" (click)=\"onChangeTypeTable('default')\" [class.active]=\"type === 'default'\">\r\n      <span class=\"mrx-icon icon-table-view icon-font-24\"></span>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #emptyResultMsgTemplateDefault>\r\n  {{ emptyResultMsg }}\r\n</ng-template>\r\n"]}