myrta-ui 17.0.85 → 17.0.86
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/select.component.mjs +9 -13
- package/esm2022/lib/components/form/select/select.enum.mjs +2 -0
- package/fesm2022/myrta-ui.mjs +7 -10
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/lib/components/form/select/select.component.d.ts +6 -6
- package/lib/components/form/select/select.enum.d.ts +5 -0
- package/package.json +1 -1
|
@@ -4,10 +4,9 @@ import { SelectSizeEnum } from './enums';
|
|
|
4
4
|
import { getSelectedItems } from './helpers/get-selected-items.helper';
|
|
5
5
|
import { getInnerItems } from './helpers/get-inner-items.helper';
|
|
6
6
|
import { v4 as uuidv4 } from 'uuid';
|
|
7
|
-
import { cleanSelectItem } from './helpers/clean-selected-items.helper';
|
|
8
7
|
import { PositionEnum } from '../../../enums/overlay';
|
|
9
8
|
import { getInnerSelected } from './helpers/get-inner-selected.helper';
|
|
10
|
-
import { MrxFormValidator } from
|
|
9
|
+
import { MrxFormValidator } from '../../../services';
|
|
11
10
|
import * as i0 from "@angular/core";
|
|
12
11
|
import * as i1 from "@angular/common";
|
|
13
12
|
import * as i2 from "@angular/forms";
|
|
@@ -36,7 +35,7 @@ export class SelectComponent {
|
|
|
36
35
|
fields = [];
|
|
37
36
|
set items(items) {
|
|
38
37
|
this.originItems = items;
|
|
39
|
-
this.
|
|
38
|
+
this._updateSelected(this.originItems, this.originSelected);
|
|
40
39
|
}
|
|
41
40
|
multiple = false;
|
|
42
41
|
isLoading = false;
|
|
@@ -136,7 +135,7 @@ export class SelectComponent {
|
|
|
136
135
|
});
|
|
137
136
|
}
|
|
138
137
|
this.dropdown.updatePopup();
|
|
139
|
-
this.
|
|
138
|
+
this._updateValue(this.innerItems);
|
|
140
139
|
}
|
|
141
140
|
clearItem(item) {
|
|
142
141
|
this.onUnselect(item);
|
|
@@ -147,20 +146,17 @@ export class SelectComponent {
|
|
|
147
146
|
i.__selected = false;
|
|
148
147
|
}
|
|
149
148
|
});
|
|
150
|
-
this.
|
|
149
|
+
this._updateValue(this.innerItems);
|
|
151
150
|
}
|
|
152
151
|
onClear(event) {
|
|
153
152
|
event.stopPropagation();
|
|
154
153
|
this.innerItems = this.innerItems.map(item => ({ ...item, __selected: false }));
|
|
155
154
|
this.dropdown.togglePopup(false);
|
|
156
|
-
this.
|
|
155
|
+
this._updateValue([]);
|
|
157
156
|
}
|
|
158
157
|
togglePopup(isOpen) {
|
|
159
158
|
this.isOpen = isOpen;
|
|
160
159
|
}
|
|
161
|
-
getCleanSelectItem(item) {
|
|
162
|
-
return cleanSelectItem(item);
|
|
163
|
-
}
|
|
164
160
|
asOption(option) {
|
|
165
161
|
return option;
|
|
166
162
|
}
|
|
@@ -170,7 +166,7 @@ export class SelectComponent {
|
|
|
170
166
|
writeValue(selected = []) {
|
|
171
167
|
if (selected) {
|
|
172
168
|
this.originSelected = selected;
|
|
173
|
-
this.
|
|
169
|
+
this._updateSelected(this.originItems, this.originSelected);
|
|
174
170
|
}
|
|
175
171
|
}
|
|
176
172
|
changeTextValueEmpty() {
|
|
@@ -183,7 +179,7 @@ export class SelectComponent {
|
|
|
183
179
|
this.changeTextValueEmpty();
|
|
184
180
|
}
|
|
185
181
|
}
|
|
186
|
-
|
|
182
|
+
_updateSelected(items = [], selected = []) {
|
|
187
183
|
if (this.multiple && Array.isArray(this.originSelected)) {
|
|
188
184
|
this.selected = getInnerSelected(items, selected, this.bindValue);
|
|
189
185
|
}
|
|
@@ -192,7 +188,7 @@ export class SelectComponent {
|
|
|
192
188
|
}
|
|
193
189
|
this.innerItems = getInnerItems(items, this.selected, this.bindValue);
|
|
194
190
|
}
|
|
195
|
-
|
|
191
|
+
_updateValue(selectedItems) {
|
|
196
192
|
const clearedSelected = getSelectedItems(selectedItems, this.bindValue);
|
|
197
193
|
const outputSelected = this.multiple ? clearedSelected : clearedSelected.length ? clearedSelected[0] : null;
|
|
198
194
|
this.changed.emit(outputSelected);
|
|
@@ -310,4 +306,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
310
306
|
}], modelChange: [{
|
|
311
307
|
type: Output
|
|
312
308
|
}] } });
|
|
313
|
-
//# 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 { 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\nimport { MrxFormValidator } from \"../../../services\";\r\n\r\n@Component({\r\n  selector: 'mrx-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrl: './select.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SelectComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SelectComponent implements ControlValueAccessor, OnInit {\r\n  public searchValue: string = '';\r\n  public isOpen: boolean = false;\r\n  public originSelected: any | any[] = [];\r\n  public originItems: SelectItemModel[] = [];\r\n  public selected: SelectItemModel[] = [];\r\n  public innerItems: SelectInnerItemModel[] = [];\r\n  public form = new MrxFormValidator();\r\n  public model = {\r\n    label: '',\r\n  }\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() set items(items: any[]) {\r\n    this.originItems = items;\r\n    this.updateSelected(this.originItems, this.originSelected)\r\n\r\n  }\r\n\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<any> = new EventEmitter<any>();\r\n  @Output() public modelChange: EventEmitter<any> = new EventEmitter<any>();\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  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 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  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"]}
|
|
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 { Field } from '../../../services';\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\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) {\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"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3Qvc2VsZWN0LmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIFNlbGVjdFZhbHVlVHlwZXMgPSBhbnkgfCBhbnlbXTtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU2VsZWN0VmFsdWVXaXRoSWQge1xyXG4gIHZhbHVlOiBTZWxlY3RWYWx1ZVR5cGVzLFxyXG4gIGlkOiBzdHJpbmdcclxufVxyXG4iXX0=
|
package/fesm2022/myrta-ui.mjs
CHANGED
|
@@ -4073,7 +4073,7 @@ class SelectComponent {
|
|
|
4073
4073
|
fields = [];
|
|
4074
4074
|
set items(items) {
|
|
4075
4075
|
this.originItems = items;
|
|
4076
|
-
this.
|
|
4076
|
+
this._updateSelected(this.originItems, this.originSelected);
|
|
4077
4077
|
}
|
|
4078
4078
|
multiple = false;
|
|
4079
4079
|
isLoading = false;
|
|
@@ -4173,7 +4173,7 @@ class SelectComponent {
|
|
|
4173
4173
|
});
|
|
4174
4174
|
}
|
|
4175
4175
|
this.dropdown.updatePopup();
|
|
4176
|
-
this.
|
|
4176
|
+
this._updateValue(this.innerItems);
|
|
4177
4177
|
}
|
|
4178
4178
|
clearItem(item) {
|
|
4179
4179
|
this.onUnselect(item);
|
|
@@ -4184,20 +4184,17 @@ class SelectComponent {
|
|
|
4184
4184
|
i.__selected = false;
|
|
4185
4185
|
}
|
|
4186
4186
|
});
|
|
4187
|
-
this.
|
|
4187
|
+
this._updateValue(this.innerItems);
|
|
4188
4188
|
}
|
|
4189
4189
|
onClear(event) {
|
|
4190
4190
|
event.stopPropagation();
|
|
4191
4191
|
this.innerItems = this.innerItems.map(item => ({ ...item, __selected: false }));
|
|
4192
4192
|
this.dropdown.togglePopup(false);
|
|
4193
|
-
this.
|
|
4193
|
+
this._updateValue([]);
|
|
4194
4194
|
}
|
|
4195
4195
|
togglePopup(isOpen) {
|
|
4196
4196
|
this.isOpen = isOpen;
|
|
4197
4197
|
}
|
|
4198
|
-
getCleanSelectItem(item) {
|
|
4199
|
-
return cleanSelectItem(item);
|
|
4200
|
-
}
|
|
4201
4198
|
asOption(option) {
|
|
4202
4199
|
return option;
|
|
4203
4200
|
}
|
|
@@ -4207,7 +4204,7 @@ class SelectComponent {
|
|
|
4207
4204
|
writeValue(selected = []) {
|
|
4208
4205
|
if (selected) {
|
|
4209
4206
|
this.originSelected = selected;
|
|
4210
|
-
this.
|
|
4207
|
+
this._updateSelected(this.originItems, this.originSelected);
|
|
4211
4208
|
}
|
|
4212
4209
|
}
|
|
4213
4210
|
changeTextValueEmpty() {
|
|
@@ -4220,7 +4217,7 @@ class SelectComponent {
|
|
|
4220
4217
|
this.changeTextValueEmpty();
|
|
4221
4218
|
}
|
|
4222
4219
|
}
|
|
4223
|
-
|
|
4220
|
+
_updateSelected(items = [], selected = []) {
|
|
4224
4221
|
if (this.multiple && Array.isArray(this.originSelected)) {
|
|
4225
4222
|
this.selected = getInnerSelected(items, selected, this.bindValue);
|
|
4226
4223
|
}
|
|
@@ -4229,7 +4226,7 @@ class SelectComponent {
|
|
|
4229
4226
|
}
|
|
4230
4227
|
this.innerItems = getInnerItems(items, this.selected, this.bindValue);
|
|
4231
4228
|
}
|
|
4232
|
-
|
|
4229
|
+
_updateValue(selectedItems) {
|
|
4233
4230
|
const clearedSelected = getSelectedItems(selectedItems, this.bindValue);
|
|
4234
4231
|
const outputSelected = this.multiple ? clearedSelected : clearedSelected.length ? clearedSelected[0] : null;
|
|
4235
4232
|
this.changed.emit(outputSelected);
|