@colijnit/corecomponents_v12 257.1.22 → 258.1.1

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,3 +1,4 @@
1
+ import { __awaiter } from "tslib";
1
2
  import { Component, ElementRef, forwardRef, HostBinding, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
3
  import { BaseInputComponent } from '../base/base-input.component';
3
4
  import { CoreComponentsIcon } from '../../core/enum/core-components-icon.enum';
@@ -10,12 +11,16 @@ export class ListOfValuesComponent extends BaseInputComponent {
10
11
  super(...arguments);
11
12
  this.icons = CoreComponentsIcon;
12
13
  this.multiselect = false;
14
+ this.largeCollection = false;
13
15
  this.displayField = 'description';
14
16
  this.searchDisabled = false;
15
17
  this.showChips = true;
16
18
  this.isSelectOpen = false;
17
19
  this.state = 'default';
20
+ this.filterText = '';
18
21
  this.selectedModels = [];
22
+ this.filteredCollection = [];
23
+ this.isLoading = false;
19
24
  this._collection = [];
20
25
  }
21
26
  set model(value) {
@@ -50,6 +55,38 @@ export class ListOfValuesComponent extends BaseInputComponent {
50
55
  }
51
56
  this.selectedModel = model;
52
57
  }
58
+ onModelChange(text) {
59
+ this.isLoading = true;
60
+ clearTimeout(this.debounceTimeout);
61
+ this.debounceTimeout = setTimeout(() => {
62
+ this.applyFilter(text);
63
+ }, 300);
64
+ }
65
+ applyFilter(text) {
66
+ var _a, _b, _c;
67
+ return __awaiter(this, void 0, void 0, function* () {
68
+ if ((text === null || text === void 0 ? void 0 : text.length) < 3) {
69
+ yield new Promise(resolve => setTimeout(resolve, 300));
70
+ this.collection = undefined;
71
+ }
72
+ else {
73
+ yield new Promise(resolve => setTimeout(resolve, 300));
74
+ this.collection = yield this.collectionLoadFn(text);
75
+ }
76
+ this.filterText = text;
77
+ if (!this.collection) {
78
+ this.changeDetector.detectChanges();
79
+ this.isLoading = false;
80
+ return [];
81
+ }
82
+ this.filteredCollection = (_a = this.collection) === null || _a === void 0 ? void 0 : _a.filter(() => {
83
+ return true;
84
+ });
85
+ (((_b = this.filteredCollection) === null || _b === void 0 ? void 0 : _b.length) > 0 && ((_c = this.filterText) === null || _c === void 0 ? void 0 : _c.length) > 2) ? this.openPopup() : this.closePopup();
86
+ this.isLoading = false;
87
+ this.changeDetector.detectChanges();
88
+ });
89
+ }
53
90
  handleInputKeyDown(event) {
54
91
  if (event) {
55
92
  if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {
@@ -124,6 +161,9 @@ export class ListOfValuesComponent extends BaseInputComponent {
124
161
  }
125
162
  else {
126
163
  this.selectedModel = option[this.displayField];
164
+ if (this.largeCollection) {
165
+ this.filterText = option[this.displayField];
166
+ }
127
167
  }
128
168
  }
129
169
  this.model = option;
@@ -164,6 +204,9 @@ export class ListOfValuesComponent extends BaseInputComponent {
164
204
  else {
165
205
  if (this.model) {
166
206
  this.selectedModel = this.model[this.displayField];
207
+ if (this.largeCollection) {
208
+ this.filterText = this.model[this.displayField];
209
+ }
167
210
  }
168
211
  else {
169
212
  this.selectedModel = '';
@@ -175,39 +218,56 @@ ListOfValuesComponent.decorators = [
175
218
  { type: Component, args: [{
176
219
  selector: 'co-list-of-values',
177
220
  template: `
178
- <co-input-text aria-haspopup="listbox" [attr.aria-expanded]="isSelectOpen" aria-controls="lov-popup" role="combobox"
179
- class="no-focus-line"
180
- overlayParent
181
- #parentForOverlay="overlayParent" type="text" [id]="label"
182
- [model]="multiselect ? selectedModels : selectedModel"
183
- [placeholder]="label"
184
- [readonly]="readonly"
185
- [disabled]="disabled"
186
- [required]="required"
187
- [noClickFocus]="false"
188
- [leftIconData]="leftIconData"
189
- [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
190
- [showClearButton]="true"
191
- [useContent]="multiselect"
192
- [customHeight]="multiselect"
193
- [keepFocussed]="keepFocussed"
194
- (modelChange)="handleInputModelChange($event)"
195
- (click)="openPopup()"
196
- (rightIconClick)="toggleSelect()"
197
- (keydown)="handleInputKeyDown($event)"
198
- (clearIconClick)="clearModel($event)"
199
- (blur)="checkModel()"
200
- >
201
- <ng-container *ngIf="multiselect && showChips">
202
- <div class="multiselect-chips-wrapper">
203
- <div class="chips" *ngFor="let chip of model">
204
- <span class="chips-description" [textContent]="chip[displayField]"></span>
205
- <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
206
- </div>
207
- </div>
208
- </ng-container>
209
- </co-input-text>
210
- `,
221
+ <co-input-text
222
+ *ngIf="!largeCollection"
223
+ aria-haspopup="listbox"
224
+ [attr.aria-expanded]="isSelectOpen"
225
+ aria-controls="lov-popup"
226
+ role="combobox"
227
+ class="no-focus-line"
228
+ overlayParent
229
+ #parentForOverlay="overlayParent"
230
+ type="text"
231
+ [id]="label"
232
+ [model]="multiselect ? selectedModels : selectedModel"
233
+ [placeholder]="label"
234
+ [readonly]="readonly"
235
+ [disabled]="disabled"
236
+ [required]="required"
237
+ [noClickFocus]="false"
238
+ [leftIconData]="leftIconData"
239
+ [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
240
+ [showClearButton]="true"
241
+ [useContent]="multiselect"
242
+ [customHeight]="multiselect"
243
+ [keepFocussed]="keepFocussed"
244
+ (modelChange)="handleInputModelChange($event)"
245
+ (click)="openPopup()"
246
+ (rightIconClick)="toggleSelect()"
247
+ (keydown)="handleInputKeyDown($event)"
248
+ (clearIconClick)="clearModel($event)"
249
+ (blur)="checkModel()">
250
+ <ng-container *ngIf="multiselect && showChips">
251
+ <div class="multiselect-chips-wrapper">
252
+ <div class="chips" *ngFor="let chip of model">
253
+ <span class="chips-description" [textContent]="chip[displayField]"></span>
254
+ <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
255
+ </div>
256
+ </div>
257
+ </ng-container>
258
+ </co-input-text>
259
+
260
+ <co-input-text
261
+ *ngIf="largeCollection"
262
+ [model]="filterText"
263
+ [placeholder]="label"
264
+ [required]="required"
265
+ [disabled]="disabled"
266
+ [readonly]="readonly"
267
+ (modelChange)="onModelChange($event)">
268
+ </co-input-text>
269
+ <div *ngIf="isLoading" class="filter-loader"><span></span></div>
270
+ `,
211
271
  providers: [
212
272
  OverlayService,
213
273
  {
@@ -222,8 +282,10 @@ ListOfValuesComponent.propDecorators = {
222
282
  model: [{ type: Input }],
223
283
  parentForOverlay: [{ type: ViewChild, args: ['parentForOverlay', { read: ElementRef },] }],
224
284
  multiselect: [{ type: HostBinding, args: ['class.custom-height',] }, { type: HostBinding, args: ['class.multi-select',] }, { type: Input }],
285
+ largeCollection: [{ type: Input }],
225
286
  displayField: [{ type: Input }],
226
287
  collection: [{ type: Input }],
288
+ collectionLoadFn: [{ type: Input }],
227
289
  leftIconData: [{ type: Input }],
228
290
  searchPlaceholder: [{ type: Input }],
229
291
  label: [{ type: Input }],
@@ -232,4 +294,4 @@ ListOfValuesComponent.propDecorators = {
232
294
  showChips: [{ type: Input }],
233
295
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values',] }]
234
296
  };
235
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAgB,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,KAAK,EAAU,SAAS,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACxI,OAAO,EAAC,kBAAkB,EAAC,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAC,kBAAkB,EAAC,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAC,cAAc,EAAC,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAC,0BAA0B,EAAC,MAAM,kCAAkC,CAAC;AAC5E,OAAO,EAAC,WAAW,EAAC,MAAM,mCAAmC,CAAC;AAE9D,OAAO,EAAC,8CAA8C,EAAC,MAAM,iEAAiE,CAAC;AA+C/H,MAAM,OAAO,qBAAsB,SAAQ,kBAAuB;IA7ClE;;QA8CoB,UAAK,GAA8B,kBAAkB,CAAC;QAkB/D,gBAAW,GAAY,KAAK,CAAC;QAG7B,iBAAY,GAAW,aAAa,CAAC;QAwBrC,mBAAc,GAAY,KAAK,CAAC;QAGhC,cAAS,GAAY,IAAI,CAAC;QAO1B,iBAAY,GAAY,KAAK,CAAC;QAC9B,UAAK,GAAW,SAAS,CAAC;QAE1B,mBAAc,GAAa,EAAE,CAAC;QAE7B,gBAAW,GAAU,EAAE,CAAC;IA+IpC,CAAC;IAzMG,IACW,KAAK,CAAC,KAAU;QACvB,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC7B,CAAC;IAED,IAAW,KAAK;QACZ,OAAO,KAAK,CAAC,KAAK,CAAC;IACvB,CAAC;IAaD,IACW,UAAU,CAAC,KAAY;QAC9B,IAAI,CAAC,WAAW,GAAG,KAAK,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAqBM,SAAS;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAWD,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC7B,CAAC;IAEM,sBAAsB,CAAC,KAAa;QACvC,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC5B,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,UAAU,GAAG,KAAK,CAAC;SAC1D;aAAM;YACH,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,EAAE;gBAC9B,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,UAAU,GAAG,KAAK,CAAC;aAC1D;SACJ;QACD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC/B,CAAC;IAEM,kBAAkB,CAAC,KAAoB;QAC1C,IAAI,KAAK,EAAE;YACP,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE;gBAChF,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,OAAO,KAAK,CAAC;aAChB;YACD,IAAI,IAAI,CAAC,qBAAqB,EAAE;gBAC5B,QAAQ,KAAK,CAAC,IAAI,EAAE;oBAChB,KAAK,WAAW,CAAC,IAAI;wBACjB,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC;wBACvD,OAAO,KAAK,CAAC;oBACjB,KAAK,WAAW,CAAC,EAAE;wBACf,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;wBAC3D,OAAO,KAAK,CAAC;oBACjB,KAAK,WAAW,CAAC,KAAK;wBAClB,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,yBAAyB,EAAE,CAAC;wBAChE,OAAO,KAAK,CAAC;oBACjB,KAAK,WAAW,CAAC,GAAG;wBAChB,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,yBAAyB,EAAE,CAAC;iBACvE;aACJ;SACJ;IACL,CAAC;IAEM,UAAU,CAAC,KAAiB;QAC/B,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC7B,CAAC;IAEM,YAAY;QACf,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,OAAO;SACV;QACD,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;QACvC,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;aAAM;YACH,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;QACD,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IACpE,CAAC;IAEM,SAAS;QACZ,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,OAAO;SACV;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,0BAA0B,EAAE;YACzF,gBAAgB,EAAE,IAAI,CAAC,UAAU;YACjC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;SAC9B,EAAE;YACC,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;YAChD,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE;YACnC,OAAO,EAAE,CAAC,KAAoB,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;SACpE,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC7B,CAAC;IAEM,qBAAqB,CAAC,IAAS;QAClC,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,MAAM,GAAG,GAAW,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC;YAC1D,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;YAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrC;IACL,CAAC;IAEM,YAAY,CAAC,MAAW;QAC3B,IAAI,MAAM,EAAE;YACR,IAAI,IAAI,CAAC,WAAW,EAAE;gBAClB,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;aAC/D;iBAAM;gBACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAClD;SACJ;QACD,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAEM,UAAU;QACb,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAChE,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAAC;QACvC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACzB,CAAC;IAEM,UAAU;QACb,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,UAAU,EAAE;YAC5D,MAAM,KAAK,GAAQ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,CAAC,aAAa,CAAC,CAAC;YAC1F,IAAI,KAAK,EAAE;gBACP,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;aACtB;iBAAM;gBACH,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;aAC1B;YACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrC;IACL,CAAC;IAEO,iBAAiB;QACrB,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,IAAI,CAAC,KAAK,EAAE;gBACZ,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;gBAC/B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;oBACnB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;gBACnD,CAAC,CAAC,CAAC;aACN;iBAAM;gBACH,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;aAClC;SACJ;aAAM;YACH,IAAI,IAAI,CAAC,KAAK,EAAE;gBACZ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACtD;iBAAM;gBACH,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;aAC3B;SACJ;IACL,CAAC;;;YAxPJ,SAAS,SAAC;gBACP,QAAQ,EAAE,mBAAmB;gBAC7B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAiCT;gBACD,SAAS,EAAE;oBACP,cAAc;oBACd;wBACI,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;qBACvD;iBACJ;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;oBAII,KAAK;+BAUL,SAAS,SAAC,kBAAkB,EAAE,EAAC,IAAI,EAAE,UAAU,EAAC;0BAGhD,WAAW,SAAC,qBAAqB,cACjC,WAAW,SAAC,oBAAoB,cAChC,KAAK;2BAGL,KAAK;yBAGL,KAAK;2BASL,KAAK;gCAGL,KAAK;oBAGL,KAAK;6BAGL,KAAK;6BAGL,KAAK;wBAGL,KAAK;wBAGL,WAAW,SAAC,yBAAyB","sourcesContent":["import {Component, ComponentRef, ElementRef, forwardRef, HostBinding, Input, OnInit, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {ListOfValuesPopupComponent} from './list-of-values-popup.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\n\r\n@Component({\r\n    selector: 'co-list-of-values',\r\n    template: `\r\n        <co-input-text aria-haspopup=\"listbox\" [attr.aria-expanded]=\"isSelectOpen\" aria-controls=\"lov-popup\" role=\"combobox\"\r\n                       class=\"no-focus-line\"\r\n                       overlayParent\r\n                       #parentForOverlay=\"overlayParent\" type=\"text\" [id]=\"label\"\r\n                       [model]=\"multiselect ? selectedModels : selectedModel\"\r\n                       [placeholder]=\"label\"\r\n                       [readonly]=\"readonly\"\r\n                       [disabled]=\"disabled\"\r\n                       [required]=\"required\"\r\n                       [noClickFocus]=\"false\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [rightIcon]=\"isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular\"\r\n                       [showClearButton]=\"true\"\r\n                       [useContent]=\"multiselect\"\r\n                       [customHeight]=\"multiselect\"\r\n                       [keepFocussed]=\"keepFocussed\"\r\n                       (modelChange)=\"handleInputModelChange($event)\"\r\n                       (click)=\"openPopup()\"\r\n                       (rightIconClick)=\"toggleSelect()\"\r\n                       (keydown)=\"handleInputKeyDown($event)\"\r\n                       (clearIconClick)=\"clearModel($event)\"\r\n                       (blur)=\"checkModel()\"\r\n        >\r\n            <ng-container *ngIf=\"multiselect && showChips\">\r\n                <div class=\"multiselect-chips-wrapper\">\r\n                    <div class=\"chips\" *ngFor=\"let chip of model\">\r\n                        <span class=\"chips-description\" [textContent]=\"chip[displayField]\"></span>\r\n                        <co-icon class=\"remove-chip-icon\" [icon]=\"icons.CrossSkinny\" (click)=\"removeOptionFromModel(chip)\"></co-icon>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n        </co-input-text>\r\n    `,\r\n    providers: [\r\n        OverlayService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => ListOfValuesComponent)\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesComponent extends BaseInputComponent<any> implements OnInit {\r\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n    @Input()\r\n    public set model(value: any) {\r\n        super.model = value;\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public get model(): any {\r\n        return super.model;\r\n    }\r\n\r\n    @ViewChild('parentForOverlay', {read: ElementRef})\r\n    public parentForOverlay: ElementRef;\r\n\r\n    @HostBinding('class.custom-height')\r\n    @HostBinding('class.multi-select')\r\n    @Input()\r\n    public multiselect: boolean = false;\r\n\r\n    @Input()\r\n    public displayField: string = 'description';\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Input()\r\n    public leftIconData: SafeHtml | undefined;\r\n\r\n    @Input()\r\n    public searchPlaceholder: string;\r\n\r\n    @Input()\r\n    public label: string;\r\n\r\n    @Input()\r\n    public customCssClass: string;\r\n\r\n    @Input()\r\n    public searchDisabled: boolean = false;\r\n\r\n    @Input()\r\n    public showChips: boolean = true;\r\n\r\n    @HostBinding('class.co-list-of-values')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public isSelectOpen: boolean = false;\r\n    public state: string = 'default';\r\n    public selectedModel: string;\r\n    public selectedModels: string[] = [];\r\n\r\n    private _collection: any[] = [];\r\n\r\n    private _lovPopupComponentRef: ComponentRef<any>;\r\n\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public handleInputModelChange(model: string): void {\r\n        if (this._lovPopupComponentRef) {\r\n            this._lovPopupComponentRef.instance.searchTerm = model;\r\n        } else {\r\n            if (!this.selectedModel && model) {\r\n                this.openPopup();\r\n                this._lovPopupComponentRef.instance.searchTerm = model;\r\n            }\r\n        }\r\n        this.selectedModel = model;\r\n    }\r\n\r\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n        if (event) {\r\n            if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {\r\n                this.openPopup();\r\n                return false;\r\n            }\r\n            if (this._lovPopupComponentRef) {\r\n                switch (event.code) {\r\n                    case KeyboardKey.Down:\r\n                        this._lovPopupComponentRef.instance.selectNextOption();\r\n                        return false;\r\n                    case KeyboardKey.Up:\r\n                        this._lovPopupComponentRef.instance.selectNextOption(true);\r\n                        return false;\r\n                    case KeyboardKey.Enter:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                        return false;\r\n                    case KeyboardKey.Tab:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public clearModel(event: MouseEvent): void {\r\n        this.setModel(undefined);\r\n    }\r\n\r\n    public toggleSelect(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = !this.isSelectOpen;\r\n        if (this.isSelectOpen) {\r\n            this.openPopup();\r\n        } else {\r\n            this.closePopup();\r\n        }\r\n        this.state = (this.state === 'default' ? 'rotated' : 'default');\r\n    }\r\n\r\n    public openPopup(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = true;\r\n        this._lovPopupComponentRef = this.overlayService.createComponent(ListOfValuesPopupComponent, {\r\n            parentForOverlay: this.elementRef,\r\n            customCssClass: this.customCssClass,\r\n            searchDisabled: this.searchDisabled,\r\n            searchPlaceholder: this.searchPlaceholder,\r\n            displayField: this.displayField,\r\n            multiselect: this.multiselect,\r\n            model: this.model,\r\n            collection: this.collection\r\n        }, {\r\n            modelChange: (value) => this.optionChosen(value),\r\n            closePopup: () => this.closePopup(),\r\n            keyDown: (event: KeyboardEvent) => this.handleInputKeyDown(event)\r\n        });\r\n        this.keepFocussed = true;\r\n    }\r\n\r\n    public removeOptionFromModel(chip: any): void {\r\n        if (this.multiselect) {\r\n            const idx: number = this.model.findIndex(m => m === chip);\r\n            this.model.splice(idx, 1);\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    public optionChosen(option: any): void {\r\n        if (option) {\r\n            if (this.multiselect) {\r\n                this.selectedModels = option.map(o => o[this.displayField]);\r\n            } else {\r\n                this.selectedModel = option[this.displayField];\r\n            }\r\n        }\r\n        this.model = option;\r\n        this.modelChange.emit(this.model);\r\n        this.detectChanges();\r\n    }\r\n\r\n    public closePopup(): void {\r\n        this.keepFocussed = false;\r\n        this.isSelectOpen = false;\r\n        this.overlayService.removeComponent(this._lovPopupComponentRef);\r\n        this._lovPopupComponentRef = undefined;\r\n        this.focused = false;\r\n    }\r\n\r\n    public checkModel(): void {\r\n        if (!this.multiselect && this.selectedModel && this.collection) {\r\n            const model: any = this.collection.find(c => c[this.displayField] === this.selectedModel);\r\n            if (model) {\r\n                this.model = model;\r\n            } else {\r\n                this.model = undefined;\r\n            }\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    private _setSelectedModel(): void {\r\n        if (this.multiselect) {\r\n            if (this.model) {\r\n                this.selectedModels.length = 0;\r\n                this.model.forEach(m => {\r\n                    this.selectedModels.push(m[this.displayField]);\r\n                });\r\n            } else {\r\n                this.selectedModels.length = 0;\r\n            }\r\n        } else {\r\n            if (this.model) {\r\n                this.selectedModel = this.model[this.displayField];\r\n            } else {\r\n                this.selectedModel = '';\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}
297
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ComponentRef, ElementRef, forwardRef, HostBinding, Input, OnInit, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {ListOfValuesPopupComponent} from './list-of-values-popup.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\n\r\n@Component({\r\n  selector: 'co-list-of-values',\r\n  template: `\r\n      <co-input-text\r\n              *ngIf=\"!largeCollection\"\r\n              aria-haspopup=\"listbox\"\r\n              [attr.aria-expanded]=\"isSelectOpen\"\r\n              aria-controls=\"lov-popup\"\r\n              role=\"combobox\"\r\n              class=\"no-focus-line\"\r\n              overlayParent\r\n              #parentForOverlay=\"overlayParent\"\r\n              type=\"text\"\r\n              [id]=\"label\"\r\n              [model]=\"multiselect ? selectedModels : selectedModel\"\r\n              [placeholder]=\"label\"\r\n              [readonly]=\"readonly\"\r\n              [disabled]=\"disabled\"\r\n              [required]=\"required\"\r\n              [noClickFocus]=\"false\"\r\n              [leftIconData]=\"leftIconData\"\r\n              [rightIcon]=\"isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular\"\r\n              [showClearButton]=\"true\"\r\n              [useContent]=\"multiselect\"\r\n              [customHeight]=\"multiselect\"\r\n              [keepFocussed]=\"keepFocussed\"\r\n              (modelChange)=\"handleInputModelChange($event)\"\r\n              (click)=\"openPopup()\"\r\n              (rightIconClick)=\"toggleSelect()\"\r\n              (keydown)=\"handleInputKeyDown($event)\"\r\n              (clearIconClick)=\"clearModel($event)\"\r\n              (blur)=\"checkModel()\">\r\n          <ng-container *ngIf=\"multiselect && showChips\">\r\n              <div class=\"multiselect-chips-wrapper\">\r\n                  <div class=\"chips\" *ngFor=\"let chip of model\">\r\n                      <span class=\"chips-description\" [textContent]=\"chip[displayField]\"></span>\r\n                      <co-icon class=\"remove-chip-icon\" [icon]=\"icons.CrossSkinny\" (click)=\"removeOptionFromModel(chip)\"></co-icon>\r\n                  </div>\r\n              </div>\r\n          </ng-container>\r\n      </co-input-text>\r\n      \r\n      <co-input-text\r\n              *ngIf=\"largeCollection\"\r\n              [model]=\"filterText\"\r\n              [placeholder]=\"label\"\r\n              [required]=\"required\"\r\n              [disabled]=\"disabled\"\r\n              [readonly]=\"readonly\"\r\n              (modelChange)=\"onModelChange($event)\">\r\n      </co-input-text>\r\n      <div *ngIf=\"isLoading\" class=\"filter-loader\"><span></span></div>\r\n  `,\r\n  providers: [\r\n    OverlayService,\r\n    {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => ListOfValuesComponent)\r\n    }\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ListOfValuesComponent extends BaseInputComponent<any> implements OnInit {\r\n  public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public set model(value: any) {\r\n    super.model = value;\r\n    this._setSelectedModel();\r\n  }\r\n\r\n  public get model(): any {\r\n    return super.model;\r\n  }\r\n\r\n  @ViewChild('parentForOverlay', {read: ElementRef})\r\n  public parentForOverlay: ElementRef;\r\n\r\n  @HostBinding('class.custom-height')\r\n  @HostBinding('class.multi-select')\r\n  @Input()\r\n  public multiselect: boolean = false;\r\n\r\n  @Input()\r\n  public largeCollection: boolean = false;\r\n\r\n  @Input()\r\n  public displayField: string = 'description';\r\n\r\n  @Input()\r\n  public set collection(value: any[]) {\r\n    this._collection = value || [];\r\n  }\r\n\r\n  public get collection(): any[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public collectionLoadFn: Function;\r\n\r\n  @Input()\r\n  public leftIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public searchPlaceholder: string;\r\n\r\n  @Input()\r\n  public label: string;\r\n\r\n  @Input()\r\n  public customCssClass: string;\r\n\r\n  @Input()\r\n  public searchDisabled: boolean = false;\r\n\r\n  @Input()\r\n  public showChips: boolean = true;\r\n\r\n  @HostBinding('class.co-list-of-values')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public isSelectOpen: boolean = false;\r\n  public state: string = 'default';\r\n  public filterText: string = '';\r\n  public selectedModel: string;\r\n  public selectedModels: string[] = [];\r\n  public filteredCollection: any[] = [];\r\n  public isLoading: boolean = false;\r\n\r\n  private _collection: any[] = [];\r\n  private debounceTimeout: any;\r\n\r\n  private _lovPopupComponentRef: ComponentRef<any>;\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    this._setSelectedModel();\r\n  }\r\n\r\n  public handleInputModelChange(model: string): void {\r\n    if (this._lovPopupComponentRef) {\r\n      this._lovPopupComponentRef.instance.searchTerm = model;\r\n    } else {\r\n      if (!this.selectedModel && model) {\r\n        this.openPopup();\r\n        this._lovPopupComponentRef.instance.searchTerm = model;\r\n      }\r\n    }\r\n    this.selectedModel = model;\r\n  }\r\n\r\n  public onModelChange(text: string) {\r\n    this.isLoading = true;\r\n    clearTimeout(this.debounceTimeout);\r\n    this.debounceTimeout = setTimeout(() => {\r\n      this.applyFilter(text);\r\n    }, 300);\r\n  }\r\n\r\n  public async applyFilter(text: string): Promise<[]> {\r\n    if (text?.length < 3) {\r\n      await new Promise(resolve => setTimeout(resolve, 300));\r\n      this.collection = undefined;\r\n    } else {\r\n      await new Promise(resolve => setTimeout(resolve, 300));\r\n      this.collection = await this.collectionLoadFn(text);\r\n    }\r\n\r\n    this.filterText = text;\r\n    if (!this.collection) {\r\n      this.changeDetector.detectChanges();\r\n      this.isLoading = false;\r\n      return [];\r\n    }\r\n\r\n    this.filteredCollection = this.collection?.filter(() => {\r\n      return true;\r\n    });\r\n    (this.filteredCollection?.length > 0 && this.filterText?.length > 2) ? this.openPopup() : this.closePopup();\r\n    this.isLoading = false;\r\n    this.changeDetector.detectChanges();\r\n  }\r\n\r\n  public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n    if (event) {\r\n      if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {\r\n        this.openPopup();\r\n        return false;\r\n      }\r\n      if (this._lovPopupComponentRef) {\r\n        switch (event.code) {\r\n          case KeyboardKey.Down:\r\n            this._lovPopupComponentRef.instance.selectNextOption();\r\n            return false;\r\n          case KeyboardKey.Up:\r\n            this._lovPopupComponentRef.instance.selectNextOption(true);\r\n            return false;\r\n          case KeyboardKey.Enter:\r\n            this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n            return false;\r\n          case KeyboardKey.Tab:\r\n            this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  public clearModel(event: MouseEvent): void {\r\n    this.setModel(undefined);\r\n  }\r\n\r\n  public toggleSelect(): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n    this.isSelectOpen = !this.isSelectOpen;\r\n    if (this.isSelectOpen) {\r\n      this.openPopup();\r\n    } else {\r\n      this.closePopup();\r\n    }\r\n    this.state = (this.state === 'default' ? 'rotated' : 'default');\r\n  }\r\n\r\n  public openPopup(): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n    this.isSelectOpen = true;\r\n    this._lovPopupComponentRef = this.overlayService.createComponent(ListOfValuesPopupComponent, {\r\n      parentForOverlay: this.elementRef,\r\n      customCssClass: this.customCssClass,\r\n      searchDisabled: this.searchDisabled,\r\n      searchPlaceholder: this.searchPlaceholder,\r\n      displayField: this.displayField,\r\n      multiselect: this.multiselect,\r\n      model: this.model,\r\n      collection: this.collection\r\n    }, {\r\n      modelChange: (value) => this.optionChosen(value),\r\n      closePopup: () => this.closePopup(),\r\n      keyDown: (event: KeyboardEvent) => this.handleInputKeyDown(event)\r\n    });\r\n    this.keepFocussed = true;\r\n  }\r\n\r\n  public removeOptionFromModel(chip: any): void {\r\n    if (this.multiselect) {\r\n      const idx: number = this.model.findIndex(m => m === chip);\r\n      this.model.splice(idx, 1);\r\n      this.modelChange.emit(this.model);\r\n    }\r\n  }\r\n\r\n  public optionChosen(option: any): void {\r\n    if (option) {\r\n      if (this.multiselect) {\r\n        this.selectedModels = option.map(o => o[this.displayField]);\r\n      } else {\r\n        this.selectedModel = option[this.displayField];\r\n        if (this.largeCollection) {\r\n          this.filterText = option[this.displayField];\r\n        }\r\n      }\r\n    }\r\n    this.model = option;\r\n    this.modelChange.emit(this.model);\r\n    this.detectChanges();\r\n  }\r\n\r\n  public closePopup(): void {\r\n    this.keepFocussed = false;\r\n    this.isSelectOpen = false;\r\n    this.overlayService.removeComponent(this._lovPopupComponentRef);\r\n    this._lovPopupComponentRef = undefined;\r\n    this.focused = false;\r\n  }\r\n\r\n  public checkModel(): void {\r\n    if (!this.multiselect && this.selectedModel && this.collection) {\r\n      const model: any = this.collection.find(c => c[this.displayField] === this.selectedModel);\r\n      if (model) {\r\n        this.model = model;\r\n      } else {\r\n        this.model = undefined;\r\n      }\r\n      this.modelChange.emit(this.model);\r\n    }\r\n  }\r\n\r\n  private _setSelectedModel(): void {\r\n    if (this.multiselect) {\r\n      if (this.model) {\r\n        this.selectedModels.length = 0;\r\n        this.model.forEach(m => {\r\n          this.selectedModels.push(m[this.displayField]);\r\n        });\r\n      } else {\r\n        this.selectedModels.length = 0;\r\n      }\r\n    } else {\r\n      if (this.model) {\r\n        this.selectedModel = this.model[this.displayField];\r\n        if (this.largeCollection) {\r\n          this.filterText = this.model[this.displayField];\r\n        }\r\n      } else {\r\n        this.selectedModel = '';\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
@@ -11170,12 +11170,16 @@ class ListOfValuesComponent extends BaseInputComponent {
11170
11170
  super(...arguments);
11171
11171
  this.icons = CoreComponentsIcon;
11172
11172
  this.multiselect = false;
11173
+ this.largeCollection = false;
11173
11174
  this.displayField = 'description';
11174
11175
  this.searchDisabled = false;
11175
11176
  this.showChips = true;
11176
11177
  this.isSelectOpen = false;
11177
11178
  this.state = 'default';
11179
+ this.filterText = '';
11178
11180
  this.selectedModels = [];
11181
+ this.filteredCollection = [];
11182
+ this.isLoading = false;
11179
11183
  this._collection = [];
11180
11184
  }
11181
11185
  set model(value) {
@@ -11210,6 +11214,38 @@ class ListOfValuesComponent extends BaseInputComponent {
11210
11214
  }
11211
11215
  this.selectedModel = model;
11212
11216
  }
11217
+ onModelChange(text) {
11218
+ this.isLoading = true;
11219
+ clearTimeout(this.debounceTimeout);
11220
+ this.debounceTimeout = setTimeout(() => {
11221
+ this.applyFilter(text);
11222
+ }, 300);
11223
+ }
11224
+ applyFilter(text) {
11225
+ var _a, _b, _c;
11226
+ return __awaiter(this, void 0, void 0, function* () {
11227
+ if ((text === null || text === void 0 ? void 0 : text.length) < 3) {
11228
+ yield new Promise(resolve => setTimeout(resolve, 300));
11229
+ this.collection = undefined;
11230
+ }
11231
+ else {
11232
+ yield new Promise(resolve => setTimeout(resolve, 300));
11233
+ this.collection = yield this.collectionLoadFn(text);
11234
+ }
11235
+ this.filterText = text;
11236
+ if (!this.collection) {
11237
+ this.changeDetector.detectChanges();
11238
+ this.isLoading = false;
11239
+ return [];
11240
+ }
11241
+ this.filteredCollection = (_a = this.collection) === null || _a === void 0 ? void 0 : _a.filter(() => {
11242
+ return true;
11243
+ });
11244
+ (((_b = this.filteredCollection) === null || _b === void 0 ? void 0 : _b.length) > 0 && ((_c = this.filterText) === null || _c === void 0 ? void 0 : _c.length) > 2) ? this.openPopup() : this.closePopup();
11245
+ this.isLoading = false;
11246
+ this.changeDetector.detectChanges();
11247
+ });
11248
+ }
11213
11249
  handleInputKeyDown(event) {
11214
11250
  if (event) {
11215
11251
  if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {
@@ -11284,6 +11320,9 @@ class ListOfValuesComponent extends BaseInputComponent {
11284
11320
  }
11285
11321
  else {
11286
11322
  this.selectedModel = option[this.displayField];
11323
+ if (this.largeCollection) {
11324
+ this.filterText = option[this.displayField];
11325
+ }
11287
11326
  }
11288
11327
  }
11289
11328
  this.model = option;
@@ -11324,6 +11363,9 @@ class ListOfValuesComponent extends BaseInputComponent {
11324
11363
  else {
11325
11364
  if (this.model) {
11326
11365
  this.selectedModel = this.model[this.displayField];
11366
+ if (this.largeCollection) {
11367
+ this.filterText = this.model[this.displayField];
11368
+ }
11327
11369
  }
11328
11370
  else {
11329
11371
  this.selectedModel = '';
@@ -11335,39 +11377,56 @@ ListOfValuesComponent.decorators = [
11335
11377
  { type: Component, args: [{
11336
11378
  selector: 'co-list-of-values',
11337
11379
  template: `
11338
- <co-input-text aria-haspopup="listbox" [attr.aria-expanded]="isSelectOpen" aria-controls="lov-popup" role="combobox"
11339
- class="no-focus-line"
11340
- overlayParent
11341
- #parentForOverlay="overlayParent" type="text" [id]="label"
11342
- [model]="multiselect ? selectedModels : selectedModel"
11343
- [placeholder]="label"
11344
- [readonly]="readonly"
11345
- [disabled]="disabled"
11346
- [required]="required"
11347
- [noClickFocus]="false"
11348
- [leftIconData]="leftIconData"
11349
- [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
11350
- [showClearButton]="true"
11351
- [useContent]="multiselect"
11352
- [customHeight]="multiselect"
11353
- [keepFocussed]="keepFocussed"
11354
- (modelChange)="handleInputModelChange($event)"
11355
- (click)="openPopup()"
11356
- (rightIconClick)="toggleSelect()"
11357
- (keydown)="handleInputKeyDown($event)"
11358
- (clearIconClick)="clearModel($event)"
11359
- (blur)="checkModel()"
11360
- >
11361
- <ng-container *ngIf="multiselect && showChips">
11362
- <div class="multiselect-chips-wrapper">
11363
- <div class="chips" *ngFor="let chip of model">
11364
- <span class="chips-description" [textContent]="chip[displayField]"></span>
11365
- <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
11366
- </div>
11367
- </div>
11368
- </ng-container>
11369
- </co-input-text>
11370
- `,
11380
+ <co-input-text
11381
+ *ngIf="!largeCollection"
11382
+ aria-haspopup="listbox"
11383
+ [attr.aria-expanded]="isSelectOpen"
11384
+ aria-controls="lov-popup"
11385
+ role="combobox"
11386
+ class="no-focus-line"
11387
+ overlayParent
11388
+ #parentForOverlay="overlayParent"
11389
+ type="text"
11390
+ [id]="label"
11391
+ [model]="multiselect ? selectedModels : selectedModel"
11392
+ [placeholder]="label"
11393
+ [readonly]="readonly"
11394
+ [disabled]="disabled"
11395
+ [required]="required"
11396
+ [noClickFocus]="false"
11397
+ [leftIconData]="leftIconData"
11398
+ [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
11399
+ [showClearButton]="true"
11400
+ [useContent]="multiselect"
11401
+ [customHeight]="multiselect"
11402
+ [keepFocussed]="keepFocussed"
11403
+ (modelChange)="handleInputModelChange($event)"
11404
+ (click)="openPopup()"
11405
+ (rightIconClick)="toggleSelect()"
11406
+ (keydown)="handleInputKeyDown($event)"
11407
+ (clearIconClick)="clearModel($event)"
11408
+ (blur)="checkModel()">
11409
+ <ng-container *ngIf="multiselect && showChips">
11410
+ <div class="multiselect-chips-wrapper">
11411
+ <div class="chips" *ngFor="let chip of model">
11412
+ <span class="chips-description" [textContent]="chip[displayField]"></span>
11413
+ <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
11414
+ </div>
11415
+ </div>
11416
+ </ng-container>
11417
+ </co-input-text>
11418
+
11419
+ <co-input-text
11420
+ *ngIf="largeCollection"
11421
+ [model]="filterText"
11422
+ [placeholder]="label"
11423
+ [required]="required"
11424
+ [disabled]="disabled"
11425
+ [readonly]="readonly"
11426
+ (modelChange)="onModelChange($event)">
11427
+ </co-input-text>
11428
+ <div *ngIf="isLoading" class="filter-loader"><span></span></div>
11429
+ `,
11371
11430
  providers: [
11372
11431
  OverlayService,
11373
11432
  {
@@ -11382,8 +11441,10 @@ ListOfValuesComponent.propDecorators = {
11382
11441
  model: [{ type: Input }],
11383
11442
  parentForOverlay: [{ type: ViewChild, args: ['parentForOverlay', { read: ElementRef },] }],
11384
11443
  multiselect: [{ type: HostBinding, args: ['class.custom-height',] }, { type: HostBinding, args: ['class.multi-select',] }, { type: Input }],
11444
+ largeCollection: [{ type: Input }],
11385
11445
  displayField: [{ type: Input }],
11386
11446
  collection: [{ type: Input }],
11447
+ collectionLoadFn: [{ type: Input }],
11387
11448
  leftIconData: [{ type: Input }],
11388
11449
  searchPlaceholder: [{ type: Input }],
11389
11450
  label: [{ type: Input }],