myrta-ui 17.1.66 → 17.1.67

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.
@@ -57,6 +57,7 @@ export class SelectComponent {
57
57
  sortPlaceholder = '';
58
58
  isFullWidthDropdown = true;
59
59
  withoutSelected = false;
60
+ hideSelected = false;
60
61
  addOption;
61
62
  customSearchFn;
62
63
  disabled = false;
@@ -108,15 +109,30 @@ export class SelectComponent {
108
109
  }
109
110
  else {
110
111
  return this.innerItems.filter(i => {
111
- if (this.bindLabel) {
112
- return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
112
+ if (this.hideSelected) {
113
+ if (this.bindLabel) {
114
+ return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;
115
+ }
116
+ else {
117
+ if (i.__origin['label']) {
118
+ return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;
119
+ }
120
+ else {
121
+ return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;
122
+ }
123
+ }
113
124
  }
114
125
  else {
115
- if (i.__origin['label']) {
116
- return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
126
+ if (this.bindLabel) {
127
+ return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
117
128
  }
118
129
  else {
119
- return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
130
+ if (i.__origin['label']) {
131
+ return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
132
+ }
133
+ else {
134
+ return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
135
+ }
120
136
  }
121
137
  }
122
138
  });
@@ -221,7 +237,7 @@ export class SelectComponent {
221
237
  this.onTouched = fn;
222
238
  }
223
239
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
224
- 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", scrollContainer: "scrollContainer", scrollStrategy: "scrollStrategy" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
240
+ 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", hideSelected: "hideSelected", addOption: "addOption", customSearchFn: "customSearchFn", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange", scrollContainer: "scrollContainer", scrollStrategy: "scrollStrategy" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
225
241
  {
226
242
  provide: NG_VALUE_ACCESSOR,
227
243
  useExisting: forwardRef(() => SelectComponent),
@@ -283,6 +299,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
283
299
  type: Input
284
300
  }], withoutSelected: [{
285
301
  type: Input
302
+ }], hideSelected: [{
303
+ type: Input
286
304
  }], addOption: [{
287
305
  type: Input
288
306
  }], customSearchFn: [{
@@ -328,4 +346,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
328
346
  }], modelChange: [{
329
347
  type: Output
330
348
  }] } });
331
- //# 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, ElementRef,\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  @Input() scrollContainer?: ElementRef;\r\n  @Input() scrollStrategy: 'reposition' | 'close' = 'close';\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          [popupPosition]=\"popupPosition\"\r\n          [scrollContainerRef]=\"scrollContainer\"\r\n          [scrollStrategy]=\"scrollStrategy\"\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 [ngTemplateOutlet]=\"popupHeaderTemplate\"></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\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 [ngTemplateOutlet]=\"popupFooterTemplate\"></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"]}
349
+ //# 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, ElementRef,\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  @Input() hideSelected: 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  @Input() scrollContainer?: ElementRef;\r\n  @Input() scrollStrategy: 'reposition' | 'close' = 'close';\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.hideSelected) {\r\n          if (this.bindLabel) {\r\n            return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;\r\n          } else {\r\n            if (i.__origin['label']) {\r\n              return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;\r\n            } else {\r\n              return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;\r\n            }\r\n          }\r\n        } else {\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\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          [popupPosition]=\"popupPosition\"\r\n          [scrollContainerRef]=\"scrollContainer\"\r\n          [scrollStrategy]=\"scrollStrategy\"\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 [ngTemplateOutlet]=\"popupHeaderTemplate\"></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\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 [ngTemplateOutlet]=\"popupFooterTemplate\"></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"]}
@@ -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", "withoutSelected", "addOption", "customSearchFn", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange", "scrollContainer", "scrollStrategy"], 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", "hideSelected", "addOption", "customSearchFn", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange", "scrollContainer", "scrollStrategy"], 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,
@@ -4171,6 +4171,7 @@ class SelectComponent {
4171
4171
  sortPlaceholder = '';
4172
4172
  isFullWidthDropdown = true;
4173
4173
  withoutSelected = false;
4174
+ hideSelected = false;
4174
4175
  addOption;
4175
4176
  customSearchFn;
4176
4177
  disabled = false;
@@ -4222,15 +4223,30 @@ class SelectComponent {
4222
4223
  }
4223
4224
  else {
4224
4225
  return this.innerItems.filter(i => {
4225
- if (this.bindLabel) {
4226
- return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4226
+ if (this.hideSelected) {
4227
+ if (this.bindLabel) {
4228
+ return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;
4229
+ }
4230
+ else {
4231
+ if (i.__origin['label']) {
4232
+ return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;
4233
+ }
4234
+ else {
4235
+ return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase()) && !i.__selected;
4236
+ }
4237
+ }
4227
4238
  }
4228
4239
  else {
4229
- if (i.__origin['label']) {
4230
- return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4240
+ if (this.bindLabel) {
4241
+ return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4231
4242
  }
4232
4243
  else {
4233
- return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4244
+ if (i.__origin['label']) {
4245
+ return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4246
+ }
4247
+ else {
4248
+ return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4249
+ }
4234
4250
  }
4235
4251
  }
4236
4252
  });
@@ -4335,7 +4351,7 @@ class SelectComponent {
4335
4351
  this.onTouched = fn;
4336
4352
  }
4337
4353
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4338
- 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", scrollContainer: "scrollContainer", scrollStrategy: "scrollStrategy" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
4354
+ 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", hideSelected: "hideSelected", addOption: "addOption", customSearchFn: "customSearchFn", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange", scrollContainer: "scrollContainer", scrollStrategy: "scrollStrategy" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
4339
4355
  {
4340
4356
  provide: NG_VALUE_ACCESSOR,
4341
4357
  useExisting: forwardRef(() => SelectComponent),
@@ -4397,6 +4413,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4397
4413
  type: Input
4398
4414
  }], withoutSelected: [{
4399
4415
  type: Input
4416
+ }], hideSelected: [{
4417
+ type: Input
4400
4418
  }], addOption: [{
4401
4419
  type: Input
4402
4420
  }], customSearchFn: [{
@@ -4548,7 +4566,7 @@ class PaginatorComponent {
4548
4566
  return item.id;
4549
4567
  }
4550
4568
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4551
- 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.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: 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", "scrollContainer", "scrollStrategy"], outputs: ["changed", "modelChange"] }] });
4569
+ 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.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: 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", "hideSelected", "addOption", "customSearchFn", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange", "scrollContainer", "scrollStrategy"], outputs: ["changed", "modelChange"] }] });
4552
4570
  }
4553
4571
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, decorators: [{
4554
4572
  type: Component,