myrta-ui 17.0.63 → 17.0.64
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.
- package/esm2022/lib/components/form/select/helpers/get-inner-selected.helper.mjs +4 -3
- package/esm2022/lib/components/form/select/helpers/modify-origin-items.helper.mjs +3 -3
- package/esm2022/lib/components/form/select/select.component.mjs +1 -1
- package/fesm2022/myrta-ui.mjs +4 -4
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,11 +1,12 @@
|
|
|
1
|
+
import isEqual from 'lodash-es/isEqual';
|
|
1
2
|
export const getInnerSelected = (items, selected, bindValue) => {
|
|
2
3
|
return items.filter(i => {
|
|
3
4
|
if (bindValue) {
|
|
4
|
-
return selected.
|
|
5
|
+
return selected.find(x => isEqual(x, i[bindValue]));
|
|
5
6
|
}
|
|
6
7
|
else {
|
|
7
|
-
return selected.
|
|
8
|
+
return selected.find(x => isEqual(x, i));
|
|
8
9
|
}
|
|
9
10
|
});
|
|
10
11
|
};
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWlubmVyLXNlbGVjdGVkLmhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL3NlbGVjdC9oZWxwZXJzL2dldC1pbm5lci1zZWxlY3RlZC5oZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxPQUFPLE1BQU0sbUJBQW1CLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxLQUF3QixFQUFFLFFBQWUsRUFBRSxTQUF3QixFQUFxQixFQUFFO0lBQ3pILE9BQU8sS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRTtRQUN0QixJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ2QsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQ3JELENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQzFDLENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQTtBQUNKLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlbGVjdEl0ZW1Nb2RlbCB9IGZyb20gJy4uL21vZGVscy9zZWxlY3QtaXRlbS5tb2RlbCc7XHJcbmltcG9ydCBpc0VxdWFsIGZyb20gJ2xvZGFzaC1lcy9pc0VxdWFsJztcclxuXHJcbmV4cG9ydCBjb25zdCBnZXRJbm5lclNlbGVjdGVkID0gKGl0ZW1zOiBTZWxlY3RJdGVtTW9kZWxbXSwgc2VsZWN0ZWQ6IGFueVtdLCBiaW5kVmFsdWU6IHN0cmluZyB8IG51bGwpOiBTZWxlY3RJdGVtTW9kZWxbXSA9PiB7XHJcbiAgcmV0dXJuIGl0ZW1zLmZpbHRlcihpID0+IHtcclxuICAgIGlmIChiaW5kVmFsdWUpIHtcclxuICAgICAgcmV0dXJuIHNlbGVjdGVkLmZpbmQoeCA9PiBpc0VxdWFsKHgsIGlbYmluZFZhbHVlXSkpXHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICByZXR1cm4gc2VsZWN0ZWQuZmluZCh4ID0+IGlzRXF1YWwoeCwgaSkpXHJcbiAgICB9XHJcbiAgfSlcclxufVxyXG4iXX0=
|
|
@@ -12,10 +12,10 @@ export const modifyOriginItems = (selected, bindValue, bindLabel) => {
|
|
|
12
12
|
}
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
|
-
return bindLabel ? modifiedSelected
|
|
15
|
+
return bindLabel ? modifiedSelected.map((i) => i['label']) : modifiedSelected;
|
|
16
16
|
}
|
|
17
17
|
else {
|
|
18
|
-
return bindLabel ? selected
|
|
18
|
+
return bindLabel ? selected.map((i) => i['label']) : selected;
|
|
19
19
|
}
|
|
20
20
|
};
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kaWZ5LW9yaWdpbi1pdGVtcy5oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3QvaGVscGVycy9tb2RpZnktb3JpZ2luLWl0ZW1zLmhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLFFBQTJCLEVBQUUsU0FBd0IsRUFBRSxTQUF3QixFQUFFLEVBQUU7SUFDbkgsSUFBSSxTQUFTLEVBQUUsQ0FBQztRQUNkLE1BQU0sZ0JBQWdCLEdBQVEsRUFBRSxDQUFBO1FBRWhDLEtBQUssSUFBSSxJQUFJLElBQUksUUFBUSxFQUFFLENBQUM7WUFDMUIsS0FBSyxJQUFJLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztnQkFDckIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxJQUFJLEdBQUcsS0FBSyxTQUFTLEVBQUUsQ0FBQztvQkFDeEQsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFBO2dCQUN4QyxDQUFDO2dCQUVELElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUM7b0JBQ3BDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtvQkFDM0IsTUFBSztnQkFDUCxDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLFNBQVMsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBa0IsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFBO0lBQ2hHLENBQUM7U0FBTSxDQUFDO1FBQ04sT0FBTyxTQUFTLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUE7SUFDL0QsQ0FBQztBQUNILENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7U2VsZWN0SXRlbU1vZGVsfSBmcm9tIFwiLi4vbW9kZWxzL3NlbGVjdC1pdGVtLm1vZGVsXCI7XHJcblxyXG5leHBvcnQgY29uc3QgbW9kaWZ5T3JpZ2luSXRlbXMgPSAoc2VsZWN0ZWQ6IFNlbGVjdEl0ZW1Nb2RlbFtdLCBiaW5kVmFsdWU6IHN0cmluZyB8IG51bGwsIGJpbmRMYWJlbDogc3RyaW5nIHwgbnVsbCkgPT4ge1xyXG4gIGlmIChiaW5kVmFsdWUpIHtcclxuICAgIGNvbnN0IG1vZGlmaWVkU2VsZWN0ZWQ6IGFueSA9IFtdXHJcblxyXG4gICAgZm9yIChsZXQgaXRlbSBvZiBzZWxlY3RlZCkge1xyXG4gICAgICBmb3IgKGxldCBrZXkgaW4gaXRlbSkge1xyXG4gICAgICAgIGlmIChpdGVtLmhhc093blByb3BlcnR5KGJpbmRWYWx1ZSkgJiYga2V5ID09PSBiaW5kVmFsdWUpIHtcclxuICAgICAgICAgIG1vZGlmaWVkU2VsZWN0ZWQucHVzaChpdGVtW2JpbmRWYWx1ZV0pXHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBpZiAoIWl0ZW0uaGFzT3duUHJvcGVydHkoYmluZFZhbHVlKSkge1xyXG4gICAgICAgICAgbW9kaWZpZWRTZWxlY3RlZC5wdXNoKG51bGwpXHJcbiAgICAgICAgICBicmVha1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBiaW5kTGFiZWwgPyBtb2RpZmllZFNlbGVjdGVkLm1hcCgoaTogeyBsYWJlbDogYW55OyB9KSA9PiBpWydsYWJlbCddKSA6IG1vZGlmaWVkU2VsZWN0ZWRcclxuICB9IGVsc2Uge1xyXG4gICAgcmV0dXJuIGJpbmRMYWJlbCA/IHNlbGVjdGVkLm1hcCgoaSkgPT4gaVsnbGFiZWwnXSkgOiBzZWxlY3RlZFxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -246,4 +246,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
246
246
|
}], modelChange: [{
|
|
247
247
|
type: Output
|
|
248
248
|
}] } });
|
|
249
|
-
//# 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, EventEmitter,\r\n  forwardRef,\r\n  Input, 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 { 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 { Field } from '../../../services';\r\nimport { TemplateOutputModel } from './models/template-output.model';\r\nimport { cleanSelectItem } from './helpers/clean-selected-items.helper';\r\nimport { PositionEnum, PositionType } from '../../../enums/overlay';\r\nimport { getInnerSelected } from './helpers/get-inner-selected.helper';\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 {\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\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\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  @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\r\n  @Output() public changed: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() public modelChange: EventEmitter<any> = new EventEmitter<any>();\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[this.bindLabel]).includes(this.searchValue);\r\n      } else {\r\n        return String(i).includes(this.searchValue);\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  public onSelect(item: any) {\r\n    if (!this.multiple) {\r\n      this.innerItems = this.innerItems.map(i => {\r\n        return {...i, __selected: i.__id === item.__id ? !i.__selected : false};\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 onOpen(event: MouseEvent) {\r\n    event.stopPropagation();\r\n\r\n    if (this.isOpen) {\r\n      this.dropdown.togglePopup(false);\r\n    } else {\r\n      this.dropdown.togglePopup(true);\r\n    }\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 getCleanSelectItem(item: SelectInnerItemModel) {\r\n    return cleanSelectItem(item)\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) {\r\n      this.originSelected = selected\r\n      this.updateSelected(this.originItems, this.originSelected)\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\r\n    this.innerItems = getInnerItems(items, this.selected);\r\n  }\r\n\r\n  private updateValue(selectedItems: SelectInnerItemModel[]) {\r\n    const clearedSelected = getSelectedItems(selectedItems, this.bindValue, this.bindLabel);\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 class=\"mrx-select\"\r\n     [class]=\"getClasses\"\r\n     [class.mrx-input-error]=\"invalid\"\r\n     [class.-disabled]=\"disabled\"\r\n     [class.-readonly]=\"readonly\"\r\n>\r\n  <div class=\"mrx-select__wrapper\">\r\n    <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\" [popupPosition]=\"popupPosition\">\r\n      @if (getSelectedLabels.length) {\r\n        @if (multiple) {\r\n          <div class=\"mrx-select__input__values\">\r\n            @for (item of getSelectedLabels; track item; let first = $first; let last = $last) {\r\n              @if (labelTemplate) {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"labelTemplate\"\r\n                  [ngTemplateOutletContext]=\"{item, first, last, clear: clearItem}\"\r\n                ></ng-container>\r\n              } @else {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"defaultLabelTemplate\"\r\n                  [ngTemplateOutletContext]=\"{item, first, last}\"\r\n                ></ng-container>\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) {\r\n              {{ bindLabel ? item[bindLabel] : item['label'] }}\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 class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n            <span\r\n              class=\"mrx-icon icon-close\"\r\n              [class.icon-font-24]=\"size === 'large'\"\r\n              [class.icon-font-16]=\"size === 'medium'\"\r\n            ></span>\r\n          </div>\r\n        }\r\n        <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n            <span\r\n              class=\"mrx-icon\"\r\n              [class.icon-chevron-up]=\"isOpen\"\r\n              [class.icon-chevron-down]=\"!isOpen\"\r\n              [class.icon-font-24]=\"size === 'large'\"\r\n              [class.icon-font-16]=\"size === 'medium'\"\r\n            ></span>\r\n        </div>\r\n      </div>\r\n    </div>\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, first, last}\"\r\n            ></ng-container>\r\n          } @else {\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"defaultOptionTemplate\"\r\n              [ngTemplateOutletContext]=\"{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-text\r\n              [size]=\"'medium'\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              [(ngModel)]=\"searchValue\"\r\n            ></mrx-input-text>\r\n          </div>\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 (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  <mrx-error-message\r\n    *ngIf=\"invalid && isInvalidMessage\"\r\n    [invalidMessage]=\"invalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\" [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[bindLabel] : label['label'] }}</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[bindIcon]) {\r\n          <span class=\"mrx-icon icon-font-24\" [class]=\"option[bindIcon]\"></span>\r\n        }\r\n\r\n        <p>{{ bindLabel ? option[bindLabel] : option['label'] }}</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"]}
|
|
249
|
+
//# 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, EventEmitter,\r\n  forwardRef,\r\n  Input, 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 { 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 { Field } from '../../../services';\r\nimport { TemplateOutputModel } from './models/template-output.model';\r\nimport { cleanSelectItem } from './helpers/clean-selected-items.helper';\r\nimport { PositionEnum, PositionType } from '../../../enums/overlay';\r\nimport { getInnerSelected } from './helpers/get-inner-selected.helper';\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 {\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\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\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  @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\r\n  @Output() public changed: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() public modelChange: EventEmitter<any> = new EventEmitter<any>();\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[this.bindLabel]).includes(this.searchValue);\r\n      } else {\r\n        return String(i).includes(this.searchValue);\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  public onSelect(item: any) {\r\n    if (!this.multiple) {\r\n      this.innerItems = this.innerItems.map(i => {\r\n        return {...i, __selected: i.__id === item.__id ? !i.__selected : false};\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 onOpen(event: MouseEvent) {\r\n    event.stopPropagation();\r\n\r\n    if (this.isOpen) {\r\n      this.dropdown.togglePopup(false);\r\n    } else {\r\n      this.dropdown.togglePopup(true);\r\n    }\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 getCleanSelectItem(item: SelectInnerItemModel) {\r\n    return cleanSelectItem(item)\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) {\r\n      this.originSelected = selected\r\n      this.updateSelected(this.originItems, this.originSelected)\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);\r\n  }\r\n\r\n  private updateValue(selectedItems: SelectInnerItemModel[]) {\r\n    const clearedSelected = getSelectedItems(selectedItems, this.bindValue, this.bindLabel);\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 class=\"mrx-select\"\r\n     [class]=\"getClasses\"\r\n     [class.mrx-input-error]=\"invalid\"\r\n     [class.-disabled]=\"disabled\"\r\n     [class.-readonly]=\"readonly\"\r\n>\r\n  <div class=\"mrx-select__wrapper\">\r\n    <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\" [popupPosition]=\"popupPosition\">\r\n      @if (getSelectedLabels.length) {\r\n        @if (multiple) {\r\n          <div class=\"mrx-select__input__values\">\r\n            @for (item of getSelectedLabels; track item; let first = $first; let last = $last) {\r\n              @if (labelTemplate) {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"labelTemplate\"\r\n                  [ngTemplateOutletContext]=\"{item, first, last, clear: clearItem}\"\r\n                ></ng-container>\r\n              } @else {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"defaultLabelTemplate\"\r\n                  [ngTemplateOutletContext]=\"{item, first, last}\"\r\n                ></ng-container>\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) {\r\n              {{ bindLabel ? item[bindLabel] : item['label'] }}\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 class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n            <span\r\n              class=\"mrx-icon icon-close\"\r\n              [class.icon-font-24]=\"size === 'large'\"\r\n              [class.icon-font-16]=\"size === 'medium'\"\r\n            ></span>\r\n          </div>\r\n        }\r\n        <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n            <span\r\n              class=\"mrx-icon\"\r\n              [class.icon-chevron-up]=\"isOpen\"\r\n              [class.icon-chevron-down]=\"!isOpen\"\r\n              [class.icon-font-24]=\"size === 'large'\"\r\n              [class.icon-font-16]=\"size === 'medium'\"\r\n            ></span>\r\n        </div>\r\n      </div>\r\n    </div>\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, first, last}\"\r\n            ></ng-container>\r\n          } @else {\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"defaultOptionTemplate\"\r\n              [ngTemplateOutletContext]=\"{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-text\r\n              [size]=\"'medium'\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              [(ngModel)]=\"searchValue\"\r\n            ></mrx-input-text>\r\n          </div>\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 (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  <mrx-error-message\r\n    *ngIf=\"invalid && isInvalidMessage\"\r\n    [invalidMessage]=\"invalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\" [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[bindLabel] : label['label'] }}</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[bindIcon]) {\r\n          <span class=\"mrx-icon icon-font-24\" [class]=\"option[bindIcon]\"></span>\r\n        }\r\n\r\n        <p>{{ bindLabel ? option[bindLabel] : option['label'] }}</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"]}
|
package/fesm2022/myrta-ui.mjs
CHANGED
|
@@ -2477,10 +2477,10 @@ const modifyOriginItems = (selected, bindValue, bindLabel) => {
|
|
|
2477
2477
|
}
|
|
2478
2478
|
}
|
|
2479
2479
|
}
|
|
2480
|
-
return bindLabel ? modifiedSelected
|
|
2480
|
+
return bindLabel ? modifiedSelected.map((i) => i['label']) : modifiedSelected;
|
|
2481
2481
|
}
|
|
2482
2482
|
else {
|
|
2483
|
-
return bindLabel ? selected
|
|
2483
|
+
return bindLabel ? selected.map((i) => i['label']) : selected;
|
|
2484
2484
|
}
|
|
2485
2485
|
};
|
|
2486
2486
|
|
|
@@ -2508,10 +2508,10 @@ const getInnerItems = (items, selectedItems = []) => {
|
|
|
2508
2508
|
const getInnerSelected = (items, selected, bindValue) => {
|
|
2509
2509
|
return items.filter(i => {
|
|
2510
2510
|
if (bindValue) {
|
|
2511
|
-
return selected.
|
|
2511
|
+
return selected.find(x => isEqual(x, i[bindValue]));
|
|
2512
2512
|
}
|
|
2513
2513
|
else {
|
|
2514
|
-
return selected.
|
|
2514
|
+
return selected.find(x => isEqual(x, i));
|
|
2515
2515
|
}
|
|
2516
2516
|
});
|
|
2517
2517
|
};
|