@colijnit/corecomponents_v12 256.1.21 → 256.1.22

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,29 +218,35 @@ 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
- >
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()">
201
250
  <ng-container *ngIf="multiselect && showChips">
202
251
  <div class="multiselect-chips-wrapper">
203
252
  <div class="chips" *ngFor="let chip of model">
@@ -207,6 +256,17 @@ ListOfValuesComponent.decorators = [
207
256
  </div>
208
257
  </ng-container>
209
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>
210
270
  `,
211
271
  providers: [
212
272
  OverlayService,
@@ -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":"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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 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}\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"]}
@@ -11157,12 +11157,16 @@ class ListOfValuesComponent extends BaseInputComponent {
11157
11157
  super(...arguments);
11158
11158
  this.icons = CoreComponentsIcon;
11159
11159
  this.multiselect = false;
11160
+ this.largeCollection = false;
11160
11161
  this.displayField = 'description';
11161
11162
  this.searchDisabled = false;
11162
11163
  this.showChips = true;
11163
11164
  this.isSelectOpen = false;
11164
11165
  this.state = 'default';
11166
+ this.filterText = '';
11165
11167
  this.selectedModels = [];
11168
+ this.filteredCollection = [];
11169
+ this.isLoading = false;
11166
11170
  this._collection = [];
11167
11171
  }
11168
11172
  set model(value) {
@@ -11197,6 +11201,38 @@ class ListOfValuesComponent extends BaseInputComponent {
11197
11201
  }
11198
11202
  this.selectedModel = model;
11199
11203
  }
11204
+ onModelChange(text) {
11205
+ this.isLoading = true;
11206
+ clearTimeout(this.debounceTimeout);
11207
+ this.debounceTimeout = setTimeout(() => {
11208
+ this.applyFilter(text);
11209
+ }, 300);
11210
+ }
11211
+ applyFilter(text) {
11212
+ var _a, _b, _c;
11213
+ return __awaiter(this, void 0, void 0, function* () {
11214
+ if ((text === null || text === void 0 ? void 0 : text.length) < 3) {
11215
+ yield new Promise(resolve => setTimeout(resolve, 300));
11216
+ this.collection = undefined;
11217
+ }
11218
+ else {
11219
+ yield new Promise(resolve => setTimeout(resolve, 300));
11220
+ this.collection = yield this.collectionLoadFn(text);
11221
+ }
11222
+ this.filterText = text;
11223
+ if (!this.collection) {
11224
+ this.changeDetector.detectChanges();
11225
+ this.isLoading = false;
11226
+ return [];
11227
+ }
11228
+ this.filteredCollection = (_a = this.collection) === null || _a === void 0 ? void 0 : _a.filter(() => {
11229
+ return true;
11230
+ });
11231
+ (((_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();
11232
+ this.isLoading = false;
11233
+ this.changeDetector.detectChanges();
11234
+ });
11235
+ }
11200
11236
  handleInputKeyDown(event) {
11201
11237
  if (event) {
11202
11238
  if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {
@@ -11271,6 +11307,9 @@ class ListOfValuesComponent extends BaseInputComponent {
11271
11307
  }
11272
11308
  else {
11273
11309
  this.selectedModel = option[this.displayField];
11310
+ if (this.largeCollection) {
11311
+ this.filterText = option[this.displayField];
11312
+ }
11274
11313
  }
11275
11314
  }
11276
11315
  this.model = option;
@@ -11311,6 +11350,9 @@ class ListOfValuesComponent extends BaseInputComponent {
11311
11350
  else {
11312
11351
  if (this.model) {
11313
11352
  this.selectedModel = this.model[this.displayField];
11353
+ if (this.largeCollection) {
11354
+ this.filterText = this.model[this.displayField];
11355
+ }
11314
11356
  }
11315
11357
  else {
11316
11358
  this.selectedModel = '';
@@ -11322,29 +11364,35 @@ ListOfValuesComponent.decorators = [
11322
11364
  { type: Component, args: [{
11323
11365
  selector: 'co-list-of-values',
11324
11366
  template: `
11325
- <co-input-text aria-haspopup="listbox" [attr.aria-expanded]="isSelectOpen" aria-controls="lov-popup" role="combobox"
11326
- class="no-focus-line"
11327
- overlayParent
11328
- #parentForOverlay="overlayParent" type="text" [id]="label"
11329
- [model]="multiselect ? selectedModels : selectedModel"
11330
- [placeholder]="label"
11331
- [readonly]="readonly"
11332
- [disabled]="disabled"
11333
- [required]="required"
11334
- [noClickFocus]="false"
11335
- [leftIconData]="leftIconData"
11336
- [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
11337
- [showClearButton]="true"
11338
- [useContent]="multiselect"
11339
- [customHeight]="multiselect"
11340
- [keepFocussed]="keepFocussed"
11341
- (modelChange)="handleInputModelChange($event)"
11342
- (click)="openPopup()"
11343
- (rightIconClick)="toggleSelect()"
11344
- (keydown)="handleInputKeyDown($event)"
11345
- (clearIconClick)="clearModel($event)"
11346
- (blur)="checkModel()"
11347
- >
11367
+ <co-input-text
11368
+ *ngIf="!largeCollection"
11369
+ aria-haspopup="listbox"
11370
+ [attr.aria-expanded]="isSelectOpen"
11371
+ aria-controls="lov-popup"
11372
+ role="combobox"
11373
+ class="no-focus-line"
11374
+ overlayParent
11375
+ #parentForOverlay="overlayParent"
11376
+ type="text"
11377
+ [id]="label"
11378
+ [model]="multiselect ? selectedModels : selectedModel"
11379
+ [placeholder]="label"
11380
+ [readonly]="readonly"
11381
+ [disabled]="disabled"
11382
+ [required]="required"
11383
+ [noClickFocus]="false"
11384
+ [leftIconData]="leftIconData"
11385
+ [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
11386
+ [showClearButton]="true"
11387
+ [useContent]="multiselect"
11388
+ [customHeight]="multiselect"
11389
+ [keepFocussed]="keepFocussed"
11390
+ (modelChange)="handleInputModelChange($event)"
11391
+ (click)="openPopup()"
11392
+ (rightIconClick)="toggleSelect()"
11393
+ (keydown)="handleInputKeyDown($event)"
11394
+ (clearIconClick)="clearModel($event)"
11395
+ (blur)="checkModel()">
11348
11396
  <ng-container *ngIf="multiselect && showChips">
11349
11397
  <div class="multiselect-chips-wrapper">
11350
11398
  <div class="chips" *ngFor="let chip of model">
@@ -11354,6 +11402,17 @@ ListOfValuesComponent.decorators = [
11354
11402
  </div>
11355
11403
  </ng-container>
11356
11404
  </co-input-text>
11405
+
11406
+ <co-input-text
11407
+ *ngIf="largeCollection"
11408
+ [model]="filterText"
11409
+ [placeholder]="label"
11410
+ [required]="required"
11411
+ [disabled]="disabled"
11412
+ [readonly]="readonly"
11413
+ (modelChange)="onModelChange($event)">
11414
+ </co-input-text>
11415
+ <div *ngIf="isLoading" class="filter-loader"><span></span></div>
11357
11416
  `,
11358
11417
  providers: [
11359
11418
  OverlayService,
@@ -11369,8 +11428,10 @@ ListOfValuesComponent.propDecorators = {
11369
11428
  model: [{ type: Input }],
11370
11429
  parentForOverlay: [{ type: ViewChild, args: ['parentForOverlay', { read: ElementRef },] }],
11371
11430
  multiselect: [{ type: HostBinding, args: ['class.custom-height',] }, { type: HostBinding, args: ['class.multi-select',] }, { type: Input }],
11431
+ largeCollection: [{ type: Input }],
11372
11432
  displayField: [{ type: Input }],
11373
11433
  collection: [{ type: Input }],
11434
+ collectionLoadFn: [{ type: Input }],
11374
11435
  leftIconData: [{ type: Input }],
11375
11436
  searchPlaceholder: [{ type: Input }],
11376
11437
  label: [{ type: Input }],