myrta-ui 17.1.14 → 17.1.16

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.
@@ -56,6 +56,7 @@ export class SelectComponent {
56
56
  sortIcon = null;
57
57
  sortPlaceholder = '';
58
58
  isFullWidthDropdown = true;
59
+ withoutSelected = false;
59
60
  addOption;
60
61
  customSearchFn;
61
62
  disabled = false;
@@ -90,7 +91,12 @@ export class SelectComponent {
90
91
  return `${SelectSizeEnum[this.size]} ${this.readonlyClass} ${this.checkValidClasses}`;
91
92
  }
92
93
  get getSelectedLabels() {
93
- return this.innerItems.filter(i => i.__selected);
94
+ if (this.withoutSelected) {
95
+ return [];
96
+ }
97
+ else {
98
+ return this.innerItems.filter(i => i.__selected);
99
+ }
94
100
  }
95
101
  get filteredItems() {
96
102
  if (this.customSearchFn) {
@@ -172,10 +178,8 @@ export class SelectComponent {
172
178
  return label;
173
179
  }
174
180
  writeValue(selected = []) {
175
- if (selected !== null) {
176
- this.originSelected = selected;
177
- this._updateSelected(this.originItems, this.originSelected);
178
- }
181
+ this.originSelected = selected;
182
+ this._updateSelected(this.originItems, this.originSelected);
179
183
  }
180
184
  changeTextValueEmpty() {
181
185
  this.form.initModelChanged(this.model);
@@ -215,7 +219,7 @@ export class SelectComponent {
215
219
  this.onTouched = fn;
216
220
  }
217
221
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
218
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: SelectComponent, selector: "mrx-select", inputs: { fields: "fields", items: "items", multiple: "multiple", isLoading: "isLoading", searchable: "searchable", clearable: "clearable", closable: "closable", size: "size", bindValue: "bindValue", bindLabel: "bindLabel", bindIcon: "bindIcon", emptyText: "emptyText", placeholder: "placeholder", searchPlaceholder: "searchPlaceholder", multiCollapseCount: "multiCollapseCount", optionValidation: ["isExtraOption", "optionValidation"], extraOptionPlaceholder: "extraOptionPlaceholder", use: "use", sortIcon: "sortIcon", sortPlaceholder: "sortPlaceholder", isFullWidthDropdown: "isFullWidthDropdown", addOption: "addOption", customSearchFn: "customSearchFn", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
222
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: SelectComponent, selector: "mrx-select", inputs: { fields: "fields", items: "items", multiple: "multiple", isLoading: "isLoading", searchable: "searchable", clearable: "clearable", closable: "closable", size: "size", bindValue: "bindValue", bindLabel: "bindLabel", bindIcon: "bindIcon", emptyText: "emptyText", placeholder: "placeholder", searchPlaceholder: "searchPlaceholder", multiCollapseCount: "multiCollapseCount", optionValidation: ["isExtraOption", "optionValidation"], extraOptionPlaceholder: "extraOptionPlaceholder", use: "use", sortIcon: "sortIcon", sortPlaceholder: "sortPlaceholder", isFullWidthDropdown: "isFullWidthDropdown", withoutSelected: "withoutSelected", addOption: "addOption", customSearchFn: "customSearchFn", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
219
223
  {
220
224
  provide: NG_VALUE_ACCESSOR,
221
225
  useExisting: forwardRef(() => SelectComponent),
@@ -275,6 +279,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
275
279
  type: Input
276
280
  }], isFullWidthDropdown: [{
277
281
  type: Input
282
+ }], withoutSelected: [{
283
+ type: Input
278
284
  }], addOption: [{
279
285
  type: Input
280
286
  }], customSearchFn: [{
@@ -316,4 +322,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
316
322
  }], modelChange: [{
317
323
  type: Output
318
324
  }] } });
319
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/select/select.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { SelectSizeEnum, SelectSizeTypes } from './enums';\r\nimport { PopupComponent } from '../../popup/components/popup/popup.component';\r\nimport { SelectInnerItemModel } from './models/select-inner-item.model';\r\nimport { AddOptionFn, CustomSearchFn, SelectItemModel } from './models/select-item.model';\r\nimport { getSelectedItems } from './helpers/get-selected-items.helper';\r\nimport { getInnerItems } from './helpers/get-inner-items.helper';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { TemplateOutputModel } from './models/template-output.model';\r\nimport { PositionEnum, PositionType } from '../../../enums/overlay';\r\nimport { getInnerSelected } from './helpers/get-inner-selected.helper';\r\nimport { MrxFormValidator } from '../../../services';\r\nimport { SelectValueTypes, SelectValueWithId } from './select.enum';\r\nimport { Field } from '../../../services/save-store/models';\r\n\r\n@Component({\r\n  selector: 'mrx-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrl: './select.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SelectComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SelectComponent implements ControlValueAccessor, OnInit {\r\n  public searchValue: string = '';\r\n  public isOpen: boolean = false;\r\n  public originSelected: any | any[] = [];\r\n  public originItems: SelectItemModel[] = [];\r\n  public selected: SelectItemModel[] = [];\r\n  public innerItems: SelectInnerItemModel[] = [];\r\n  public form = new MrxFormValidator();\r\n  public model = {\r\n    label: '',\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() set items(items: any[]) {\r\n    this.originItems = items;\r\n    this._updateSelected(this.originItems, this.originSelected);\r\n  }\r\n\r\n  @Input() multiple: boolean = false;\r\n  @Input() isLoading: boolean = false;\r\n  @Input() searchable: boolean = false;\r\n  @Input() clearable: boolean = true;\r\n  @Input() closable: boolean = true;\r\n  @Input() size: SelectSizeTypes = 'large';\r\n  @Input() bindValue: string | null = null;\r\n  @Input() bindLabel: string | null = null;\r\n  @Input() bindIcon: string | null = null;\r\n  @Input() emptyText: string = 'Не найдено';\r\n  @Input() placeholder: string = 'Выберите значение';\r\n  @Input() searchPlaceholder: string = 'Введите значение';\r\n  @Input() multiCollapseCount: number | null = null;\r\n  @Input('isExtraOption') optionValidation: { label: { required: boolean, minLength: number } } | null = null;\r\n  @Input() extraOptionPlaceholder: string = 'Введите значение';\r\n  @Input() use: 'default' | 'link' = 'default';\r\n  @Input() sortIcon: 'asc' | 'desc' | null = null;\r\n  @Input() sortPlaceholder: string = '';\r\n  @Input() isFullWidthDropdown: boolean = true;\r\n\r\n  @Input() addOption!: AddOptionFn;\r\n  @Input() customSearchFn?: CustomSearchFn;\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input() popupPosition: PositionType = PositionEnum.BottomStart;\r\n\r\n  @Input() singleChange: boolean = false;\r\n\r\n  @ViewChild('dropdown') dropdown!: PopupComponent;\r\n\r\n  @ContentChild('optionTemplate') optionTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('labelTemplate') labelTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('popupHeaderTemplate') popupHeaderTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('popupFooterTemplate') popupFooterTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('contentTemplate') contentTemplate!: TemplateRef<any>;\r\n\r\n  @Output() public changed: EventEmitter<SelectValueTypes> = new EventEmitter<SelectValueTypes>();\r\n  @Output() public modelChange: EventEmitter<SelectValueWithId> = new EventEmitter<SelectValueWithId>();\r\n\r\n  ngOnInit(): void {\r\n    if (this.optionValidation) {\r\n      this.form.initFields(this.model, this.optionValidation);\r\n    }\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${SelectSizeEnum[this.size]} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getSelectedLabels(): SelectInnerItemModel[] {\r\n    return this.innerItems.filter(i => i.__selected);\r\n  }\r\n\r\n  public get filteredItems(): SelectInnerItemModel[] {\r\n    if (this.customSearchFn) {\r\n      return this.innerItems.filter(item => {\r\n        return this.customSearchFn?.(this.searchValue, item.__origin) ?? false\r\n      })\r\n    } else {\r\n      return this.innerItems.filter(i => {\r\n        if (this.bindLabel) {\r\n          return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());\r\n        } else {\r\n          if (i.__origin['label']) {\r\n            return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());\r\n          } else {\r\n            return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage?.length;\r\n  }\r\n\r\n  get getIconState(): string {\r\n    return this.isOpen ? 'opened' : '';\r\n  }\r\n\r\n  get getIconSize(): string {\r\n    return this.size === 'medium' ? 'icon-font-16' : 'icon-font-24';\r\n  }\r\n\r\n  public onSelect(item: SelectInnerItemModel) {\r\n    if (!this.multiple) {\r\n      this.innerItems = this.innerItems.map(i => {\r\n        if (this.singleChange) {\r\n          return {...i, __selected: i.__id === item.__id};\r\n        }\r\n        if (this.use === 'default') {\r\n          return {...i, __selected: i.__id === item.__id ? !i.__selected : false};\r\n        } else {\r\n          return {...i, __selected: i.__id === item.__id};\r\n        }\r\n      });\r\n    } else {\r\n      this.innerItems = this.innerItems.map(i => {\r\n        return {...i, __selected: i.__id === item.__id ? !i.__selected : i.__selected};\r\n      });\r\n    }\r\n\r\n    this.dropdown.updatePopup();\r\n\r\n    this._updateValue(this.innerItems);\r\n  }\r\n\r\n  public clearItem(item: SelectInnerItemModel) {\r\n    this.onUnselect(item);\r\n  }\r\n\r\n  public onUnselect(item: SelectInnerItemModel) {\r\n    this.innerItems.forEach(i => {\r\n      if (i.__id === item.__id) {\r\n        i.__selected = false;\r\n      }\r\n    });\r\n\r\n    this._updateValue(this.innerItems);\r\n  }\r\n\r\n  public onClear(event: MouseEvent) {\r\n    event.stopPropagation();\r\n\r\n    this.innerItems = this.innerItems.map(item => ({...item, __selected: false}));\r\n\r\n    this.dropdown.togglePopup(false);\r\n\r\n    this._updateValue([]);\r\n  }\r\n\r\n  public togglePopup(isOpen: boolean) {\r\n    this.isOpen = isOpen;\r\n  }\r\n\r\n  public asOption(option: SelectInnerItemModel): SelectInnerItemModel {\r\n    return option;\r\n  }\r\n\r\n  public asLabel(label: SelectInnerItemModel): SelectInnerItemModel {\r\n    return label;\r\n  }\r\n\r\n  public writeValue(selected: any | any[] = []): void {\r\n    if (selected !== null) {\r\n      this.originSelected = selected;\r\n      this._updateSelected(this.originItems, this.originSelected);\r\n    }\r\n  }\r\n\r\n  public changeTextValueEmpty(): void {\r\n    this.form.initModelChanged(this.model);\r\n  }\r\n\r\n  public onAddNewCustomOption() {\r\n    if (this.form.isValid()) {\r\n      this.addOption(this.model.label);\r\n      this.model.label = '';\r\n\r\n      this.changeTextValueEmpty();\r\n    }\r\n  }\r\n\r\n  private _updateSelected(items: any[] = [], selected: any[] = []) {\r\n    if (this.multiple && Array.isArray(this.originSelected)) {\r\n      this.selected = getInnerSelected(items, selected, this.bindValue);\r\n    } else {\r\n      this.selected = getInnerSelected(items, [selected], this.bindValue);\r\n    }\r\n    this.innerItems = getInnerItems(items, this.selected, this.bindValue);\r\n  }\r\n\r\n  private _updateValue(selectedItems: SelectInnerItemModel[]) {\r\n    const clearedSelected = getSelectedItems(selectedItems, this.bindValue);\r\n    const outputSelected = this.multiple ? clearedSelected : clearedSelected.length ? clearedSelected[0] : null;\r\n\r\n    this.changed.emit(outputSelected);\r\n    this.modelChange.emit({value: outputSelected, id: this.uuid});\r\n    this.onChange(outputSelected);\r\n    this.onTouched();\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n}\r\n","<div\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class.mrx-input-error]=\"invalid\"\r\n  [class]=\"getClasses\"\r\n  class=\"mrx-select\"\r\n>\r\n  <div class=\"mrx-select__wrapper\">\r\n    @switch (use) {\r\n      @case ('default') {\r\n        <div\r\n          class=\"mrx-select__input\"\r\n          [mrxPopupTrigger]=\"dropdown\"\r\n          [isFullWidthDropdown]=\"isFullWidthDropdown\"\r\n        >\r\n          @if (getSelectedLabels.length) {\r\n            @if (multiple) {\r\n              <div class=\"mrx-select__input__values\">\r\n                @if (multiCollapseCount && getSelectedLabels.length >= multiCollapseCount) {\r\n                  <div class=\"mrx-select__input__badge\">\r\n                    <p>Выбрано: {{ getSelectedLabels.length }}</p>\r\n\r\n                    @if (!disabled && !readonly) {\r\n                      <span class=\"mrx-icon icon-close icon-font-16\" (click)=\"onClear($event)\"></span>\r\n                    }\r\n                  </div>\r\n                } @else {\r\n                  @for (item of getSelectedLabels; track item.__id; let first = $first; let last = $last) {\r\n                    @if (labelTemplate) {\r\n                      <ng-container\r\n                        [ngTemplateOutlet]=\"labelTemplate\"\r\n                        [ngTemplateOutletContext]=\"{item: item, first, last, clear: clearItem.bind(this)}\"\r\n                      ></ng-container>\r\n                    } @else {\r\n                      <ng-container\r\n                        [ngTemplateOutlet]=\"defaultLabelTemplate\"\r\n                        [ngTemplateOutletContext]=\"{item: item, first, last}\"\r\n                      ></ng-container>\r\n                    }\r\n                  }\r\n                }\r\n              </div>\r\n            } @else {\r\n              <div class=\"mrx-select__input__value\">\r\n                @for (item of getSelectedLabels; track item.__id) {\r\n                  {{ bindLabel ? item.__origin[bindLabel] : item.__origin['label'] || item.__origin }}\r\n                }\r\n              </div>\r\n            }\r\n          } @else {\r\n            <div class=\"mrx-select__input__placeholder\">{{ placeholder }}</div>\r\n          }\r\n\r\n          <div class=\"mrx-select__input__controls\">\r\n            @if (isLoading) {\r\n              <mrx-loader\r\n                [size]=\"size === 'large' ? 'small' : 'extra-small'\"\r\n                [color]=\"'brand'\"\r\n              ></mrx-loader>\r\n            }\r\n\r\n            @if (getSelectedLabels.length && clearable) {\r\n              <div\r\n                class=\"mrx-icon icon-close mrx-select__input__controls--icon\"\r\n                [class]=\"getIconSize\"\r\n                (click)=\"onClear($event)\"\r\n              ></div>\r\n            }\r\n\r\n            <div\r\n              class=\"mrx-icon icon-chevron-down mrx-select__input__controls--icon\"\r\n              [class]=\"[getIconState, getIconSize]\"\r\n            ></div>\r\n          </div>\r\n        </div>\r\n      }\r\n      @case ('link') {\r\n        <div\r\n          class=\"mrx-select__input-link\"\r\n          [mrxPopupTrigger]=\"dropdown\"\r\n          [popupPosition]=\"popupPosition\"\r\n          [isFullWidthDropdown]=\"isFullWidthDropdown\"\r\n        >\r\n          <div class=\"mrx-select__input-link__controls\">\r\n            @if (sortPlaceholder) {\r\n              <p>{{ sortPlaceholder }}</p>\r\n            }\r\n\r\n            @if (sortIcon) {\r\n              <span\r\n                class=\"mrx-icon {{sortIcon === 'asc' ? 'icon-sorting-up' : 'icon-sorting-down'}}\"\r\n                [class]=\"getIconSize\"\r\n              ></span>\r\n            }\r\n          </div>\r\n\r\n          <div class=\"mrx-select__input-link__controls\">\r\n            @if (getSelectedLabels.length) {\r\n              <div class=\"mrx-select__input-link__value\">\r\n                @for (item of getSelectedLabels; track item.__id) {\r\n                  {{ bindLabel ? item.__origin[bindLabel] : item.__origin['label'] || item.__origin }}\r\n                }\r\n              </div>\r\n            }\r\n\r\n            <div\r\n              class=\"mrx-icon icon-chevron-down mrx-select__input__controls--icon\"\r\n              [class]=\"[getIconState, getIconSize]\"\r\n            ></div>\r\n          </div>\r\n        </div>\r\n      }\r\n    }\r\n\r\n    <mrx-popup #dropdown [closeAfterClick]=\"closable\" (toggle)=\"togglePopup($event)\">\r\n      @for (item of filteredItems; track item.__id; let first = $first; let last = $last) {\r\n        <mrx-popup-item [custom]=\"true\" [id]=\"item.__id\" (clicked)=\"onSelect(item)\">\r\n          @if (optionTemplate) {\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"optionTemplate\"\r\n              [ngTemplateOutletContext]=\"{item: item, first, last}\"\r\n            ></ng-container>\r\n          } @else {\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"defaultOptionTemplate\"\r\n              [ngTemplateOutletContext]=\"{item: item, first, last}\"\r\n            ></ng-container>\r\n          }\r\n        </mrx-popup-item>\r\n      } @empty {\r\n        <mrx-popup-item [custom]=\"true\">\r\n          <div class=\"mrx-select__dropdown__empty\">{{ emptyText }}</div>\r\n        </mrx-popup-item>\r\n      }\r\n\r\n      <ng-template #headerTemplate>\r\n        @if (searchable) {\r\n          <div class=\"mrx-select__dropdown__search\">\r\n            <mrx-input-search\r\n              [size]=\"'medium'\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              [(ngModel)]=\"searchValue\"\r\n            ></mrx-input-search>\r\n          </div>\r\n        }\r\n\r\n        @if (contentTemplate) {\r\n          <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\r\n        }\r\n\r\n        @if (popupHeaderTemplate) {\r\n          <ng-container\r\n            [ngTemplateOutlet]=\"popupHeaderTemplate\"\r\n          ></ng-container>\r\n        }\r\n      </ng-template>\r\n\r\n      <ng-template #footerTemplate>\r\n        @if (!!addOption) {\r\n          <div class=\"mrx-select__dropdown__extra-option\">\r\n            <mrx-input-text\r\n              class=\"flex-grow-1\"\r\n              [size]=\"'medium'\"\r\n              [placeholder]=\"extraOptionPlaceholder\"\r\n              [(ngModel)]=\"model.label\"\r\n              [maxlength]=\"300\"\r\n              [invalid]=\"!!form.errors['label']\"\r\n              [invalidMessage]=\"form.errors['label']\"\r\n              (ngModelChange)=\"changeTextValueEmpty()\"\r\n            ></mrx-input-text>\r\n            <mrx-button\r\n              [iconOnly]=\"true\"\r\n              icon=\"<span class='mrx-icon icon-plus icon-font-24'></span>\"\r\n              size=\"medium\"\r\n              type=\"secondary\"\r\n              (click)=\"onAddNewCustomOption()\"\r\n            ></mrx-button>\r\n          </div>\r\n        }\r\n\r\n        @if (popupFooterTemplate) {\r\n          <ng-container\r\n            [ngTemplateOutlet]=\"popupFooterTemplate\"\r\n          ></ng-container>\r\n        }\r\n      </ng-template>\r\n    </mrx-popup>\r\n  </div>\r\n\r\n  @if (invalid && isInvalidMessage) {\r\n    <mrx-error-message [invalidMessage]=\"invalidMessage\"></mrx-error-message>\r\n  }\r\n\r\n  <mrx-save-state [fields]=\"fields\" [id]=\"uuid\" [type]=\"'input'\"></mrx-save-state>\r\n</div>\r\n\r\n<ng-template #defaultLabelTemplate let-item=\"item\">\r\n  @if (asLabel(item); as label) {\r\n    <div class=\"mrx-select__input__badge\">\r\n      <p>{{ bindLabel ? label.__origin[bindLabel] : label.__origin['label'] || label.__origin }}</p>\r\n      <span class=\"mrx-icon icon-close icon-font-16\" (click)=\"onUnselect(label)\"></span>\r\n    </div>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTemplate let-item=\"item\">\r\n  @if (asOption(item); as option) {\r\n    <div class=\"mrx-select__dropdown__item\">\r\n      <div class=\"mrx-select__dropdown__item--content\">\r\n        @if (bindIcon && option.__origin[bindIcon]) {\r\n          <span class=\"mrx-icon icon-font-24\" [class]=\"option[bindIcon]\"></span>\r\n        }\r\n\r\n        <p>{{ bindLabel ? option.__origin[bindLabel] : option.__origin['label'] || option.__origin }}</p>\r\n      </div>\r\n\r\n      @if (option.__selected) {\r\n        <span class=\"mrx-icon icon-check icon-font-24\"></span>\r\n      }\r\n    </div>\r\n  }\r\n</ng-template>\r\n"]}
325
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/select/select.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { SelectSizeEnum, SelectSizeTypes } from './enums';\r\nimport { PopupComponent } from '../../popup/components/popup/popup.component';\r\nimport { SelectInnerItemModel, AddOptionFn, CustomSearchFn, SelectItemModel, TemplateOutputModel } from './models';\r\nimport { getSelectedItems } from './helpers/get-selected-items.helper';\r\nimport { getInnerItems } from './helpers/get-inner-items.helper';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { PositionEnum, PositionType } from '../../../enums/overlay';\r\nimport { getInnerSelected } from './helpers/get-inner-selected.helper';\r\nimport { MrxFormValidator } from '../../../services';\r\nimport { SelectValueTypes, SelectValueWithId } from './select.enum';\r\nimport { Field } from '../../../services';\r\n\r\n@Component({\r\n  selector: 'mrx-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrl: './select.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SelectComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SelectComponent implements ControlValueAccessor, OnInit {\r\n  public searchValue: string = '';\r\n  public isOpen: boolean = false;\r\n  public originSelected: any | any[] = [];\r\n  public originItems: SelectItemModel[] = [];\r\n  public selected: SelectItemModel[] = [];\r\n  public innerItems: SelectInnerItemModel[] = [];\r\n  public form = new MrxFormValidator();\r\n  public model = {\r\n    label: '',\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() set items(items: any[]) {\r\n    this.originItems = items;\r\n    this._updateSelected(this.originItems, this.originSelected);\r\n  }\r\n\r\n  @Input() multiple: boolean = false;\r\n  @Input() isLoading: boolean = false;\r\n  @Input() searchable: boolean = false;\r\n  @Input() clearable: boolean = true;\r\n  @Input() closable: boolean = true;\r\n  @Input() size: SelectSizeTypes = 'large';\r\n  @Input() bindValue: string | null = null;\r\n  @Input() bindLabel: string | null = null;\r\n  @Input() bindIcon: string | null = null;\r\n  @Input() emptyText: string = 'Не найдено';\r\n  @Input() placeholder: string = 'Выберите значение';\r\n  @Input() searchPlaceholder: string = 'Введите значение';\r\n  @Input() multiCollapseCount: number | null = null;\r\n  @Input('isExtraOption') optionValidation: { label: { required: boolean, minLength: number } } | null = null;\r\n  @Input() extraOptionPlaceholder: string = 'Введите значение';\r\n  @Input() use: 'default' | 'link' = 'default';\r\n  @Input() sortIcon: 'asc' | 'desc' | null = null;\r\n  @Input() sortPlaceholder: string = '';\r\n  @Input() isFullWidthDropdown: boolean = true;\r\n  @Input() withoutSelected: boolean = false;\r\n\r\n  @Input() addOption!: AddOptionFn;\r\n  @Input() customSearchFn?: CustomSearchFn;\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input() popupPosition: PositionType = PositionEnum.BottomStart;\r\n\r\n  @Input() singleChange: boolean = false;\r\n\r\n  @ViewChild('dropdown') dropdown!: PopupComponent;\r\n\r\n  @ContentChild('optionTemplate') optionTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('labelTemplate') labelTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('popupHeaderTemplate') popupHeaderTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('popupFooterTemplate') popupFooterTemplate!: TemplateRef<TemplateOutputModel>;\r\n  @ContentChild('contentTemplate') contentTemplate!: TemplateRef<any>;\r\n\r\n  @Output() public changed: EventEmitter<SelectValueTypes> = new EventEmitter<SelectValueTypes>();\r\n  @Output() public modelChange: EventEmitter<SelectValueWithId> = new EventEmitter<SelectValueWithId>();\r\n\r\n  ngOnInit(): void {\r\n    if (this.optionValidation) {\r\n      this.form.initFields(this.model, this.optionValidation);\r\n    }\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${SelectSizeEnum[this.size]} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getSelectedLabels(): SelectInnerItemModel[] {\r\n    if (this.withoutSelected) {\r\n      return []\r\n    } else {\r\n      return this.innerItems.filter(i => i.__selected);\r\n    }\r\n  }\r\n\r\n  public get filteredItems(): SelectInnerItemModel[] {\r\n    if (this.customSearchFn) {\r\n      return this.innerItems.filter(item => {\r\n        return this.customSearchFn?.(this.searchValue, item.__origin) ?? false\r\n      })\r\n    } else {\r\n      return this.innerItems.filter(i => {\r\n        if (this.bindLabel) {\r\n          return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());\r\n        } else {\r\n          if (i.__origin['label']) {\r\n            return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());\r\n          } else {\r\n            return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage?.length;\r\n  }\r\n\r\n  get getIconState(): string {\r\n    return this.isOpen ? 'opened' : '';\r\n  }\r\n\r\n  get getIconSize(): string {\r\n    return this.size === 'medium' ? 'icon-font-16' : 'icon-font-24';\r\n  }\r\n\r\n  public onSelect(item: SelectInnerItemModel) {\r\n    if (!this.multiple) {\r\n      this.innerItems = this.innerItems.map(i => {\r\n        if (this.singleChange) {\r\n          return {...i, __selected: i.__id === item.__id};\r\n        }\r\n        if (this.use === 'default') {\r\n          return {...i, __selected: i.__id === item.__id ? !i.__selected : false};\r\n        } else {\r\n          return {...i, __selected: i.__id === item.__id};\r\n        }\r\n      });\r\n    } else {\r\n      this.innerItems = this.innerItems.map(i => {\r\n        return {...i, __selected: i.__id === item.__id ? !i.__selected : i.__selected};\r\n      });\r\n    }\r\n\r\n    this.dropdown.updatePopup();\r\n\r\n    this._updateValue(this.innerItems);\r\n  }\r\n\r\n  public clearItem(item: SelectInnerItemModel) {\r\n    this.onUnselect(item);\r\n  }\r\n\r\n  public onUnselect(item: SelectInnerItemModel) {\r\n    this.innerItems.forEach(i => {\r\n      if (i.__id === item.__id) {\r\n        i.__selected = false;\r\n      }\r\n    });\r\n\r\n    this._updateValue(this.innerItems);\r\n  }\r\n\r\n  public onClear(event: MouseEvent) {\r\n    event.stopPropagation();\r\n\r\n    this.innerItems = this.innerItems.map(item => ({...item, __selected: false}));\r\n\r\n    this.dropdown.togglePopup(false);\r\n\r\n    this._updateValue([]);\r\n  }\r\n\r\n  public togglePopup(isOpen: boolean) {\r\n    this.isOpen = isOpen;\r\n  }\r\n\r\n  public asOption(option: SelectInnerItemModel): SelectInnerItemModel {\r\n    return option;\r\n  }\r\n\r\n  public asLabel(label: SelectInnerItemModel): SelectInnerItemModel {\r\n    return label;\r\n  }\r\n\r\n  public writeValue(selected: any | any[] = []): void {\r\n    this.originSelected = selected;\r\n    this._updateSelected(this.originItems, this.originSelected);\r\n  }\r\n\r\n  public changeTextValueEmpty(): void {\r\n    this.form.initModelChanged(this.model);\r\n  }\r\n\r\n  public onAddNewCustomOption() {\r\n    if (this.form.isValid()) {\r\n      this.addOption(this.model.label);\r\n      this.model.label = '';\r\n\r\n      this.changeTextValueEmpty();\r\n    }\r\n  }\r\n\r\n  private _updateSelected(items: any[] = [], selected: any[] = []) {\r\n    if (this.multiple && Array.isArray(this.originSelected)) {\r\n      this.selected = getInnerSelected(items, selected, this.bindValue);\r\n    } else {\r\n      this.selected = getInnerSelected(items, [selected], this.bindValue);\r\n    }\r\n    this.innerItems = getInnerItems(items, this.selected, this.bindValue);\r\n  }\r\n\r\n  private _updateValue(selectedItems: SelectInnerItemModel[]) {\r\n    const clearedSelected = getSelectedItems(selectedItems, this.bindValue);\r\n    const outputSelected = this.multiple ? clearedSelected : clearedSelected.length ? clearedSelected[0] : null;\r\n\r\n    this.changed.emit(outputSelected);\r\n    this.modelChange.emit({value: outputSelected, id: this.uuid});\r\n    this.onChange(outputSelected);\r\n    this.onTouched();\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n}\r\n","<div\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class.mrx-input-error]=\"invalid\"\r\n  [class]=\"getClasses\"\r\n  class=\"mrx-select\"\r\n>\r\n  <div class=\"mrx-select__wrapper\">\r\n    @switch (use) {\r\n      @case ('default') {\r\n        <div\r\n          class=\"mrx-select__input\"\r\n          [mrxPopupTrigger]=\"dropdown\"\r\n          [isFullWidthDropdown]=\"isFullWidthDropdown\"\r\n        >\r\n          @if (getSelectedLabels.length) {\r\n            @if (multiple) {\r\n              <div class=\"mrx-select__input__values\">\r\n                @if (multiCollapseCount && getSelectedLabels.length >= multiCollapseCount) {\r\n                  <div class=\"mrx-select__input__badge\">\r\n                    <p>Выбрано: {{ getSelectedLabels.length }}</p>\r\n\r\n                    @if (!disabled && !readonly) {\r\n                      <span class=\"mrx-icon icon-close icon-font-16\" (click)=\"onClear($event)\"></span>\r\n                    }\r\n                  </div>\r\n                } @else {\r\n                  @for (item of getSelectedLabels; track item.__id; let first = $first; let last = $last) {\r\n                    @if (labelTemplate) {\r\n                      <ng-container\r\n                        [ngTemplateOutlet]=\"labelTemplate\"\r\n                        [ngTemplateOutletContext]=\"{item: item, first, last, clear: clearItem.bind(this)}\"\r\n                      ></ng-container>\r\n                    } @else {\r\n                      <ng-container\r\n                        [ngTemplateOutlet]=\"defaultLabelTemplate\"\r\n                        [ngTemplateOutletContext]=\"{item: item, first, last}\"\r\n                      ></ng-container>\r\n                    }\r\n                  }\r\n                }\r\n              </div>\r\n            } @else {\r\n              <div class=\"mrx-select__input__value\">\r\n                @for (item of getSelectedLabels; track item.__id) {\r\n                  {{ bindLabel ? item.__origin[bindLabel] : item.__origin['label'] || item.__origin }}\r\n                }\r\n              </div>\r\n            }\r\n          } @else {\r\n            <div class=\"mrx-select__input__placeholder\">{{ placeholder }}</div>\r\n          }\r\n\r\n          <div class=\"mrx-select__input__controls\">\r\n            @if (isLoading) {\r\n              <mrx-loader\r\n                [size]=\"size === 'large' ? 'small' : 'extra-small'\"\r\n                [color]=\"'brand'\"\r\n              ></mrx-loader>\r\n            }\r\n\r\n            @if (getSelectedLabels.length && clearable) {\r\n              <div\r\n                class=\"mrx-icon icon-close mrx-select__input__controls--icon\"\r\n                [class]=\"getIconSize\"\r\n                (click)=\"onClear($event)\"\r\n              ></div>\r\n            }\r\n\r\n            <div\r\n              class=\"mrx-icon icon-chevron-down mrx-select__input__controls--icon\"\r\n              [class]=\"[getIconState, getIconSize]\"\r\n            ></div>\r\n          </div>\r\n        </div>\r\n      }\r\n      @case ('link') {\r\n        <div\r\n          class=\"mrx-select__input-link\"\r\n          [mrxPopupTrigger]=\"dropdown\"\r\n          [popupPosition]=\"popupPosition\"\r\n          [isFullWidthDropdown]=\"isFullWidthDropdown\"\r\n        >\r\n          <div class=\"mrx-select__input-link__controls\">\r\n            @if (sortPlaceholder) {\r\n              <p>{{ sortPlaceholder }}</p>\r\n            }\r\n\r\n            @if (sortIcon) {\r\n              <span\r\n                class=\"mrx-icon {{sortIcon === 'asc' ? 'icon-sorting-up' : 'icon-sorting-down'}}\"\r\n                [class]=\"getIconSize\"\r\n              ></span>\r\n            }\r\n          </div>\r\n\r\n          <div class=\"mrx-select__input-link__controls\">\r\n            @if (getSelectedLabels.length) {\r\n              <div class=\"mrx-select__input-link__value\">\r\n                @for (item of getSelectedLabels; track item.__id) {\r\n                  {{ bindLabel ? item.__origin[bindLabel] : item.__origin['label'] || item.__origin }}\r\n                }\r\n              </div>\r\n            }\r\n\r\n            <div\r\n              class=\"mrx-icon icon-chevron-down mrx-select__input__controls--icon\"\r\n              [class]=\"[getIconState, getIconSize]\"\r\n            ></div>\r\n          </div>\r\n        </div>\r\n      }\r\n    }\r\n\r\n    <mrx-popup #dropdown [closeAfterClick]=\"closable\" (toggle)=\"togglePopup($event)\">\r\n      @for (item of filteredItems; track item.__id; let first = $first; let last = $last) {\r\n        <mrx-popup-item [custom]=\"true\" [id]=\"item.__id\" (clicked)=\"onSelect(item)\">\r\n          @if (optionTemplate) {\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"optionTemplate\"\r\n              [ngTemplateOutletContext]=\"{item: item, first, last}\"\r\n            ></ng-container>\r\n          } @else {\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"defaultOptionTemplate\"\r\n              [ngTemplateOutletContext]=\"{item: item, first, last}\"\r\n            ></ng-container>\r\n          }\r\n        </mrx-popup-item>\r\n      } @empty {\r\n        <mrx-popup-item [custom]=\"true\">\r\n          <div class=\"mrx-select__dropdown__empty\">{{ emptyText }}</div>\r\n        </mrx-popup-item>\r\n      }\r\n\r\n      <ng-template #headerTemplate>\r\n        @if (searchable) {\r\n          <div class=\"mrx-select__dropdown__search\">\r\n            <mrx-input-search\r\n              [size]=\"'medium'\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              [(ngModel)]=\"searchValue\"\r\n            ></mrx-input-search>\r\n          </div>\r\n        }\r\n\r\n        @if (contentTemplate) {\r\n          <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\r\n        }\r\n\r\n        @if (popupHeaderTemplate) {\r\n          <ng-container\r\n            [ngTemplateOutlet]=\"popupHeaderTemplate\"\r\n          ></ng-container>\r\n        }\r\n      </ng-template>\r\n\r\n      <ng-template #footerTemplate>\r\n        @if (!!addOption) {\r\n          <div class=\"mrx-select__dropdown__extra-option\">\r\n            <mrx-input-text\r\n              class=\"flex-grow-1\"\r\n              [size]=\"'medium'\"\r\n              [placeholder]=\"extraOptionPlaceholder\"\r\n              [(ngModel)]=\"model.label\"\r\n              [maxlength]=\"300\"\r\n              [invalid]=\"!!form.errors['label']\"\r\n              [invalidMessage]=\"form.errors['label']\"\r\n              (ngModelChange)=\"changeTextValueEmpty()\"\r\n            ></mrx-input-text>\r\n            <mrx-button\r\n              [iconOnly]=\"true\"\r\n              icon=\"<span class='mrx-icon icon-plus icon-font-24'></span>\"\r\n              size=\"medium\"\r\n              type=\"secondary\"\r\n              (click)=\"onAddNewCustomOption()\"\r\n            ></mrx-button>\r\n          </div>\r\n        }\r\n\r\n        @if (popupFooterTemplate) {\r\n          <ng-container\r\n            [ngTemplateOutlet]=\"popupFooterTemplate\"\r\n          ></ng-container>\r\n        }\r\n      </ng-template>\r\n    </mrx-popup>\r\n  </div>\r\n\r\n  @if (invalid && isInvalidMessage) {\r\n    <mrx-error-message [invalidMessage]=\"invalidMessage\"></mrx-error-message>\r\n  }\r\n\r\n  <mrx-save-state [fields]=\"fields\" [id]=\"uuid\" [type]=\"'input'\"></mrx-save-state>\r\n</div>\r\n\r\n<ng-template #defaultLabelTemplate let-item=\"item\">\r\n  @if (asLabel(item); as label) {\r\n    <div class=\"mrx-select__input__badge\">\r\n      <p>{{ bindLabel ? label.__origin[bindLabel] : label.__origin['label'] || label.__origin }}</p>\r\n      <span class=\"mrx-icon icon-close icon-font-16\" (click)=\"onUnselect(label)\"></span>\r\n    </div>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTemplate let-item=\"item\">\r\n  @if (asOption(item); as option) {\r\n    <div class=\"mrx-select__dropdown__item\">\r\n      <div class=\"mrx-select__dropdown__item--content\">\r\n        @if (bindIcon && option.__origin[bindIcon]) {\r\n          <span class=\"mrx-icon icon-font-24\" [class]=\"option[bindIcon]\"></span>\r\n        }\r\n\r\n        <p>{{ bindLabel ? option.__origin[bindLabel] : option.__origin['label'] || option.__origin }}</p>\r\n      </div>\r\n\r\n      @if (option.__selected) {\r\n        <span class=\"mrx-icon icon-check icon-font-24\"></span>\r\n      }\r\n    </div>\r\n  }\r\n</ng-template>\r\n"]}
@@ -73,7 +73,7 @@ export class LabelComponent {
73
73
  this.clickedLink.emit(event);
74
74
  }
75
75
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LabelComponent, deps: [{ token: i1.TooltipService }], target: i0.ɵɵFactoryTarget.Component });
76
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LabelComponent, selector: "mrx-label", inputs: { requiredHidden: "requiredHidden", required: "required", boldLabel: "boldLabel", disabled: "disabled", placeholder: "placeholder", label: "label", customClasses: "customClasses", triggerTextPosition: "triggerTextPosition", isPublicInfo: "isPublicInfo", publicInfoTooltip: "publicInfoTooltip", isSwitch: "isSwitch", switchLabel: "switchLabel", switchValue: "switchValue", isCheckbox: "isCheckbox", checkboxLabel: "checkboxLabel", checkboxValue: "checkboxValue", counter: "counter", linkText: "linkText", linkPrevent: "linkPrevent", linkType: "linkType", linkMonochrome: "linkMonochrome", href: "href", triggerType: "triggerType", tooltip: "tooltip", tooltipInitialVisible: "tooltipInitialVisible", isSaveToStorage: "isSaveToStorage" }, outputs: { changeSwitchValue: "changeSwitchValue", changeCheckboxValue: "changeCheckboxValue", clickedLink: "clickedLink" }, providers: [TooltipService], queries: [{ propertyName: "customIcons", first: true, predicate: ["customIcons"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n class=\"mrx-label\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n <span *ngIf=\"required && !disabled && !requiredHidden\" class=\"required-active\">*</span>\r\n\r\n <span\r\n *ngIf=\"isPublicInfo\"\r\n class=\"mrx-icon icon-megafon ml-1\"\r\n [mrxCdkTooltip]=\"publicInfoTooltip\"\r\n ></span>\r\n\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n *ngIf=\"tooltipService.getTooltip\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n <mrx-badge *ngIf=\"counter\" customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n </div>\r\n\r\n <mrx-switch\r\n *ngIf=\"isSwitch\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n\r\n <mrx-checkbox\r\n *ngIf=\"isCheckbox\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n\r\n <mrx-link\r\n *ngIf=\"linkText\"\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >{{ linkText }}</mrx-link>\r\n</div>\r\n\r\n<mrx-tooltip\r\n *ngIf=\"tooltipService.getTooltip\"\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n></mrx-tooltip>\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.TooltipComponent, selector: "mrx-tooltip", inputs: ["tooltip", "tooltipVisible", "tooltipInitiallyVisible", "triggerType"], outputs: ["visibilityChanged"] }, { kind: "component", type: i5.TooltipTriggerComponent, selector: "mrx-tooltip-trigger", inputs: ["triggerTextPosition", "triggerType", "customClasses", "isVisibleTooltip"], outputs: ["toggleTooltip"] }, { kind: "component", type: i6.SwitchComponent, selector: "mrx-switch", inputs: ["fields", "size", "type", "label", "boldLabel", "disabled", "readonly", "required", "customClasses", "leftText", "rightText"], outputs: ["changed", "modelChange"] }, { kind: "component", type: i7.BadgeComponent, selector: "mrx-badge", inputs: ["type", "tag", "size", "color", "customColor", "text", "path", "customClasses", "target"], outputs: ["clicked"] }, { kind: "component", type: i8.LinkComponent, selector: "mrx-link", inputs: ["href", "target", "routerLink", "queryParams", "type", "monochrome", "customClasses", "prevent", "size"], outputs: ["clicked"] }, { kind: "directive", type: i9.CdkTooltipDirective, selector: "[mrxCdkTooltip]", inputs: ["mrxCdkTooltip", "tooltipActive", "autoCloseByScroll", "tooltipPosition", "tooltipMaxWidth"] }, { kind: "component", type: i10.CheckboxComponent, selector: "mrx-checkbox", inputs: ["fields", "required", "boldLabel", "indeterminate", "disabled", "readonly", "label", "customClasses", "customWrapperClasses", "invalid", "checkInvalid", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changed", "modelChange"] }], animations: [
76
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: LabelComponent, selector: "mrx-label", inputs: { requiredHidden: "requiredHidden", required: "required", boldLabel: "boldLabel", disabled: "disabled", placeholder: "placeholder", label: "label", customClasses: "customClasses", triggerTextPosition: "triggerTextPosition", isPublicInfo: "isPublicInfo", publicInfoTooltip: "publicInfoTooltip", isSwitch: "isSwitch", switchLabel: "switchLabel", switchValue: "switchValue", isCheckbox: "isCheckbox", checkboxLabel: "checkboxLabel", checkboxValue: "checkboxValue", counter: "counter", linkText: "linkText", linkPrevent: "linkPrevent", linkType: "linkType", linkMonochrome: "linkMonochrome", href: "href", triggerType: "triggerType", tooltip: "tooltip", tooltipInitialVisible: "tooltipInitialVisible", isSaveToStorage: "isSaveToStorage" }, outputs: { changeSwitchValue: "changeSwitchValue", changeCheckboxValue: "changeCheckboxValue", clickedLink: "clickedLink" }, providers: [TooltipService], queries: [{ propertyName: "customIcons", first: true, predicate: ["customIcons"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n class=\"mrx-label\"\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n @if (required && !disabled && !requiredHidden) {\r\n <span class=\"required-active\">*</span>\r\n }\r\n\r\n @if (isPublicInfo) {\r\n <span class=\"mrx-icon icon-megafon ml-1\" [mrxCdkTooltip]=\"publicInfoTooltip\"></span>\r\n }\r\n\r\n @if (tooltipService.getTooltip) {\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n }\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n @if (counter) {\r\n <mrx-badge customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n }\r\n </div>\r\n\r\n @if (isSwitch) {\r\n <mrx-switch\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n }\r\n\r\n @if (isCheckbox) {\r\n <mrx-checkbox\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n }\r\n\r\n @if (linkText) {\r\n <mrx-link\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >\r\n {{ linkText }}\r\n </mrx-link>\r\n }\r\n</div>\r\n\r\n@if (tooltipService.getTooltip) {\r\n <mrx-tooltip\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip>\r\n}\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.TooltipComponent, selector: "mrx-tooltip", inputs: ["tooltip", "tooltipVisible", "tooltipInitiallyVisible", "triggerType"], outputs: ["visibilityChanged"] }, { kind: "component", type: i5.TooltipTriggerComponent, selector: "mrx-tooltip-trigger", inputs: ["triggerTextPosition", "triggerType", "customClasses", "isVisibleTooltip"], outputs: ["toggleTooltip"] }, { kind: "component", type: i6.SwitchComponent, selector: "mrx-switch", inputs: ["fields", "size", "type", "label", "boldLabel", "disabled", "readonly", "required", "customClasses", "leftText", "rightText"], outputs: ["changed", "modelChange"] }, { kind: "component", type: i7.BadgeComponent, selector: "mrx-badge", inputs: ["type", "tag", "size", "color", "customColor", "text", "path", "customClasses", "target"], outputs: ["clicked"] }, { kind: "component", type: i8.LinkComponent, selector: "mrx-link", inputs: ["href", "target", "routerLink", "queryParams", "type", "monochrome", "customClasses", "prevent", "size"], outputs: ["clicked"] }, { kind: "directive", type: i9.CdkTooltipDirective, selector: "[mrxCdkTooltip]", inputs: ["mrxCdkTooltip", "tooltipActive", "autoCloseByScroll", "tooltipPosition", "tooltipMaxWidth"] }, { kind: "component", type: i10.CheckboxComponent, selector: "mrx-checkbox", inputs: ["fields", "required", "boldLabel", "indeterminate", "disabled", "readonly", "label", "customClasses", "customWrapperClasses", "invalid", "checkInvalid", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changed", "modelChange"] }], animations: [
77
77
  trigger('openClose', [
78
78
  state('open', style({ height: '*', padding: '*', 'margin-bottom': '8px' })),
79
79
  state('closed', style({ height: 0, padding: 0, 'margin-bottom': 0 })),
@@ -91,7 +91,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
91
91
  transition('open => closed', [animate('0.5s ease')]),
92
92
  transition('closed => open', [animate('0.5s ease')]),
93
93
  ]),
94
- ], providers: [TooltipService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n class=\"mrx-label\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n <span *ngIf=\"required && !disabled && !requiredHidden\" class=\"required-active\">*</span>\r\n\r\n <span\r\n *ngIf=\"isPublicInfo\"\r\n class=\"mrx-icon icon-megafon ml-1\"\r\n [mrxCdkTooltip]=\"publicInfoTooltip\"\r\n ></span>\r\n\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n *ngIf=\"tooltipService.getTooltip\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n <mrx-badge *ngIf=\"counter\" customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n </div>\r\n\r\n <mrx-switch\r\n *ngIf=\"isSwitch\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n\r\n <mrx-checkbox\r\n *ngIf=\"isCheckbox\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n\r\n <mrx-link\r\n *ngIf=\"linkText\"\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >{{ linkText }}</mrx-link>\r\n</div>\r\n\r\n<mrx-tooltip\r\n *ngIf=\"tooltipService.getTooltip\"\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n></mrx-tooltip>\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"] }]
94
+ ], providers: [TooltipService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n class=\"mrx-label\"\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n @if (required && !disabled && !requiredHidden) {\r\n <span class=\"required-active\">*</span>\r\n }\r\n\r\n @if (isPublicInfo) {\r\n <span class=\"mrx-icon icon-megafon ml-1\" [mrxCdkTooltip]=\"publicInfoTooltip\"></span>\r\n }\r\n\r\n @if (tooltipService.getTooltip) {\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n }\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n @if (counter) {\r\n <mrx-badge customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n }\r\n </div>\r\n\r\n @if (isSwitch) {\r\n <mrx-switch\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n }\r\n\r\n @if (isCheckbox) {\r\n <mrx-checkbox\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n }\r\n\r\n @if (linkText) {\r\n <mrx-link\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >\r\n {{ linkText }}\r\n </mrx-link>\r\n }\r\n</div>\r\n\r\n@if (tooltipService.getTooltip) {\r\n <mrx-tooltip\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip>\r\n}\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"] }]
95
95
  }], ctorParameters: () => [{ type: i1.TooltipService }], propDecorators: { requiredHidden: [{
96
96
  type: Input
97
97
  }], required: [{
@@ -154,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
154
154
  }], clickedLink: [{
155
155
  type: Output
156
156
  }] } });
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"label.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/label/label.component.ts","../../../../../../projects/myrta-ui/src/lib/components/label/label.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EAEL,MAAM,EAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAEjF,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;;;;AAoBrE,MAAM,OAAO,cAAc;IA+DN;IA9DX,QAAQ,GAAG,EAAE,CAAA;IACb,sBAAsB,GAAG,KAAK,CAAA;IAC9B,gBAAgB,GAAG,KAAK,CAAA;IAEhB,cAAc,GAAG,KAAK,CAAC;IACvB,QAAQ,GAAG,KAAK,CAAC;IACjB,SAAS,GAAG,IAAI,CAAC;IACjB,QAAQ,GAAG,KAAK,CAAC;IACjB,WAAW,GAAG,EAAE,CAAC;IACjB,KAAK,GAAG,EAAE,CAAC;IACX,aAAa,GAAG,EAAE,CAAC;IACnB,mBAAmB,GAA6B,SAAS,CAAC;IAC1D,YAAY,GAAG,KAAK,CAAC;IACrB,iBAAiB,GAAG,EAAE,CAAC;IAEvC,SAAS;IACO,QAAQ,GAAG,KAAK,CAAC;IACjB,WAAW,GAAG,EAAE,CAAC;IACjB,WAAW,GAAG,KAAK,CAAC;IAEpC,WAAW;IACK,UAAU,GAAG,KAAK,CAAC;IACnB,aAAa,GAAG,EAAE,CAAC;IACnB,aAAa,GAAG,KAAK,CAAC;IAEtC,UAAU;IACM,OAAO,GAAuB,CAAC,CAAC;IAEhD,OAAO;IACE,QAAQ,GAAG,EAAE,CAAC;IACd,WAAW,GAAG,IAAI,CAAC;IACnB,QAAQ,GAAc,QAAQ,CAAC;IAC/B,cAAc,GAAG,IAAI,CAAC;IACtB,IAAI,GAAG,GAAG,CAAC;IAEX,WAAW,GAAwB,WAAW,CAAC;IAE3B,WAAW,CAA2B;IAElD,iBAAiB,GAAG,IAAI,YAAY,EAAoB,CAAC;IACzD,mBAAmB,GAAG,IAAI,YAAY,EAAsB,CAAC;IAE9E,IACI,OAAO,CAAC,OAAe;QACzB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,cAAc,CAAC,UAAU,GAAG,OAAO,CAAA;IAC1C,CAAC;IAED,IACI,qBAAqB,CAAC,KAAc;QACtC,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,cAAc,CAAC,4BAA4B,CAAC,KAAK,CAAC,CAAA;IACzD,CAAC;IAED,IACI,eAAe,CAAC,KAAc;QAChC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,cAAc,CAAC,gBAAgB,GAAG,KAAK,CAAA;IAC9C,CAAC;IAES,WAAW,GAA6B,IAAI,YAAY,EAAc,CAAC;IAEjF,YAAmB,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;IAAI,CAAC;IAEtD,IAAW,UAAU;QACnB,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;IACjC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC9E,CAAC;IAEM,aAAa,CAAC,KAAiB;QACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;wGA3EU,cAAc;4FAAd,cAAc,y4BAHd,CAAC,cAAc,CAAC,kIC7B7B,0kEAiEA,qqGD5Cc;YACV,OAAO,CAAC,WAAW,EAAE;gBACnB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC3E,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,eAAe,EAAE,CAAC,EAAE,CAAC,CAAC;gBACrE,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;gBACpD,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;aACrD,CAAC;SACH;;4FAIU,cAAc;kBAf1B,SAAS;+BACE,WAAW,cAGT;wBACV,OAAO,CAAC,WAAW,EAAE;4BACnB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC;4BAC3E,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,eAAe,EAAE,CAAC,EAAE,CAAC,CAAC;4BACrE,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;4BACpD,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;yBACrD,CAAC;qBACH,aACU,CAAC,cAAc,CAAC,mBACV,uBAAuB,CAAC,MAAM;mFAO/B,cAAc;sBAA7B,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBAGU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBAGU,UAAU;sBAAzB,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBAGU,OAAO;sBAAtB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEuB,WAAW;sBAAvC,YAAY;uBAAC,aAAa;gBAEV,iBAAiB;sBAAjC,MAAM;gBACU,mBAAmB;sBAAnC,MAAM;gBAGH,OAAO;sBADV,KAAK;gBAOF,qBAAqB;sBADxB,KAAK;gBAOF,eAAe;sBADlB,KAAK;gBAMI,WAAW;sBAApB,MAAM","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild, ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { TooltipTextPositionTypes, TooltipTriggerTypes } from '../tooltip/tooltip-trigger/tooltip-trigger.enum';\r\nimport { TooltipService } from '../tooltip/services/tooltip.service';\r\nimport { LinkTypes } from '../link/link.enum';\r\nimport { SwitchValueTypes } from '../form/switch/switch.enum';\r\nimport { CheckboxValueTypes } from '../form/checkbox/checkbox.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-label',\r\n  templateUrl: './label.component.html',\r\n  styleUrls: ['./label.component.less'],\r\n  animations: [\r\n    trigger('openClose', [\r\n      state('open', style({ height: '*', padding: '*', 'margin-bottom': '8px' })),\r\n      state('closed', style({ height: 0, padding: 0, 'margin-bottom': 0 })),\r\n      transition('open => closed', [animate('0.5s ease')]),\r\n      transition('closed => open', [animate('0.5s ease')]),\r\n    ]),\r\n  ],\r\n  providers: [TooltipService],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class LabelComponent implements OnInit {\r\n  private _tooltip = ''\r\n  private _tooltipInitialVisible = false\r\n  private _isSaveToStorage = false\r\n\r\n  @Input() public requiredHidden = false;\r\n  @Input() public required = false;\r\n  @Input() public boldLabel = true;\r\n  @Input() public disabled = false;\r\n  @Input() public placeholder = '';\r\n  @Input() public label = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public triggerTextPosition: TooltipTextPositionTypes = 'default';\r\n  @Input() public isPublicInfo = false;\r\n  @Input() public publicInfoTooltip = '';\r\n\r\n  // SWITCH\r\n  @Input() public isSwitch = false;\r\n  @Input() public switchLabel = '';\r\n  @Input() public switchValue = false;\r\n\r\n  // CHECKBOX\r\n  @Input() public isCheckbox = false;\r\n  @Input() public checkboxLabel = '';\r\n  @Input() public checkboxValue = false;\r\n\r\n  // COUNTER\r\n  @Input() public counter: number | undefined = 0;\r\n\r\n  // LINK\r\n  @Input() linkText = '';\r\n  @Input() linkPrevent = true;\r\n  @Input() linkType: LinkTypes = 'pseudo';\r\n  @Input() linkMonochrome = true;\r\n  @Input() href = '#';\r\n\r\n  @Input() triggerType: TooltipTriggerTypes = 'attention';\r\n\r\n  @ContentChild('customIcons') customIcons!: TemplateRef<ElementRef>;\r\n\r\n  @Output() public changeSwitchValue = new EventEmitter<SwitchValueTypes>();\r\n  @Output() public changeCheckboxValue = new EventEmitter<CheckboxValueTypes>();\r\n\r\n  @Input()\r\n  set tooltip(tooltip: string) {\r\n    this._tooltip = tooltip;\r\n    this.tooltipService.setTooltip = tooltip\r\n  }\r\n\r\n  @Input()\r\n  set tooltipInitialVisible(value: boolean) {\r\n    this._tooltipInitialVisible = value;\r\n    this.tooltipService.toggleTooltipVisibleFromCode(value)\r\n  }\r\n\r\n  @Input()\r\n  set isSaveToStorage(value: boolean) {\r\n    this._isSaveToStorage = value;\r\n    this.tooltipService.setSaveToStorage = value\r\n  }\r\n\r\n  @Output() clickedLink: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  constructor(public tooltipService: TooltipService) { }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses}`;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.tooltipService.initTooltip(this._tooltip, this._tooltipInitialVisible);\r\n  }\r\n\r\n  public onClickToLink(event: MouseEvent): void {\r\n    this.clickedLink.emit(event)\r\n  }\r\n}\r\n","<div class=\"mrx-label-wrapper mb-2\">\r\n  <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n    <label\r\n      [class]=\"getClasses\"\r\n      [class.required]=\"required\"\r\n      [class.bold-label]=\"boldLabel\"\r\n      class=\"mrx-label\"\r\n    >\r\n      <ng-content></ng-content>\r\n\r\n      <span *ngIf=\"required && !disabled && !requiredHidden\" class=\"required-active\">*</span>\r\n\r\n      <span\r\n        *ngIf=\"isPublicInfo\"\r\n        class=\"mrx-icon icon-megafon ml-1\"\r\n        [mrxCdkTooltip]=\"publicInfoTooltip\"\r\n      ></span>\r\n\r\n      <mrx-tooltip-trigger\r\n        customClasses=\"ml-1\"\r\n        *ngIf=\"tooltipService.getTooltip\"\r\n        (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n        [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n        [triggerTextPosition]=\"triggerTextPosition\"\r\n        [triggerType]=\"triggerType\"\r\n      ></mrx-tooltip-trigger>\r\n\r\n      <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n    </label>\r\n\r\n    <mrx-badge *ngIf=\"counter\" customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n  </div>\r\n\r\n  <mrx-switch\r\n    *ngIf=\"isSwitch\"\r\n    [boldLabel]=\"boldLabel\"\r\n    [label]=\"switchLabel\"\r\n    [ngModel]=\"switchValue\"\r\n    (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n  ></mrx-switch>\r\n\r\n  <mrx-checkbox\r\n    *ngIf=\"isCheckbox\"\r\n    [boldLabel]=\"boldLabel\"\r\n    [label]=\"checkboxLabel\"\r\n    [ngModel]=\"checkboxValue\"\r\n    (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n  ></mrx-checkbox>\r\n\r\n  <mrx-link\r\n    *ngIf=\"linkText\"\r\n    [prevent]=\"linkPrevent\"\r\n    [type]=\"linkType\"\r\n    [monochrome]=\"linkMonochrome\"\r\n    (click)=\"onClickToLink($event)\"\r\n  >{{ linkText }}</mrx-link>\r\n</div>\r\n\r\n<mrx-tooltip\r\n  *ngIf=\"tooltipService.getTooltip\"\r\n  [tooltip]=\"tooltipService.getTooltip\"\r\n  [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n  [triggerType]=\"triggerType\"\r\n></mrx-tooltip>\r\n\r\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"label.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/label/label.component.ts","../../../../../../projects/myrta-ui/src/lib/components/label/label.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild, ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { TooltipTextPositionTypes, TooltipTriggerTypes } from '../tooltip/tooltip-trigger/tooltip-trigger.enum';\r\nimport { TooltipService } from '../tooltip/services/tooltip.service';\r\nimport { LinkTypes } from '../link/link.enum';\r\nimport { SwitchValueTypes } from '../form/switch/switch.enum';\r\nimport { CheckboxValueTypes } from '../form/checkbox/checkbox.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-label',\r\n  templateUrl: './label.component.html',\r\n  styleUrls: ['./label.component.less'],\r\n  animations: [\r\n    trigger('openClose', [\r\n      state('open', style({ height: '*', padding: '*', 'margin-bottom': '8px' })),\r\n      state('closed', style({ height: 0, padding: 0, 'margin-bottom': 0 })),\r\n      transition('open => closed', [animate('0.5s ease')]),\r\n      transition('closed => open', [animate('0.5s ease')]),\r\n    ]),\r\n  ],\r\n  providers: [TooltipService],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class LabelComponent implements OnInit {\r\n  private _tooltip = ''\r\n  private _tooltipInitialVisible = false\r\n  private _isSaveToStorage = false\r\n\r\n  @Input() public requiredHidden = false;\r\n  @Input() public required = false;\r\n  @Input() public boldLabel = true;\r\n  @Input() public disabled = false;\r\n  @Input() public placeholder = '';\r\n  @Input() public label = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public triggerTextPosition: TooltipTextPositionTypes = 'default';\r\n  @Input() public isPublicInfo = false;\r\n  @Input() public publicInfoTooltip = '';\r\n\r\n  // SWITCH\r\n  @Input() public isSwitch = false;\r\n  @Input() public switchLabel = '';\r\n  @Input() public switchValue = false;\r\n\r\n  // CHECKBOX\r\n  @Input() public isCheckbox = false;\r\n  @Input() public checkboxLabel = '';\r\n  @Input() public checkboxValue = false;\r\n\r\n  // COUNTER\r\n  @Input() public counter: number | undefined = 0;\r\n\r\n  // LINK\r\n  @Input() linkText = '';\r\n  @Input() linkPrevent = true;\r\n  @Input() linkType: LinkTypes = 'pseudo';\r\n  @Input() linkMonochrome = true;\r\n  @Input() href = '#';\r\n\r\n  @Input() triggerType: TooltipTriggerTypes = 'attention';\r\n\r\n  @ContentChild('customIcons') customIcons!: TemplateRef<ElementRef>;\r\n\r\n  @Output() public changeSwitchValue = new EventEmitter<SwitchValueTypes>();\r\n  @Output() public changeCheckboxValue = new EventEmitter<CheckboxValueTypes>();\r\n\r\n  @Input()\r\n  set tooltip(tooltip: string) {\r\n    this._tooltip = tooltip;\r\n    this.tooltipService.setTooltip = tooltip\r\n  }\r\n\r\n  @Input()\r\n  set tooltipInitialVisible(value: boolean) {\r\n    this._tooltipInitialVisible = value;\r\n    this.tooltipService.toggleTooltipVisibleFromCode(value)\r\n  }\r\n\r\n  @Input()\r\n  set isSaveToStorage(value: boolean) {\r\n    this._isSaveToStorage = value;\r\n    this.tooltipService.setSaveToStorage = value\r\n  }\r\n\r\n  @Output() clickedLink: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  constructor(public tooltipService: TooltipService) { }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses}`;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.tooltipService.initTooltip(this._tooltip, this._tooltipInitialVisible);\r\n  }\r\n\r\n  public onClickToLink(event: MouseEvent): void {\r\n    this.clickedLink.emit(event)\r\n  }\r\n}\r\n","<div class=\"mrx-label-wrapper mb-2\">\r\n  <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n    <label\r\n      class=\"mrx-label\"\r\n      [class]=\"getClasses\"\r\n      [class.required]=\"required\"\r\n      [class.bold-label]=\"boldLabel\"\r\n    >\r\n      <ng-content></ng-content>\r\n\r\n      @if (required && !disabled && !requiredHidden) {\r\n        <span class=\"required-active\">*</span>\r\n      }\r\n\r\n      @if (isPublicInfo) {\r\n        <span class=\"mrx-icon icon-megafon ml-1\" [mrxCdkTooltip]=\"publicInfoTooltip\"></span>\r\n      }\r\n\r\n      @if (tooltipService.getTooltip) {\r\n        <mrx-tooltip-trigger\r\n          customClasses=\"ml-1\"\r\n          (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n          [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n          [triggerTextPosition]=\"triggerTextPosition\"\r\n          [triggerType]=\"triggerType\"\r\n        ></mrx-tooltip-trigger>\r\n      }\r\n\r\n      <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n    </label>\r\n\r\n    @if (counter) {\r\n      <mrx-badge customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n    }\r\n  </div>\r\n\r\n  @if (isSwitch) {\r\n    <mrx-switch\r\n      [boldLabel]=\"boldLabel\"\r\n      [label]=\"switchLabel\"\r\n      [ngModel]=\"switchValue\"\r\n      [disabled]=\"disabled\"\r\n      (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n    ></mrx-switch>\r\n  }\r\n\r\n  @if (isCheckbox) {\r\n    <mrx-checkbox\r\n      [boldLabel]=\"boldLabel\"\r\n      [label]=\"checkboxLabel\"\r\n      [ngModel]=\"checkboxValue\"\r\n      [disabled]=\"disabled\"\r\n      (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n    ></mrx-checkbox>\r\n  }\r\n\r\n  @if (linkText) {\r\n    <mrx-link\r\n      [prevent]=\"linkPrevent\"\r\n      [type]=\"linkType\"\r\n      [monochrome]=\"linkMonochrome\"\r\n      (click)=\"onClickToLink($event)\"\r\n    >\r\n      {{ linkText }}\r\n    </mrx-link>\r\n  }\r\n</div>\r\n\r\n@if (tooltipService.getTooltip) {\r\n  <mrx-tooltip\r\n    [tooltip]=\"tooltipService.getTooltip\"\r\n    [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n    [triggerType]=\"triggerType\"\r\n  ></mrx-tooltip>\r\n}\r\n\r\n"]}
@@ -110,7 +110,7 @@ export class PaginatorComponent {
110
110
  return item.id;
111
111
  }
112
112
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
113
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", dropdownPosition: "dropdownPosition", popupPosition: "popupPosition", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n @if (withPageSize) {\r\n <mrx-select\r\n [ngModel]=\"pageSize\"\r\n [size]=\"'medium'\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n [popupPosition]=\"popupPosition\"\r\n [singleChange]=\"true\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-select>\r\n }\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.SelectComponent, selector: "mrx-select", inputs: ["fields", "items", "multiple", "isLoading", "searchable", "clearable", "closable", "size", "bindValue", "bindLabel", "bindIcon", "emptyText", "placeholder", "searchPlaceholder", "multiCollapseCount", "isExtraOption", "extraOptionPlaceholder", "use", "sortIcon", "sortPlaceholder", "isFullWidthDropdown", "addOption", "customSearchFn", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange"], outputs: ["changed", "modelChange"] }] });
113
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", dropdownPosition: "dropdownPosition", popupPosition: "popupPosition", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n @if (withPageSize) {\r\n <mrx-select\r\n [ngModel]=\"pageSize\"\r\n [size]=\"'medium'\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n [popupPosition]=\"popupPosition\"\r\n [singleChange]=\"true\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-select>\r\n }\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.SelectComponent, selector: "mrx-select", inputs: ["fields", "items", "multiple", "isLoading", "searchable", "clearable", "closable", "size", "bindValue", "bindLabel", "bindIcon", "emptyText", "placeholder", "searchPlaceholder", "multiCollapseCount", "isExtraOption", "extraOptionPlaceholder", "use", "sortIcon", "sortPlaceholder", "isFullWidthDropdown", "withoutSelected", "addOption", "customSearchFn", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange"], outputs: ["changed", "modelChange"] }] });
114
114
  }
115
115
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, decorators: [{
116
116
  type: Component,
@@ -1417,7 +1417,7 @@ class LabelComponent {
1417
1417
  this.clickedLink.emit(event);
1418
1418
  }
1419
1419
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LabelComponent, deps: [{ token: TooltipService }], target: i0.ɵɵFactoryTarget.Component });
1420
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LabelComponent, selector: "mrx-label", inputs: { requiredHidden: "requiredHidden", required: "required", boldLabel: "boldLabel", disabled: "disabled", placeholder: "placeholder", label: "label", customClasses: "customClasses", triggerTextPosition: "triggerTextPosition", isPublicInfo: "isPublicInfo", publicInfoTooltip: "publicInfoTooltip", isSwitch: "isSwitch", switchLabel: "switchLabel", switchValue: "switchValue", isCheckbox: "isCheckbox", checkboxLabel: "checkboxLabel", checkboxValue: "checkboxValue", counter: "counter", linkText: "linkText", linkPrevent: "linkPrevent", linkType: "linkType", linkMonochrome: "linkMonochrome", href: "href", triggerType: "triggerType", tooltip: "tooltip", tooltipInitialVisible: "tooltipInitialVisible", isSaveToStorage: "isSaveToStorage" }, outputs: { changeSwitchValue: "changeSwitchValue", changeCheckboxValue: "changeCheckboxValue", clickedLink: "clickedLink" }, providers: [TooltipService], queries: [{ propertyName: "customIcons", first: true, predicate: ["customIcons"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n class=\"mrx-label\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n <span *ngIf=\"required && !disabled && !requiredHidden\" class=\"required-active\">*</span>\r\n\r\n <span\r\n *ngIf=\"isPublicInfo\"\r\n class=\"mrx-icon icon-megafon ml-1\"\r\n [mrxCdkTooltip]=\"publicInfoTooltip\"\r\n ></span>\r\n\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n *ngIf=\"tooltipService.getTooltip\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n <mrx-badge *ngIf=\"counter\" customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n </div>\r\n\r\n <mrx-switch\r\n *ngIf=\"isSwitch\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n\r\n <mrx-checkbox\r\n *ngIf=\"isCheckbox\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n\r\n <mrx-link\r\n *ngIf=\"linkText\"\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >{{ linkText }}</mrx-link>\r\n</div>\r\n\r\n<mrx-tooltip\r\n *ngIf=\"tooltipService.getTooltip\"\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n></mrx-tooltip>\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: TooltipComponent, selector: "mrx-tooltip", inputs: ["tooltip", "tooltipVisible", "tooltipInitiallyVisible", "triggerType"], outputs: ["visibilityChanged"] }, { kind: "component", type: TooltipTriggerComponent, selector: "mrx-tooltip-trigger", inputs: ["triggerTextPosition", "triggerType", "customClasses", "isVisibleTooltip"], outputs: ["toggleTooltip"] }, { kind: "component", type: SwitchComponent, selector: "mrx-switch", inputs: ["fields", "size", "type", "label", "boldLabel", "disabled", "readonly", "required", "customClasses", "leftText", "rightText"], outputs: ["changed", "modelChange"] }, { kind: "component", type: BadgeComponent, selector: "mrx-badge", inputs: ["type", "tag", "size", "color", "customColor", "text", "path", "customClasses", "target"], outputs: ["clicked"] }, { kind: "component", type: LinkComponent, selector: "mrx-link", inputs: ["href", "target", "routerLink", "queryParams", "type", "monochrome", "customClasses", "prevent", "size"], outputs: ["clicked"] }, { kind: "directive", type: CdkTooltipDirective, selector: "[mrxCdkTooltip]", inputs: ["mrxCdkTooltip", "tooltipActive", "autoCloseByScroll", "tooltipPosition", "tooltipMaxWidth"] }, { kind: "component", type: CheckboxComponent, selector: "mrx-checkbox", inputs: ["fields", "required", "boldLabel", "indeterminate", "disabled", "readonly", "label", "customClasses", "customWrapperClasses", "invalid", "checkInvalid", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changed", "modelChange"] }], animations: [
1420
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: LabelComponent, selector: "mrx-label", inputs: { requiredHidden: "requiredHidden", required: "required", boldLabel: "boldLabel", disabled: "disabled", placeholder: "placeholder", label: "label", customClasses: "customClasses", triggerTextPosition: "triggerTextPosition", isPublicInfo: "isPublicInfo", publicInfoTooltip: "publicInfoTooltip", isSwitch: "isSwitch", switchLabel: "switchLabel", switchValue: "switchValue", isCheckbox: "isCheckbox", checkboxLabel: "checkboxLabel", checkboxValue: "checkboxValue", counter: "counter", linkText: "linkText", linkPrevent: "linkPrevent", linkType: "linkType", linkMonochrome: "linkMonochrome", href: "href", triggerType: "triggerType", tooltip: "tooltip", tooltipInitialVisible: "tooltipInitialVisible", isSaveToStorage: "isSaveToStorage" }, outputs: { changeSwitchValue: "changeSwitchValue", changeCheckboxValue: "changeCheckboxValue", clickedLink: "clickedLink" }, providers: [TooltipService], queries: [{ propertyName: "customIcons", first: true, predicate: ["customIcons"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n class=\"mrx-label\"\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n @if (required && !disabled && !requiredHidden) {\r\n <span class=\"required-active\">*</span>\r\n }\r\n\r\n @if (isPublicInfo) {\r\n <span class=\"mrx-icon icon-megafon ml-1\" [mrxCdkTooltip]=\"publicInfoTooltip\"></span>\r\n }\r\n\r\n @if (tooltipService.getTooltip) {\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n }\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n @if (counter) {\r\n <mrx-badge customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n }\r\n </div>\r\n\r\n @if (isSwitch) {\r\n <mrx-switch\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n }\r\n\r\n @if (isCheckbox) {\r\n <mrx-checkbox\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n }\r\n\r\n @if (linkText) {\r\n <mrx-link\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >\r\n {{ linkText }}\r\n </mrx-link>\r\n }\r\n</div>\r\n\r\n@if (tooltipService.getTooltip) {\r\n <mrx-tooltip\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip>\r\n}\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i1$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: TooltipComponent, selector: "mrx-tooltip", inputs: ["tooltip", "tooltipVisible", "tooltipInitiallyVisible", "triggerType"], outputs: ["visibilityChanged"] }, { kind: "component", type: TooltipTriggerComponent, selector: "mrx-tooltip-trigger", inputs: ["triggerTextPosition", "triggerType", "customClasses", "isVisibleTooltip"], outputs: ["toggleTooltip"] }, { kind: "component", type: SwitchComponent, selector: "mrx-switch", inputs: ["fields", "size", "type", "label", "boldLabel", "disabled", "readonly", "required", "customClasses", "leftText", "rightText"], outputs: ["changed", "modelChange"] }, { kind: "component", type: BadgeComponent, selector: "mrx-badge", inputs: ["type", "tag", "size", "color", "customColor", "text", "path", "customClasses", "target"], outputs: ["clicked"] }, { kind: "component", type: LinkComponent, selector: "mrx-link", inputs: ["href", "target", "routerLink", "queryParams", "type", "monochrome", "customClasses", "prevent", "size"], outputs: ["clicked"] }, { kind: "directive", type: CdkTooltipDirective, selector: "[mrxCdkTooltip]", inputs: ["mrxCdkTooltip", "tooltipActive", "autoCloseByScroll", "tooltipPosition", "tooltipMaxWidth"] }, { kind: "component", type: CheckboxComponent, selector: "mrx-checkbox", inputs: ["fields", "required", "boldLabel", "indeterminate", "disabled", "readonly", "label", "customClasses", "customWrapperClasses", "invalid", "checkInvalid", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changed", "modelChange"] }], animations: [
1421
1421
  trigger('openClose', [
1422
1422
  state('open', style({ height: '*', padding: '*', 'margin-bottom': '8px' })),
1423
1423
  state('closed', style({ height: 0, padding: 0, 'margin-bottom': 0 })),
@@ -1435,7 +1435,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1435
1435
  transition('open => closed', [animate('0.5s ease')]),
1436
1436
  transition('closed => open', [animate('0.5s ease')]),
1437
1437
  ]),
1438
- ], providers: [TooltipService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n class=\"mrx-label\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n <span *ngIf=\"required && !disabled && !requiredHidden\" class=\"required-active\">*</span>\r\n\r\n <span\r\n *ngIf=\"isPublicInfo\"\r\n class=\"mrx-icon icon-megafon ml-1\"\r\n [mrxCdkTooltip]=\"publicInfoTooltip\"\r\n ></span>\r\n\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n *ngIf=\"tooltipService.getTooltip\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n <mrx-badge *ngIf=\"counter\" customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n </div>\r\n\r\n <mrx-switch\r\n *ngIf=\"isSwitch\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n\r\n <mrx-checkbox\r\n *ngIf=\"isCheckbox\"\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n\r\n <mrx-link\r\n *ngIf=\"linkText\"\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >{{ linkText }}</mrx-link>\r\n</div>\r\n\r\n<mrx-tooltip\r\n *ngIf=\"tooltipService.getTooltip\"\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n></mrx-tooltip>\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"] }]
1438
+ ], providers: [TooltipService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mrx-label-wrapper mb-2\">\r\n <div class=\"mrx-label-content d-flex align-items-start\" [class.mr-2]=\"isSwitch\">\r\n <label\r\n class=\"mrx-label\"\r\n [class]=\"getClasses\"\r\n [class.required]=\"required\"\r\n [class.bold-label]=\"boldLabel\"\r\n >\r\n <ng-content></ng-content>\r\n\r\n @if (required && !disabled && !requiredHidden) {\r\n <span class=\"required-active\">*</span>\r\n }\r\n\r\n @if (isPublicInfo) {\r\n <span class=\"mrx-icon icon-megafon ml-1\" [mrxCdkTooltip]=\"publicInfoTooltip\"></span>\r\n }\r\n\r\n @if (tooltipService.getTooltip) {\r\n <mrx-tooltip-trigger\r\n customClasses=\"ml-1\"\r\n (toggleTooltip)=\"tooltipService.toggleTooltipVisible()\"\r\n [isVisibleTooltip]=\"tooltipService.getTooltipVisible\"\r\n [triggerTextPosition]=\"triggerTextPosition\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip-trigger>\r\n }\r\n\r\n <ng-container *ngTemplateOutlet=\"customIcons\"></ng-container>\r\n </label>\r\n\r\n @if (counter) {\r\n <mrx-badge customClasses=\"ml-2\" type=\"circle\" size=\"small\">{{ counter }}</mrx-badge>\r\n }\r\n </div>\r\n\r\n @if (isSwitch) {\r\n <mrx-switch\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"switchLabel\"\r\n [ngModel]=\"switchValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-switch>\r\n }\r\n\r\n @if (isCheckbox) {\r\n <mrx-checkbox\r\n [boldLabel]=\"boldLabel\"\r\n [label]=\"checkboxLabel\"\r\n [ngModel]=\"checkboxValue\"\r\n [disabled]=\"disabled\"\r\n (ngModelChange)=\"changeCheckboxValue.emit($event)\"\r\n ></mrx-checkbox>\r\n }\r\n\r\n @if (linkText) {\r\n <mrx-link\r\n [prevent]=\"linkPrevent\"\r\n [type]=\"linkType\"\r\n [monochrome]=\"linkMonochrome\"\r\n (click)=\"onClickToLink($event)\"\r\n >\r\n {{ linkText }}\r\n </mrx-link>\r\n }\r\n</div>\r\n\r\n@if (tooltipService.getTooltip) {\r\n <mrx-tooltip\r\n [tooltip]=\"tooltipService.getTooltip\"\r\n [tooltipVisible]=\"tooltipService.getTooltipVisible\"\r\n [triggerType]=\"triggerType\"\r\n ></mrx-tooltip>\r\n}\r\n\r\n", styles: [".mrx-label-wrapper.mrx-label-wrapper{display:flex;align-items:flex-start;justify-content:space-between}.mrx-label.mrx-label{display:inline-block;min-height:20px;color:var(--neutral-text-primary)}.mrx-label.mrx-label:not(.mrx-label.mrx-label.bold-label){font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-label.mrx-label.bold-label{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height)}.mrx-label.mrx-label .required-active{font-family:var(--body-md-bold-font-family);font-size:var(--body-md-bold-font-size);font-weight:var(--body-md-bold-font-weight);line-height:var(--body-md-bold-line-height);color:var(--system-icon-negative);margin-left:var(--spacing-1);position:relative;display:inline-block}::ng-deep .mrx-label-wrapper .mrx-switch{white-space:nowrap}::ng-deep mrx-tooltip-trigger{display:inline-flex;align-items:center}\n"] }]
1439
1439
  }], ctorParameters: () => [{ type: TooltipService }], propDecorators: { requiredHidden: [{
1440
1440
  type: Input
1441
1441
  }], required: [{
@@ -3984,6 +3984,7 @@ class SelectComponent {
3984
3984
  sortIcon = null;
3985
3985
  sortPlaceholder = '';
3986
3986
  isFullWidthDropdown = true;
3987
+ withoutSelected = false;
3987
3988
  addOption;
3988
3989
  customSearchFn;
3989
3990
  disabled = false;
@@ -4018,7 +4019,12 @@ class SelectComponent {
4018
4019
  return `${SelectSizeEnum[this.size]} ${this.readonlyClass} ${this.checkValidClasses}`;
4019
4020
  }
4020
4021
  get getSelectedLabels() {
4021
- return this.innerItems.filter(i => i.__selected);
4022
+ if (this.withoutSelected) {
4023
+ return [];
4024
+ }
4025
+ else {
4026
+ return this.innerItems.filter(i => i.__selected);
4027
+ }
4022
4028
  }
4023
4029
  get filteredItems() {
4024
4030
  if (this.customSearchFn) {
@@ -4100,10 +4106,8 @@ class SelectComponent {
4100
4106
  return label;
4101
4107
  }
4102
4108
  writeValue(selected = []) {
4103
- if (selected !== null) {
4104
- this.originSelected = selected;
4105
- this._updateSelected(this.originItems, this.originSelected);
4106
- }
4109
+ this.originSelected = selected;
4110
+ this._updateSelected(this.originItems, this.originSelected);
4107
4111
  }
4108
4112
  changeTextValueEmpty() {
4109
4113
  this.form.initModelChanged(this.model);
@@ -4143,7 +4147,7 @@ class SelectComponent {
4143
4147
  this.onTouched = fn;
4144
4148
  }
4145
4149
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4146
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: SelectComponent, selector: "mrx-select", inputs: { fields: "fields", items: "items", multiple: "multiple", isLoading: "isLoading", searchable: "searchable", clearable: "clearable", closable: "closable", size: "size", bindValue: "bindValue", bindLabel: "bindLabel", bindIcon: "bindIcon", emptyText: "emptyText", placeholder: "placeholder", searchPlaceholder: "searchPlaceholder", multiCollapseCount: "multiCollapseCount", optionValidation: ["isExtraOption", "optionValidation"], extraOptionPlaceholder: "extraOptionPlaceholder", use: "use", sortIcon: "sortIcon", sortPlaceholder: "sortPlaceholder", isFullWidthDropdown: "isFullWidthDropdown", addOption: "addOption", customSearchFn: "customSearchFn", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
4150
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: SelectComponent, selector: "mrx-select", inputs: { fields: "fields", items: "items", multiple: "multiple", isLoading: "isLoading", searchable: "searchable", clearable: "clearable", closable: "closable", size: "size", bindValue: "bindValue", bindLabel: "bindLabel", bindIcon: "bindIcon", emptyText: "emptyText", placeholder: "placeholder", searchPlaceholder: "searchPlaceholder", multiCollapseCount: "multiCollapseCount", optionValidation: ["isExtraOption", "optionValidation"], extraOptionPlaceholder: "extraOptionPlaceholder", use: "use", sortIcon: "sortIcon", sortPlaceholder: "sortPlaceholder", isFullWidthDropdown: "isFullWidthDropdown", withoutSelected: "withoutSelected", addOption: "addOption", customSearchFn: "customSearchFn", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
4147
4151
  {
4148
4152
  provide: NG_VALUE_ACCESSOR,
4149
4153
  useExisting: forwardRef(() => SelectComponent),
@@ -4203,6 +4207,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4203
4207
  type: Input
4204
4208
  }], isFullWidthDropdown: [{
4205
4209
  type: Input
4210
+ }], withoutSelected: [{
4211
+ type: Input
4206
4212
  }], addOption: [{
4207
4213
  type: Input
4208
4214
  }], customSearchFn: [{
@@ -4350,7 +4356,7 @@ class PaginatorComponent {
4350
4356
  return item.id;
4351
4357
  }
4352
4358
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4353
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", dropdownPosition: "dropdownPosition", popupPosition: "popupPosition", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n @if (withPageSize) {\r\n <mrx-select\r\n [ngModel]=\"pageSize\"\r\n [size]=\"'medium'\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n [popupPosition]=\"popupPosition\"\r\n [singleChange]=\"true\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-select>\r\n }\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: SelectComponent, selector: "mrx-select", inputs: ["fields", "items", "multiple", "isLoading", "searchable", "clearable", "closable", "size", "bindValue", "bindLabel", "bindIcon", "emptyText", "placeholder", "searchPlaceholder", "multiCollapseCount", "isExtraOption", "extraOptionPlaceholder", "use", "sortIcon", "sortPlaceholder", "isFullWidthDropdown", "addOption", "customSearchFn", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange"], outputs: ["changed", "modelChange"] }] });
4359
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PaginatorComponent, selector: "mrx-paginator", inputs: { pageSizes: "pageSizes", currentPage: "currentPage", pageSize: "pageSize", total: "total", customClasses: "customClasses", isEmptyPaginator: "isEmptyPaginator", isPaginatorText: "isPaginatorText", paginatorText: "paginatorText", dropdownPosition: "dropdownPosition", popupPosition: "popupPosition", setPosition: ["position", "setPosition"], setWithPageSize: ["withPageSize", "setWithPageSize"] }, outputs: { dataStateChanged: "dataStateChanged" }, ngImport: i0, template: "<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n <ul class=\"mrx-paginator__list\">\r\n <li\r\n class=\"mrx-paginator__previous\"\r\n [class.disabled]=\"currentPage <= 1\"\r\n (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n </li>\r\n\r\n <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n <li\r\n class=\"mrx-paginator__item\"\r\n *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n (click)=\"onChangeCurrentPage(item.index)\"\r\n [class.active]=\"currentPage === item.index\"\r\n >\r\n {{item.index}}\r\n </li>\r\n\r\n <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n <li\r\n class=\"mrx-paginator__next\"\r\n [class.disabled]=\"currentPage >= getItems\"\r\n (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n </li>\r\n </ul>\r\n\r\n @if (withPageSize) {\r\n <mrx-select\r\n [ngModel]=\"pageSize\"\r\n [size]=\"'medium'\"\r\n [items]=\"pageSizes\"\r\n [clearable]=\"false\"\r\n [searchable]=\"false\"\r\n [popupPosition]=\"popupPosition\"\r\n [singleChange]=\"true\"\r\n (ngModelChange)=\"onChangePageSize($event)\"\r\n ></mrx-select>\r\n }\r\n\r\n <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n \u041E\u0442\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u044B {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} \u0438\u0437 {{total}}\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: [":host::ng-deep .mrx-paginator{display:flex;align-items:center;list-style:none;padding-left:0;gap:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container{padding-left:var(--spacing-4)}:host::ng-deep .mrx-paginator .mrx-input-select .ng-select .ng-select-container .ng-value-container{min-width:36px;padding:0!important;min-height:auto}:host::ng-deep .mrx-paginator ul{display:flex;align-items:center;justify-content:center;list-style:none;padding:0;margin:0;gap:var(--spacing-1)}:host::ng-deep .mrx-paginator ul li{display:flex;align-items:center;justify-content:center;cursor:pointer}:host::ng-deep .mrx-paginator .mrx-paginator__item{padding-left:var(--spacing-3);padding-right:var(--spacing-3);min-width:32px;min-height:32px;border-radius:4px;font-weight:400;font-size:16px;line-height:24px;transition:.2s}:host::ng-deep .mrx-paginator .mrx-paginator__item.active{background-color:var(--brand-bg-primary-default);color:#fff}:host::ng-deep .mrx-paginator .mrx-paginator__item.dots,:host::ng-deep .mrx-paginator .mrx-paginator__item.disabled{cursor:default}:host::ng-deep .mrx-paginator .mrx-paginator__item:not(.dots,.active):hover{background-color:var(--brand-bg-tertiary-hover)}:host::ng-deep .mrx-paginator .mrx-paginator__previous,:host::ng-deep .mrx-paginator .mrx-paginator__next{min-width:24px;min-height:24px}:host::ng-deep .mrx-paginator .mrx-paginator__previous.disabled .mrx-icon,:host::ng-deep .mrx-paginator .mrx-paginator__next.disabled .mrx-icon{color:var(--neutral-icon-disabled)}:host::ng-deep .mrx-paginator__text{font-size:16px;line-height:24px;color:var(--neutral-text-primary)}.mrx-paginator.mrx-paginator.paginator-centered{justify-content:center}.mrx-paginator.mrx-paginator.paginator-left{justify-content:flex-start}.mrx-paginator.mrx-paginator.paginator-right{justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: SelectComponent, selector: "mrx-select", inputs: ["fields", "items", "multiple", "isLoading", "searchable", "clearable", "closable", "size", "bindValue", "bindLabel", "bindIcon", "emptyText", "placeholder", "searchPlaceholder", "multiCollapseCount", "isExtraOption", "extraOptionPlaceholder", "use", "sortIcon", "sortPlaceholder", "isFullWidthDropdown", "withoutSelected", "addOption", "customSearchFn", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange"], outputs: ["changed", "modelChange"] }] });
4354
4360
  }
4355
4361
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, decorators: [{
4356
4362
  type: Component,