@colijnit/corecomponents_v12 12.1.1 → 12.1.3

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.
@@ -40,6 +40,7 @@ export class ListOfValuesComponent extends BaseInputComponent {
40
40
  if (this._lovPopupComponentRef) {
41
41
  this._lovPopupComponentRef.instance.searchTerm = model;
42
42
  }
43
+ this.selectedModel = model;
43
44
  }
44
45
  handleInputKeyDown(event) {
45
46
  if (event) {
@@ -53,13 +54,13 @@ export class ListOfValuesComponent extends BaseInputComponent {
53
54
  this._lovPopupComponentRef.instance.selectNextOption();
54
55
  return false;
55
56
  case KeyboardKey.Up:
56
- this._lovPopupComponentRef.instance.selectPreviousOption();
57
+ this._lovPopupComponentRef.instance.selectNextOption(true);
57
58
  return false;
58
59
  case KeyboardKey.Enter:
59
- this._lovPopupComponentRef.instance.selectOptionByActiveIndex();
60
+ this._lovPopupComponentRef.instance.selectOptionAndClosePopup();
60
61
  return false;
61
62
  case KeyboardKey.Tab:
62
- this._lovPopupComponentRef.instance.selectOptionByActiveIndex();
63
+ this._lovPopupComponentRef.instance.selectOptionAndClosePopup();
63
64
  }
64
65
  }
65
66
  }
@@ -107,11 +108,13 @@ export class ListOfValuesComponent extends BaseInputComponent {
107
108
  }
108
109
  }
109
110
  optionChosen(option) {
110
- if (this.multiselect) {
111
- this.selectedModels = option.map(o => o[this.displayField]);
112
- }
113
- else {
114
- this.selectedModel = option[this.displayField];
111
+ if (option) {
112
+ if (this.multiselect) {
113
+ this.selectedModels = option.map(o => o[this.displayField]);
114
+ }
115
+ else {
116
+ this.selectedModel = option[this.displayField];
117
+ }
115
118
  }
116
119
  this.model = option;
117
120
  this.modelChange.emit(this.model);
@@ -122,6 +125,18 @@ export class ListOfValuesComponent extends BaseInputComponent {
122
125
  this._lovPopupComponentRef = undefined;
123
126
  this.focused = false;
124
127
  }
128
+ checkModel() {
129
+ if (!this.multiselect && this.selectedModel && this.collection) {
130
+ const model = this.collection.find(c => c[this.displayField] === this.selectedModel);
131
+ if (model) {
132
+ this.model = model;
133
+ }
134
+ else {
135
+ this.model = undefined;
136
+ }
137
+ this.modelChange.emit(this.model);
138
+ }
139
+ }
125
140
  _setSelectedModel() {
126
141
  if (this.multiselect) {
127
142
  if (this.model) {
@@ -167,6 +182,7 @@ ListOfValuesComponent.decorators = [
167
182
  (rightIconClick)="toggleSelect()"
168
183
  (keydown)="handleInputKeyDown($event)"
169
184
  (clearIconClick)="clearModel($event)"
185
+ (blur)="checkModel()"
170
186
  >
171
187
  </co-input-text>
172
188
  <ng-container *ngIf="multiselect">
@@ -197,4 +213,4 @@ ListOfValuesComponent.propDecorators = {
197
213
  searchDisabled: [{ type: Input }],
198
214
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values',] }]
199
215
  };
200
- //# 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, 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\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                       (modelChange)=\"handleInputModelChange($event)\"\r\n                       (click)=\"openPopup()\"\r\n                       (rightIconClick)=\"toggleSelect()\"\r\n                       (keydown)=\"handleInputKeyDown($event)\"\r\n                       (clearIconClick)=\"clearModel($event)\"\r\n        >\r\n        </co-input-text>\r\n        <ng-container *ngIf=\"multiselect\">\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    `,\r\n    providers: [\r\n        OverlayService\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    @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        }\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.selectPreviousOption();\r\n                        return false;\r\n                    case KeyboardKey.Enter:\r\n                        this._lovPopupComponentRef.instance.selectOptionByActiveIndex();\r\n                        return false;\r\n                    case KeyboardKey.Tab:\r\n                        this._lovPopupComponentRef.instance.selectOptionByActiveIndex();\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            });\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 (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        this.model = option;\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public closePopup(): void {\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    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"]}
216
+ //# 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, 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\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                       (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        </co-input-text>\r\n        <ng-container *ngIf=\"multiselect\">\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    `,\r\n    providers: [\r\n        OverlayService\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    @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        }\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            });\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    }\r\n\r\n    public closePopup(): void {\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"]}
@@ -4387,7 +4387,7 @@ CoDialogComponent.decorators = [
4387
4387
  <ng-container [ngTemplateOutlet]="headerTemplate"></ng-container>
4388
4388
  </div>
4389
4389
  <div class="dialog-close-button" *ngIf="showCloseIcon" (click)="handleCloseDialog($event)">
4390
- <co-icon [icon]="icons.Cancel"></co-icon>
4390
+ <co-icon [icon]="icons.CrossSkinny"></co-icon>
4391
4391
  </div>
4392
4392
  </div>
4393
4393
  <div class="dialog-content" [ngClass]="customCssClass ? customCssClass : undefined">
@@ -6576,6 +6576,9 @@ class InputDateRangePickerComponent extends BaseInputDatePickerDirective {
6576
6576
  this.toggleCalendar();
6577
6577
  }
6578
6578
  }
6579
+ clearDate(index) {
6580
+ this.model[index] = undefined;
6581
+ }
6579
6582
  toggleCalendar() {
6580
6583
  if (this.readonly) {
6581
6584
  return;
@@ -6643,6 +6646,7 @@ InputDateRangePickerComponent.decorators = [
6643
6646
  [leftIconData]="leftIconData"
6644
6647
  [placeholder]="placeholder"
6645
6648
  (blur)="handleFirstDateChanged(firstDateAsString)"
6649
+ (clearIconClick)="clearDate(0)"
6646
6650
  ></co-input-text>
6647
6651
  <co-input-text class="no-focus-line custom-height"
6648
6652
  [(model)]= "secondDateAsString"
@@ -6652,6 +6656,7 @@ InputDateRangePickerComponent.decorators = [
6652
6656
  [rightIcon]="rightIcon"
6653
6657
  (rightIconClick)="toggleCalendar()"
6654
6658
  (blur)="handleSecondDateChanged(secondDateAsString)"
6659
+ (clearIconClick)="clearDate(1)"
6655
6660
  ></co-input-text>
6656
6661
  </div>
6657
6662
  `,
@@ -7104,6 +7109,9 @@ class InputNumberPickerComponent extends BaseInputComponent {
7104
7109
  return false;
7105
7110
  }
7106
7111
  }
7112
+ handleBlur() {
7113
+ this.modelChange.next(this.model);
7114
+ }
7107
7115
  handleChangeModel(value) {
7108
7116
  this._changeFromButton = false;
7109
7117
  this.numberLogic.setValue(value);
@@ -7231,7 +7239,8 @@ InputNumberPickerComponent.decorators = [
7231
7239
  [disabled]="disabled"
7232
7240
  [required]="required"
7233
7241
  (ngModelChange)="handleChangeModel($event)"
7234
- (keydown)="handleInputKeyDown($event)"/>
7242
+ (keydown)="handleInputKeyDown($event)"
7243
+ (blur)="handleBlur()"/>
7235
7244
  <div class="button-wrapper">
7236
7245
  <co-button *ngIf="showButtons" class="plus-operator" [class.select]="plusSelected" tabindex="-1"
7237
7246
  [disabled]="readonly"
@@ -10226,7 +10235,6 @@ class ListOfValuesPopupComponent {
10226
10235
  this._collection = [];
10227
10236
  this._searchTerm = '';
10228
10237
  this._lovItems = [];
10229
- this._activeIndex = -1;
10230
10238
  }
10231
10239
  set lovItems(children) {
10232
10240
  this._lovItems = children.toArray();
@@ -10252,6 +10260,8 @@ class ListOfValuesPopupComponent {
10252
10260
  }
10253
10261
  set searchTerm(value) {
10254
10262
  this._searchTerm = value;
10263
+ this.model = undefined;
10264
+ this.highLightModel = undefined;
10255
10265
  this.filterViewModels();
10256
10266
  }
10257
10267
  get searchTerm() {
@@ -10260,7 +10270,6 @@ class ListOfValuesPopupComponent {
10260
10270
  ngOnInit() {
10261
10271
  if (this.model) {
10262
10272
  if (!this.multiselect) {
10263
- this._activeIndex = this.viewModelsMain.findIndex(v => v.model === this.model);
10264
10273
  this._scrollIntoView();
10265
10274
  }
10266
10275
  else {
@@ -10273,52 +10282,87 @@ class ListOfValuesPopupComponent {
10273
10282
  }
10274
10283
  }
10275
10284
  }
10285
+ handleInputKeyDown(event) {
10286
+ if (event) {
10287
+ switch (event.code) {
10288
+ case KeyboardKey.Down:
10289
+ this.selectNextOption();
10290
+ return false;
10291
+ case KeyboardKey.Up:
10292
+ this.selectNextOption(true);
10293
+ return false;
10294
+ case KeyboardKey.SpaceBar:
10295
+ if (this.highLightModel) {
10296
+ this.selectViewModel(this.highLightModel, false);
10297
+ return false;
10298
+ }
10299
+ }
10300
+ }
10301
+ }
10276
10302
  filterViewModels() {
10277
10303
  if (!this.collection) {
10278
10304
  return;
10279
10305
  }
10280
10306
  this._prepareViewModels();
10281
10307
  }
10282
- selectViewModel(viewModel) {
10283
- const idx = this.viewModelsMain.findIndex(vm => vm === viewModel);
10308
+ selectViewModel(viewModel, closePopup = true) {
10284
10309
  if (!this.multiselect) {
10285
- this._activeIndex = idx;
10286
- this.selectOptionByActiveIndex();
10310
+ this.selectModelByViewModel(viewModel, closePopup);
10287
10311
  }
10288
10312
  else {
10289
- this.viewModelsMain[idx].checked = !this.viewModelsMain[idx].checked;
10313
+ const idx = this.viewModels.findIndex(vm => vm === viewModel);
10314
+ this.viewModels[idx].checked = !this.viewModels[idx].checked;
10290
10315
  this.selectOptions();
10291
10316
  }
10292
10317
  }
10318
+ selectModelByViewModel(viewModel, closePopup = true) {
10319
+ this.model = this.viewModelsMain.find(vm => vm === viewModel).model;
10320
+ this.modelChange.emit(this.model);
10321
+ this._scrollIntoView();
10322
+ if (closePopup) {
10323
+ this.closePopup.emit();
10324
+ }
10325
+ }
10293
10326
  // for single select
10294
- selectOptionByActiveIndex(closePopup = true) {
10295
- if (this._activeIndex > -1) {
10296
- this.model = this.viewModelsMain[this._activeIndex].model;
10297
- this.modelChange.emit(this.model);
10298
- this._scrollIntoView();
10299
- if (closePopup) {
10300
- this.closePopup.emit();
10327
+ selectOptionAndClosePopup() {
10328
+ if (!this.model && this.searchTerm) {
10329
+ const wishModel = this.viewModelsMain.find(vmm => vmm.model[this.displayField] === this.searchTerm);
10330
+ if (wishModel) {
10331
+ this.selectViewModel(wishModel);
10332
+ }
10333
+ else {
10334
+ this.model = undefined;
10335
+ this.modelChange.emit(this.model);
10336
+ this.searchTerm = '';
10301
10337
  }
10302
10338
  }
10339
+ else {
10340
+ this.closePopup.emit();
10341
+ }
10303
10342
  }
10304
10343
  // for multi select
10305
10344
  selectOptions() {
10306
10345
  this.model = this.viewModelsMain.filter(v => v.checked).map(m => m.model);
10307
10346
  this.modelChange.emit(this.model);
10308
10347
  }
10309
- selectNextOption() {
10310
- if (!this._lovItems || this._activeIndex >= this._lovItems.length - 1) {
10311
- return;
10348
+ selectNextOption(back = false) {
10349
+ let nextModel;
10350
+ if (!this.highLightModel) {
10351
+ nextModel = this.viewModels[back ? this.viewModels.length - 1 : 0];
10312
10352
  }
10313
- this._activeIndex++;
10314
- this.selectOptionByActiveIndex(false);
10315
- }
10316
- selectPreviousOption() {
10317
- if (this._activeIndex <= 0) {
10318
- return;
10353
+ else {
10354
+ const currentViewModelIdx = this.viewModels.findIndex(vm => vm === this.highLightModel);
10355
+ if (back) {
10356
+ nextModel = this.viewModels[currentViewModelIdx <= 0 ? this.viewModels.length - 1 : currentViewModelIdx - 1];
10357
+ }
10358
+ else {
10359
+ nextModel = this.viewModels[currentViewModelIdx >= this.viewModels.length - 1 ? 0 : currentViewModelIdx + 1];
10360
+ }
10361
+ }
10362
+ this.highLightModel = nextModel;
10363
+ if (!this.multiselect) {
10364
+ this.selectViewModel(nextModel, false);
10319
10365
  }
10320
- this._activeIndex--;
10321
- this.selectOptionByActiveIndex(false);
10322
10366
  }
10323
10367
  _prepareViewModelsMain() {
10324
10368
  this.viewModelsMain.length = 0;
@@ -10331,10 +10375,11 @@ class ListOfValuesPopupComponent {
10331
10375
  this.viewModels = this.viewModelsMain.filter(vm => vm.model[this.displayField] && vm.model[this.displayField].toLowerCase().includes(this.searchTerm ? this.searchTerm.toLowerCase() : ""));
10332
10376
  }
10333
10377
  _scrollIntoView() {
10334
- if (!this._lovItems || this._lovItems.length <= 0 || this._activeIndex < 0 || !this._lovItems[this._activeIndex] || !this.dropDownList) {
10378
+ const activeIndex = this.viewModels.findIndex(vmm => vmm === this.highLightModel);
10379
+ if (!this._lovItems || this._lovItems.length <= 0 || activeIndex < 0 || !this.dropDownList) {
10335
10380
  return;
10336
10381
  }
10337
- const activeItem = this._lovItems[this._activeIndex].nativeElement ? this._lovItems[this._activeIndex].nativeElement : undefined;
10382
+ const activeItem = this._lovItems[activeIndex].nativeElement ? this._lovItems[activeIndex].nativeElement : undefined;
10338
10383
  const scrollParent = this.dropDownList.nativeElement ? this.dropDownList.nativeElement : undefined;
10339
10384
  this._scrollActiveItemIntoView(activeItem, scrollParent);
10340
10385
  }
@@ -10358,18 +10403,22 @@ ListOfValuesPopupComponent.decorators = [
10358
10403
  { type: Component, args: [{
10359
10404
  selector: 'co-list-of-values-popup',
10360
10405
  template: `
10361
- <div class="lov-options" #dropDownList [overlay]="parentForOverlay" [inheritWidth]="true" [ngClass]="customCssClass" id="lov-popup"
10406
+ <div class="lov-options" [overlay]="parentForOverlay" [inheritWidth]="true" [ngClass]="customCssClass" id="lov-popup"
10362
10407
  [tabIndex]="-1" role="listbox"
10363
10408
  (clickOutside)="closePopup.emit($event)">
10364
- <co-input-search *ngIf="multiselect" [(model)]="searchTerm" (modelChange)="filterViewModels()" [placeholder]="searchPlaceholder"></co-input-search>
10365
- <ul class="dropdown-list">
10366
- <li #lovItem *ngFor="let viewModel of viewModels; let index = index" [class.selected]="viewModel.model === model"
10367
- (click)="selectViewModel(viewModel)" role="option">
10409
+ <co-input-search *ngIf="multiselect"
10410
+ [(model)]="searchTerm"
10411
+ [placeholder]="searchPlaceholder"
10412
+ (keydown)="handleInputKeyDown($event)"
10413
+ (modelChange)="filterViewModels()"></co-input-search>
10414
+ <ul class="dropdown-list" #dropDownList>
10415
+ <li #lovItem *ngFor="let viewModel of viewModels; let index = index" [class.selected]="viewModel === highLightModel"
10416
+ (click)="selectViewModel(viewModel, false)" role="option">
10368
10417
  <ng-container *ngIf="!multiselect">
10369
10418
  <span class="lov-options-text" [textContent]="viewModel.model[displayField]"></span>
10370
10419
  </ng-container>
10371
10420
  <ng-container *ngIf="multiselect">
10372
- <co-input-checkbox [model]="viewModel.checked" (modelChange)="selectViewModel(viewModel)"></co-input-checkbox>
10421
+ <co-input-checkbox [model]="viewModel.checked" (modelChange)="selectViewModel(viewModel, false)"></co-input-checkbox>
10373
10422
  <span class="lov-options-text" [textContent]="viewModel.model[displayField]"></span>
10374
10423
  </ng-container>
10375
10424
  </li>
@@ -10432,6 +10481,7 @@ class ListOfValuesComponent extends BaseInputComponent {
10432
10481
  if (this._lovPopupComponentRef) {
10433
10482
  this._lovPopupComponentRef.instance.searchTerm = model;
10434
10483
  }
10484
+ this.selectedModel = model;
10435
10485
  }
10436
10486
  handleInputKeyDown(event) {
10437
10487
  if (event) {
@@ -10445,13 +10495,13 @@ class ListOfValuesComponent extends BaseInputComponent {
10445
10495
  this._lovPopupComponentRef.instance.selectNextOption();
10446
10496
  return false;
10447
10497
  case KeyboardKey.Up:
10448
- this._lovPopupComponentRef.instance.selectPreviousOption();
10498
+ this._lovPopupComponentRef.instance.selectNextOption(true);
10449
10499
  return false;
10450
10500
  case KeyboardKey.Enter:
10451
- this._lovPopupComponentRef.instance.selectOptionByActiveIndex();
10501
+ this._lovPopupComponentRef.instance.selectOptionAndClosePopup();
10452
10502
  return false;
10453
10503
  case KeyboardKey.Tab:
10454
- this._lovPopupComponentRef.instance.selectOptionByActiveIndex();
10504
+ this._lovPopupComponentRef.instance.selectOptionAndClosePopup();
10455
10505
  }
10456
10506
  }
10457
10507
  }
@@ -10499,11 +10549,13 @@ class ListOfValuesComponent extends BaseInputComponent {
10499
10549
  }
10500
10550
  }
10501
10551
  optionChosen(option) {
10502
- if (this.multiselect) {
10503
- this.selectedModels = option.map(o => o[this.displayField]);
10504
- }
10505
- else {
10506
- this.selectedModel = option[this.displayField];
10552
+ if (option) {
10553
+ if (this.multiselect) {
10554
+ this.selectedModels = option.map(o => o[this.displayField]);
10555
+ }
10556
+ else {
10557
+ this.selectedModel = option[this.displayField];
10558
+ }
10507
10559
  }
10508
10560
  this.model = option;
10509
10561
  this.modelChange.emit(this.model);
@@ -10514,6 +10566,18 @@ class ListOfValuesComponent extends BaseInputComponent {
10514
10566
  this._lovPopupComponentRef = undefined;
10515
10567
  this.focused = false;
10516
10568
  }
10569
+ checkModel() {
10570
+ if (!this.multiselect && this.selectedModel && this.collection) {
10571
+ const model = this.collection.find(c => c[this.displayField] === this.selectedModel);
10572
+ if (model) {
10573
+ this.model = model;
10574
+ }
10575
+ else {
10576
+ this.model = undefined;
10577
+ }
10578
+ this.modelChange.emit(this.model);
10579
+ }
10580
+ }
10517
10581
  _setSelectedModel() {
10518
10582
  if (this.multiselect) {
10519
10583
  if (this.model) {
@@ -10559,6 +10623,7 @@ ListOfValuesComponent.decorators = [
10559
10623
  (rightIconClick)="toggleSelect()"
10560
10624
  (keydown)="handleInputKeyDown($event)"
10561
10625
  (clearIconClick)="clearModel($event)"
10626
+ (blur)="checkModel()"
10562
10627
  >
10563
10628
  </co-input-text>
10564
10629
  <ng-container *ngIf="multiselect">