myrta-ui 17.1.12 → 17.1.13

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.
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWl0ZW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3QvbW9kZWxzL3NlbGVjdC1pdGVtLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNlbGVjdEl0ZW1Nb2RlbCB7XHJcbiAgW25hbWU6IHN0cmluZ106IGFueTtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQWRkT3B0aW9uRm4gPSAoKHRlcm06IHN0cmluZykgPT4gYW55KTtcclxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWl0ZW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3QvbW9kZWxzL3NlbGVjdC1pdGVtLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNlbGVjdEl0ZW1Nb2RlbCB7XHJcbiAgW25hbWU6IHN0cmluZ106IGFueTtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQWRkT3B0aW9uRm4gPSAoKHRlcm06IHN0cmluZykgPT4gYW55KTtcclxuXHJcbmV4cG9ydCB0eXBlIEN1c3RvbVNlYXJjaEZuID0gKHNlYXJjaFZhbHVlOiBzdHJpbmcsIGl0ZW06IFNlbGVjdEl0ZW1Nb2RlbCkgPT4gYm9vbGVhblxyXG4iXX0=
@@ -50,13 +50,14 @@ export class SelectComponent {
50
50
  placeholder = 'Выберите значение';
51
51
  searchPlaceholder = 'Введите значение';
52
52
  multiCollapseCount = null;
53
- addOption;
54
53
  optionValidation = null;
55
54
  extraOptionPlaceholder = 'Введите значение';
56
55
  use = 'default';
57
56
  sortIcon = null;
58
57
  sortPlaceholder = '';
59
58
  isFullWidthDropdown = true;
59
+ addOption;
60
+ customSearchFn;
60
61
  disabled = false;
61
62
  readonly = false;
62
63
  invalid = false;
@@ -92,19 +93,26 @@ export class SelectComponent {
92
93
  return this.innerItems.filter(i => i.__selected);
93
94
  }
94
95
  get filteredItems() {
95
- return this.innerItems.filter(i => {
96
- if (this.bindLabel) {
97
- return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
98
- }
99
- else {
100
- if (i.__origin['label']) {
101
- return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
96
+ if (this.customSearchFn) {
97
+ return this.innerItems.filter(item => {
98
+ return this.customSearchFn?.(this.searchValue, item.__origin) ?? false;
99
+ });
100
+ }
101
+ else {
102
+ return this.innerItems.filter(i => {
103
+ if (this.bindLabel) {
104
+ return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
102
105
  }
103
106
  else {
104
- return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
107
+ if (i.__origin['label']) {
108
+ return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
109
+ }
110
+ else {
111
+ return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
112
+ }
105
113
  }
106
- }
107
- });
114
+ });
115
+ }
108
116
  }
109
117
  get isInvalidMessage() {
110
118
  return !!this.invalidMessage || !!this.invalidMessage?.length;
@@ -207,7 +215,7 @@ export class SelectComponent {
207
215
  this.onTouched = fn;
208
216
  }
209
217
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
210
- 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", addOption: "addOption", optionValidation: ["isExtraOption", "optionValidation"], extraOptionPlaceholder: "extraOptionPlaceholder", use: "use", sortIcon: "sortIcon", sortPlaceholder: "sortPlaceholder", isFullWidthDropdown: "isFullWidthDropdown", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
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: [
211
219
  {
212
220
  provide: NG_VALUE_ACCESSOR,
213
221
  useExisting: forwardRef(() => SelectComponent),
@@ -254,8 +262,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
254
262
  type: Input
255
263
  }], multiCollapseCount: [{
256
264
  type: Input
257
- }], addOption: [{
258
- type: Input
259
265
  }], optionValidation: [{
260
266
  type: Input,
261
267
  args: ['isExtraOption']
@@ -269,6 +275,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
269
275
  type: Input
270
276
  }], isFullWidthDropdown: [{
271
277
  type: Input
278
+ }], addOption: [{
279
+ type: Input
280
+ }], customSearchFn: [{
281
+ type: Input
272
282
  }], disabled: [{
273
283
  type: Input
274
284
  }], readonly: [{
@@ -306,4 +316,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
306
316
  }], modelChange: [{
307
317
  type: Output
308
318
  }] } });
309
- //# 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, 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() addOption!: AddOptionFn;\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() 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    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  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"]}
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"]}
@@ -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", "addOption", "isExtraOption", "extraOptionPlaceholder", "use", "sortIcon", "sortPlaceholder", "isFullWidthDropdown", "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", "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,
@@ -3978,13 +3978,14 @@ class SelectComponent {
3978
3978
  placeholder = 'Выберите значение';
3979
3979
  searchPlaceholder = 'Введите значение';
3980
3980
  multiCollapseCount = null;
3981
- addOption;
3982
3981
  optionValidation = null;
3983
3982
  extraOptionPlaceholder = 'Введите значение';
3984
3983
  use = 'default';
3985
3984
  sortIcon = null;
3986
3985
  sortPlaceholder = '';
3987
3986
  isFullWidthDropdown = true;
3987
+ addOption;
3988
+ customSearchFn;
3988
3989
  disabled = false;
3989
3990
  readonly = false;
3990
3991
  invalid = false;
@@ -4020,19 +4021,26 @@ class SelectComponent {
4020
4021
  return this.innerItems.filter(i => i.__selected);
4021
4022
  }
4022
4023
  get filteredItems() {
4023
- return this.innerItems.filter(i => {
4024
- if (this.bindLabel) {
4025
- return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4026
- }
4027
- else {
4028
- if (i.__origin['label']) {
4029
- return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4024
+ if (this.customSearchFn) {
4025
+ return this.innerItems.filter(item => {
4026
+ return this.customSearchFn?.(this.searchValue, item.__origin) ?? false;
4027
+ });
4028
+ }
4029
+ else {
4030
+ return this.innerItems.filter(i => {
4031
+ if (this.bindLabel) {
4032
+ return String(i.__origin[this.bindLabel]).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4030
4033
  }
4031
4034
  else {
4032
- return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4035
+ if (i.__origin['label']) {
4036
+ return String(i.__origin['label']).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4037
+ }
4038
+ else {
4039
+ return String(i.__origin).toLowerCase().includes(this.searchValue.toLocaleLowerCase());
4040
+ }
4033
4041
  }
4034
- }
4035
- });
4042
+ });
4043
+ }
4036
4044
  }
4037
4045
  get isInvalidMessage() {
4038
4046
  return !!this.invalidMessage || !!this.invalidMessage?.length;
@@ -4135,7 +4143,7 @@ class SelectComponent {
4135
4143
  this.onTouched = fn;
4136
4144
  }
4137
4145
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4138
- 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", addOption: "addOption", optionValidation: ["isExtraOption", "optionValidation"], extraOptionPlaceholder: "extraOptionPlaceholder", use: "use", sortIcon: "sortIcon", sortPlaceholder: "sortPlaceholder", isFullWidthDropdown: "isFullWidthDropdown", disabled: "disabled", readonly: "readonly", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", popupPosition: "popupPosition", singleChange: "singleChange" }, outputs: { changed: "changed", modelChange: "modelChange" }, providers: [
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: [
4139
4147
  {
4140
4148
  provide: NG_VALUE_ACCESSOR,
4141
4149
  useExisting: forwardRef(() => SelectComponent),
@@ -4182,8 +4190,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4182
4190
  type: Input
4183
4191
  }], multiCollapseCount: [{
4184
4192
  type: Input
4185
- }], addOption: [{
4186
- type: Input
4187
4193
  }], optionValidation: [{
4188
4194
  type: Input,
4189
4195
  args: ['isExtraOption']
@@ -4197,6 +4203,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4197
4203
  type: Input
4198
4204
  }], isFullWidthDropdown: [{
4199
4205
  type: Input
4206
+ }], addOption: [{
4207
+ type: Input
4208
+ }], customSearchFn: [{
4209
+ type: Input
4200
4210
  }], disabled: [{
4201
4211
  type: Input
4202
4212
  }], readonly: [{
@@ -4340,7 +4350,7 @@ class PaginatorComponent {
4340
4350
  return item.id;
4341
4351
  }
4342
4352
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4343
- 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", "addOption", "isExtraOption", "extraOptionPlaceholder", "use", "sortIcon", "sortPlaceholder", "isFullWidthDropdown", "disabled", "readonly", "invalid", "invalidMessage", "checkInvalid", "popupPosition", "singleChange"], outputs: ["changed", "modelChange"] }] });
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"] }] });
4344
4354
  }
4345
4355
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, decorators: [{
4346
4356
  type: Component,