@colijnit/corecomponents_v12 258.1.0 → 258.1.2

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.
@@ -10,36 +10,56 @@ export class HourSchedulingExpandableTemplateComponent {
10
10
  onDragStartCustom === null || onDragStartCustom === void 0 ? void 0 : onDragStartCustom.call(obj);
11
11
  event.dataTransfer.setData("text", JSON.stringify({ obj }));
12
12
  }
13
+ leftForObject(index, objects) {
14
+ if (index === 0) {
15
+ return 0;
16
+ }
17
+ else {
18
+ return index * this.widthForObject(index, objects);
19
+ }
20
+ }
21
+ widthForObject(index, objects) {
22
+ if (objects.length > 1) {
23
+ return 100 / objects.length;
24
+ }
25
+ if (objects.length === 1) {
26
+ return 100;
27
+ }
28
+ }
13
29
  }
14
30
  HourSchedulingExpandableTemplateComponent.decorators = [
15
31
  { type: Component, args: [{
16
32
  selector: "co-hour-scheduling-expandable-template",
17
33
  template: `
18
- <div
19
- *ngFor="let obj of objects"
20
- [class]="'custom-scheduled-object'"
21
- [class.selected]="obj['selected']"
22
- [draggable]="!obj['selected']"
23
- [style.--height]="obj['height'] + 'px'"
24
- [style.--top]="obj['top'] + 'px'"
25
- (click)="onSelectBlock(obj)"
26
- (dragstart)="onExpandableDragStart($event, obj, onDragStartCustom(obj) )">
34
+ <div class="row">
35
+ <div
36
+ *ngFor="let obj of objects"
37
+ [class]="'custom-scheduled-object'"
38
+ [class.selected]="obj['selected']"
39
+ [draggable]="!obj['selected']"
40
+ [style.--height]="obj['height'] + 'px'"
41
+ [style.--top]="obj['top'] + 'px'"
42
+ [style.--left]="leftForObject(objects.indexOf(obj), objects) + '%'"
43
+ [style.--width]="widthForObject(objects.indexOf(obj), objects) + '%'"
44
+ (click)="onSelectBlock(obj)"
45
+ (dragstart)="onExpandableDragStart($event, obj, onDragStartCustom(obj) )">
27
46
 
28
- <div
29
- *ngIf="obj['selected']"
30
- class="top-resizer"
31
- (mousedown)="onResizeStart($event, obj, 'top')"></div>
32
- <ng-template
33
- [ngTemplateOutlet]="objectTemplate"
34
- [ngTemplateOutletContext]="{
47
+ <div
48
+ *ngIf="obj['selected']"
49
+ class="top-resizer"
50
+ (mousedown)="onResizeStart($event, obj, 'top')"></div>
51
+ <ng-template
52
+ [ngTemplateOutlet]="objectTemplate"
53
+ [ngTemplateOutletContext]="{
35
54
  object: obj
36
55
  }"
37
- >
38
- </ng-template>
39
- <div *ngIf="obj['selected']"
40
- class="bottom-resizer"
41
- (mousedown)="onResizeStart($event, obj, 'bottom')"></div>
42
- </div>
56
+ >
57
+ </ng-template>
58
+ <div *ngIf="obj['selected']"
59
+ class="bottom-resizer"
60
+ (mousedown)="onResizeStart($event, obj, 'bottom')"></div>
61
+ </div>
62
+ </div>
43
63
  `,
44
64
  encapsulation: ViewEncapsulation.None
45
65
  },] }
@@ -52,4 +72,4 @@ HourSchedulingExpandableTemplateComponent.propDecorators = {
52
72
  onSelectBlock: [{ type: Input }],
53
73
  showClass: [{ type: HostBinding, args: ["class.co-hour-scheduling-expandable-template",] }]
54
74
  };
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlL2NvbXBvbmVudHMvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBZSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQWlDNUYsTUFBTSxPQUFPLHlDQUF5QztJQS9CdEQ7UUFxQ1MsWUFBTyxHQUFhLEVBQUUsQ0FBQztJQTRCaEMsQ0FBQztJQVZRLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTSxxQkFBcUIsQ0FBQyxLQUFnQixFQUFFLEdBQVcsRUFBRSxpQkFBMkI7UUFDckYsaUJBQWlCLGFBQWpCLGlCQUFpQix1QkFBakIsaUJBQWlCLENBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzdCLEtBQUssQ0FBQyxZQUFhLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQy9ELENBQUM7OztZQTlERixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLHdDQUF3QztnQkFDbEQsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztLQTBCVDtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN4Qzs7OzZCQUdFLEtBQUs7c0JBR0wsS0FBSztnQ0FHTCxLQUFLOzRCQUlMLEtBQUs7NEJBSUwsS0FBSzt3QkFPTCxXQUFXLFNBQUMsOENBQThDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCwgVGVtcGxhdGVSZWYsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJjby1ob3VyLXNjaGVkdWxpbmctZXhwYW5kYWJsZS10ZW1wbGF0ZVwiLFxyXG4gICAgdGVtcGxhdGU6IGBcclxuICAgICAgPGRpdlxyXG4gICAgICAgICpuZ0Zvcj1cImxldCBvYmogb2Ygb2JqZWN0c1wiXHJcbiAgICAgICAgW2NsYXNzXT1cIidjdXN0b20tc2NoZWR1bGVkLW9iamVjdCdcIlxyXG4gICAgICAgIFtjbGFzcy5zZWxlY3RlZF09XCJvYmpbJ3NlbGVjdGVkJ11cIlxyXG4gICAgICAgIFtkcmFnZ2FibGVdPVwiIW9ialsnc2VsZWN0ZWQnXVwiXHJcbiAgICAgICAgW3N0eWxlLi0taGVpZ2h0XT1cIm9ialsnaGVpZ2h0J10gKyAncHgnXCJcclxuICAgICAgICBbc3R5bGUuLS10b3BdPVwib2JqWyd0b3AnXSArICdweCdcIlxyXG4gICAgICAgIChjbGljayk9XCJvblNlbGVjdEJsb2NrKG9iailcIlxyXG4gICAgICAgIChkcmFnc3RhcnQpPVwib25FeHBhbmRhYmxlRHJhZ1N0YXJ0KCRldmVudCwgb2JqLCBvbkRyYWdTdGFydEN1c3RvbShvYmopIClcIj5cclxuXHJcbiAgICAgICAgPGRpdlxyXG4gICAgICAgICAgKm5nSWY9XCJvYmpbJ3NlbGVjdGVkJ11cIlxyXG4gICAgICAgICAgY2xhc3M9XCJ0b3AtcmVzaXplclwiXHJcbiAgICAgICAgICAobW91c2Vkb3duKT1cIm9uUmVzaXplU3RhcnQoJGV2ZW50LCBvYmosICd0b3AnKVwiPjwvZGl2PlxyXG4gICAgICAgIDxuZy10ZW1wbGF0ZVxyXG4gICAgICAgICAgW25nVGVtcGxhdGVPdXRsZXRdPVwib2JqZWN0VGVtcGxhdGVcIlxyXG4gICAgICAgICAgW25nVGVtcGxhdGVPdXRsZXRDb250ZXh0XT1cIntcclxuICAgICAgICAgICAgICBvYmplY3Q6IG9ialxyXG4gICAgICAgICAgICB9XCJcclxuICAgICAgICA+XHJcbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICA8ZGl2ICpuZ0lmPVwib2JqWydzZWxlY3RlZCddXCJcclxuICAgICAgICAgICAgIGNsYXNzPVwiYm90dG9tLXJlc2l6ZXJcIlxyXG4gICAgICAgICAgICAgKG1vdXNlZG93bik9XCJvblJlc2l6ZVN0YXJ0KCRldmVudCwgb2JqLCAnYm90dG9tJylcIj48L2Rpdj5cclxuICAgICAgPC9kaXY+XHJcbiAgICBgLFxyXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSG91clNjaGVkdWxpbmdFeHBhbmRhYmxlVGVtcGxhdGVDb21wb25lbnQge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBvYmplY3RUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgb2JqZWN0czogT2JqZWN0W10gPSBbXTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgb25EcmFnU3RhcnRDdXN0b206IEZ1bmN0aW9uO1xyXG5cclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgb25SZXNpemVTdGFydDogRnVuY3Rpb247XHJcblxyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBvblNlbGVjdEJsb2NrOiBGdW5jdGlvbjtcclxuXHJcblxyXG5cclxuXHJcblxyXG4gIEBIb3N0QmluZGluZyhcImNsYXNzLmNvLWhvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlLXRlbXBsYXRlXCIpXHJcbiAgcHVibGljIHNob3dDbGFzcygpIHtcclxuICAgIHJldHVybiB0cnVlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uRXhwYW5kYWJsZURyYWdTdGFydChldmVudDogRHJhZ0V2ZW50LCBvYmo6IE9iamVjdCwgb25EcmFnU3RhcnRDdXN0b206IEZ1bmN0aW9uKSB7XHJcbiAgICBvbkRyYWdTdGFydEN1c3RvbT8uY2FsbChvYmopO1xyXG4gICAgZXZlbnQuZGF0YVRyYW5zZmVyIS5zZXREYXRhKFwidGV4dFwiLCBKU09OLnN0cmluZ2lmeSh7IG9iaiB9KSk7XHJcbiAgfVxyXG5cclxuXHJcbn1cclxuIl19
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlL2NvbXBvbmVudHMvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBZSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQXFDNUYsTUFBTSxPQUFPLHlDQUF5QztJQW5DdEQ7UUF5Q1MsWUFBTyxHQUFhLEVBQUUsQ0FBQztJQThDaEMsQ0FBQztJQTVCUSxTQUFTO1FBQ2QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRU0scUJBQXFCLENBQUMsS0FBZ0IsRUFBRSxHQUFXLEVBQUUsaUJBQTJCO1FBQ3JGLGlCQUFpQixhQUFqQixpQkFBaUIsdUJBQWpCLGlCQUFpQixDQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM3QixLQUFLLENBQUMsWUFBYSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRU0sYUFBYSxDQUFDLEtBQWEsRUFBRSxPQUFpQjtRQUNuRCxJQUFHLEtBQUssS0FBSyxDQUFDLEVBQUU7WUFDZCxPQUFPLENBQUMsQ0FBQztTQUNWO2FBQU07WUFDTCxPQUFPLEtBQUssR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztTQUNwRDtJQUVILENBQUM7SUFFTSxjQUFjLENBQUMsS0FBYSxFQUFFLE9BQWlCO1FBQ3BELElBQUcsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDckIsT0FBTyxHQUFHLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztTQUM3QjtRQUNELElBQUcsT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDdkIsT0FBTyxHQUFHLENBQUM7U0FDWjtJQUNILENBQUM7OztZQXBGRixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLHdDQUF3QztnQkFDbEQsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7S0E4QlQ7Z0JBQ0QsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7YUFDeEM7Ozs2QkFHRSxLQUFLO3NCQUdMLEtBQUs7Z0NBR0wsS0FBSzs0QkFJTCxLQUFLOzRCQUlMLEtBQUs7d0JBT0wsV0FBVyxTQUFDLDhDQUE4QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBIb3N0QmluZGluZywgSW5wdXQsIFRlbXBsYXRlUmVmLCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6IFwiY28taG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGVcIixcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICAgICAgPGRpdiBjbGFzcz1cInJvd1wiPlxyXG4gICAgICAgICAgICA8ZGl2XHJcbiAgICAgICAgICAgICAgICAgICAgKm5nRm9yPVwibGV0IG9iaiBvZiBvYmplY3RzXCJcclxuICAgICAgICAgICAgICAgICAgICBbY2xhc3NdPVwiJ2N1c3RvbS1zY2hlZHVsZWQtb2JqZWN0J1wiXHJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzLnNlbGVjdGVkXT1cIm9ialsnc2VsZWN0ZWQnXVwiXHJcbiAgICAgICAgICAgICAgICAgICAgW2RyYWdnYWJsZV09XCIhb2JqWydzZWxlY3RlZCddXCJcclxuICAgICAgICAgICAgICAgICAgICBbc3R5bGUuLS1oZWlnaHRdPVwib2JqWydoZWlnaHQnXSArICdweCdcIlxyXG4gICAgICAgICAgICAgICAgICAgIFtzdHlsZS4tLXRvcF09XCJvYmpbJ3RvcCddICsgJ3B4J1wiXHJcbiAgICAgICAgICAgICAgICAgICAgW3N0eWxlLi0tbGVmdF09XCJsZWZ0Rm9yT2JqZWN0KG9iamVjdHMuaW5kZXhPZihvYmopLCBvYmplY3RzKSArICclJ1wiXHJcbiAgICAgICAgICAgICAgICAgICAgW3N0eWxlLi0td2lkdGhdPVwid2lkdGhGb3JPYmplY3Qob2JqZWN0cy5pbmRleE9mKG9iaiksIG9iamVjdHMpICsgJyUnXCJcclxuICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwib25TZWxlY3RCbG9jayhvYmopXCJcclxuICAgICAgICAgICAgICAgICAgICAoZHJhZ3N0YXJ0KT1cIm9uRXhwYW5kYWJsZURyYWdTdGFydCgkZXZlbnQsIG9iaiwgb25EcmFnU3RhcnRDdXN0b20ob2JqKSApXCI+XHJcblxyXG4gICAgICAgICAgICAgICAgPGRpdlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAqbmdJZj1cIm9ialsnc2VsZWN0ZWQnXVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidG9wLXJlc2l6ZXJcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAobW91c2Vkb3duKT1cIm9uUmVzaXplU3RhcnQoJGV2ZW50LCBvYmosICd0b3AnKVwiPjwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPG5nLXRlbXBsYXRlXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0XT1cIm9iamVjdFRlbXBsYXRlXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW25nVGVtcGxhdGVPdXRsZXRDb250ZXh0XT1cIntcclxuICAgICAgICAgICAgICBvYmplY3Q6IG9ialxyXG4gICAgICAgICAgICB9XCJcclxuICAgICAgICAgICAgICAgID5cclxuICAgICAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVwib2JqWydzZWxlY3RlZCddXCJcclxuICAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJib3R0b20tcmVzaXplclwiXHJcbiAgICAgICAgICAgICAgICAgICAgIChtb3VzZWRvd24pPVwib25SZXNpemVTdGFydCgkZXZlbnQsIG9iaiwgJ2JvdHRvbScpXCI+PC9kaXY+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgYCxcclxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIEhvdXJTY2hlZHVsaW5nRXhwYW5kYWJsZVRlbXBsYXRlQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgb2JqZWN0VGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIG9iamVjdHM6IE9iamVjdFtdID0gW107XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIG9uRHJhZ1N0YXJ0Q3VzdG9tOiBGdW5jdGlvbjtcclxuXHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIG9uUmVzaXplU3RhcnQ6IEZ1bmN0aW9uO1xyXG5cclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgb25TZWxlY3RCbG9jazogRnVuY3Rpb247XHJcblxyXG5cclxuXHJcblxyXG5cclxuICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby1ob3VyLXNjaGVkdWxpbmctZXhwYW5kYWJsZS10ZW1wbGF0ZVwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3MoKSB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbkV4cGFuZGFibGVEcmFnU3RhcnQoZXZlbnQ6IERyYWdFdmVudCwgb2JqOiBPYmplY3QsIG9uRHJhZ1N0YXJ0Q3VzdG9tOiBGdW5jdGlvbikge1xyXG4gICAgb25EcmFnU3RhcnRDdXN0b20/LmNhbGwob2JqKTtcclxuICAgIGV2ZW50LmRhdGFUcmFuc2ZlciEuc2V0RGF0YShcInRleHRcIiwgSlNPTi5zdHJpbmdpZnkoeyBvYmogfSkpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGxlZnRGb3JPYmplY3QoaW5kZXg6IG51bWJlciwgb2JqZWN0czogT2JqZWN0W10pIHtcclxuICAgIGlmKGluZGV4ID09PSAwKSB7XHJcbiAgICAgIHJldHVybiAwO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgcmV0dXJuIGluZGV4ICogdGhpcy53aWR0aEZvck9iamVjdChpbmRleCwgb2JqZWN0cyk7XHJcbiAgICB9XHJcblxyXG4gIH1cclxuXHJcbiAgcHVibGljIHdpZHRoRm9yT2JqZWN0KGluZGV4OiBudW1iZXIsIG9iamVjdHM6IE9iamVjdFtdKSB7XHJcbiAgICBpZihvYmplY3RzLmxlbmd0aCA+IDEpIHtcclxuICAgICAgcmV0dXJuIDEwMCAvIG9iamVjdHMubGVuZ3RoO1xyXG4gICAgfVxyXG4gICAgaWYob2JqZWN0cy5sZW5ndGggPT09IDEpIHtcclxuICAgICAgcmV0dXJuIDEwMDtcclxuICAgIH1cclxuICB9XHJcblxyXG5cclxufVxyXG4iXX0=
@@ -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":"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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"]}
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"]}