@colijnit/corecomponents_v12 12.2.0 → 12.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,12 +2,14 @@ import { Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewCh
2
2
  import { InputSearchComponent } from '../input-search/input-search.component';
3
3
  import { KeyboardKey } from '../../core/enum/keyboard-key.enum';
4
4
  export class ListOfValuesPopupComponent {
5
- constructor() {
5
+ constructor(_elementRef) {
6
+ this._elementRef = _elementRef;
6
7
  this.multiselect = false;
7
8
  this.displayField = 'description';
8
9
  this.searchDisabled = false;
9
10
  this.modelChange = new EventEmitter();
10
11
  this.closePopup = new EventEmitter();
12
+ this.keyDown = new EventEmitter();
11
13
  this.viewModels = [];
12
14
  this.viewModelsMain = [];
13
15
  this._collection = [];
@@ -72,8 +74,14 @@ export class ListOfValuesPopupComponent {
72
74
  case KeyboardKey.SpaceBar:
73
75
  if (this.highLightModel) {
74
76
  this.selectViewModel(this.highLightModel, false);
75
- return false;
76
77
  }
78
+ else {
79
+ this.keyDown.next(event);
80
+ }
81
+ return false;
82
+ default:
83
+ this.keyDown.next(event);
84
+ return true;
77
85
  }
78
86
  }
79
87
  }
@@ -141,6 +149,9 @@ export class ListOfValuesPopupComponent {
141
149
  if (!this.multiselect) {
142
150
  this.selectViewModel(nextModel, false);
143
151
  }
152
+ else {
153
+ this._scrollIntoView();
154
+ }
144
155
  }
145
156
  _prepareViewModelsMain() {
146
157
  this.viewModelsMain.length = 0;
@@ -165,8 +176,9 @@ export class ListOfValuesPopupComponent {
165
176
  if (!activeItem || !scrollParent) {
166
177
  return;
167
178
  }
168
- const { offsetHeight, offsetTop } = activeItem;
169
- const { offsetHeight: parentOffsetHeight, scrollTop } = scrollParent;
179
+ let { offsetHeight, offsetTop } = activeItem;
180
+ let { offsetHeight: parentOffsetHeight, scrollTop, offsetTop: parentOffsetTop } = scrollParent;
181
+ offsetTop = offsetTop - parentOffsetTop;
170
182
  const isAbove = offsetTop < scrollTop;
171
183
  const isBelow = offsetTop + offsetHeight > scrollTop + parentOffsetHeight;
172
184
  if (isAbove) {
@@ -182,16 +194,17 @@ ListOfValuesPopupComponent.decorators = [
182
194
  selector: 'co-list-of-values-popup',
183
195
  template: `
184
196
  <div class="lov-options" [overlay]="parentForOverlay" [inheritWidth]="true" [ngClass]="customCssClass" id="lov-popup"
185
- [tabIndex]="-1" role="listbox"
197
+ role="listbox" [tabindex]="-1"
186
198
  (clickOutside)="closePopup.emit($event)">
187
- <co-input-search *ngIf="multiselect"
199
+ <co-input-search *ngIf="multiselect"
200
+ tabindex="-1"
188
201
  [(model)]="searchTerm"
189
202
  [placeholder]="searchPlaceholder"
190
203
  (keydown)="handleInputKeyDown($event)"
191
204
  (modelChange)="filterViewModels()"></co-input-search>
192
205
  <ul class="dropdown-list" #dropDownList>
193
206
  <li #lovItem *ngFor="let viewModel of viewModels; let index = index" [class.selected]="viewModel === highLightModel"
194
- (click)="selectViewModel(viewModel, false)" role="option">
207
+ (click)="selectViewModel(viewModel, !multiselect)" role="option">
195
208
  <ng-container *ngIf="!multiselect">
196
209
  <span class="lov-options-text" [textContent]="viewModel.model[displayField]"></span>
197
210
  </ng-container>
@@ -206,6 +219,9 @@ ListOfValuesPopupComponent.decorators = [
206
219
  encapsulation: ViewEncapsulation.None
207
220
  },] }
208
221
  ];
222
+ ListOfValuesPopupComponent.ctorParameters = () => [
223
+ { type: ElementRef }
224
+ ];
209
225
  ListOfValuesPopupComponent.propDecorators = {
210
226
  lovItems: [{ type: ViewChildren, args: ['lovItem', { read: ElementRef },] }],
211
227
  dropDownList: [{ type: ViewChild, args: ['dropDownList', { read: ElementRef },] }],
@@ -220,6 +236,7 @@ ListOfValuesPopupComponent.propDecorators = {
220
236
  collection: [{ type: Input }],
221
237
  modelChange: [{ type: Output }],
222
238
  closePopup: [{ type: Output }],
239
+ keyDown: [{ type: Output }],
223
240
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values-popup',] }]
224
241
  };
225
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values-popup.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values-popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n    ViewChildren,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport {InputSearchComponent} from '../input-search/input-search.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\n\r\nexport interface lovViewModel {\r\n    checked: boolean\r\n    model: any\r\n}\r\n\r\n@Component({\r\n    selector: 'co-list-of-values-popup',\r\n    template: `\r\n        <div class=\"lov-options\" [overlay]=\"parentForOverlay\" [inheritWidth]=\"true\" [ngClass]=\"customCssClass\" id=\"lov-popup\"\r\n             [tabIndex]=\"-1\" role=\"listbox\"\r\n             (clickOutside)=\"closePopup.emit($event)\">\r\n            <co-input-search *ngIf=\"multiselect\" \r\n                             [(model)]=\"searchTerm\"\r\n                             [placeholder]=\"searchPlaceholder\"\r\n                             (keydown)=\"handleInputKeyDown($event)\"\r\n                             (modelChange)=\"filterViewModels()\"></co-input-search>\r\n            <ul class=\"dropdown-list\" #dropDownList>\r\n                <li #lovItem *ngFor=\"let viewModel of viewModels; let index = index\" [class.selected]=\"viewModel === highLightModel\"\r\n                    (click)=\"selectViewModel(viewModel, false)\" role=\"option\">\r\n                    <ng-container *ngIf=\"!multiselect\">\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"multiselect\">\r\n                        <co-input-checkbox [model]=\"viewModel.checked\" (modelChange)=\"selectViewModel(viewModel, false)\"></co-input-checkbox>\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesPopupComponent implements OnInit {\r\n    @ViewChildren('lovItem', { read: ElementRef }) set lovItems(children) {\r\n        this._lovItems = children.toArray();\r\n        this._scrollIntoView();\r\n    }\r\n\r\n    @ViewChild('dropDownList', { read: ElementRef })\r\n    public dropDownList: ElementRef;\r\n\r\n    @ViewChild(InputSearchComponent) set inputSearch(component: InputSearchComponent) {\r\n        this._searchInput = component;\r\n        if (this._searchInput) {\r\n            this._searchInput.requestFocus();\r\n        }\r\n    }\r\n\r\n    @Input()\r\n    public model: any;\r\n\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 searchPlaceholder: 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 parentForOverlay: ElementRef;\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n        this._prepareViewModelsMain();\r\n        this._prepareViewModels();\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Output()\r\n    public modelChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @Output()\r\n    public closePopup: EventEmitter<Event> = new EventEmitter<Event>();\r\n\r\n    @HostBinding('class.co-list-of-values-popup')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public set searchTerm(value: string) {\r\n        this._searchTerm = value;\r\n        this.model = undefined;\r\n        this.highLightModel = undefined;\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get searchTerm(): string {\r\n        return this._searchTerm;\r\n    }\r\n\r\n    public viewModels: lovViewModel[] = [];\r\n    public viewModelsMain: lovViewModel[] = [];\r\n    public highLightModel: lovViewModel;\r\n\r\n    private _collection: any[] = [];\r\n    private _searchTerm: string = '';\r\n    private _lovItems: ElementRef[] = [];\r\n    private _searchInput: InputSearchComponent;\r\n\r\n    ngOnInit() {\r\n        if (this.model) {\r\n            if (!this.multiselect) {\r\n                this._scrollIntoView();\r\n            } else {\r\n                for (let i = 0; i < this.model.length; i++) {\r\n                    const viewModel: lovViewModel = this.viewModelsMain.find(v => JSON.stringify(v.model) === JSON.stringify(this.model[i]));\r\n                    if (viewModel) {\r\n                        viewModel.checked = true;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n        if (event) {\r\n            switch (event.code) {\r\n                case KeyboardKey.Down:\r\n                    this.selectNextOption();\r\n                    return false;\r\n                case KeyboardKey.Up:\r\n                    this.selectNextOption(true);\r\n                    return false;\r\n                case KeyboardKey.SpaceBar:\r\n                    if (this.highLightModel) {\r\n                        this.selectViewModel(this.highLightModel, false);\r\n                        return false;\r\n                    }\r\n            }\r\n        }\r\n    }\r\n\r\n    public filterViewModels(): void {\r\n        if (!this.collection) {\r\n            return;\r\n        }\r\n        this._prepareViewModels();\r\n    }\r\n\r\n    public selectViewModel(viewModel: lovViewModel, closePopup: boolean = true): void {\r\n        if (!this.multiselect) {\r\n            this.selectModelByViewModel(viewModel, closePopup);\r\n        } else {\r\n            const idx: number = this.viewModels.findIndex(vm => vm === viewModel);\r\n            this.viewModels[idx].checked = !this.viewModels[idx].checked;\r\n            this.selectOptions();\r\n        }\r\n    }\r\n\r\n    public selectModelByViewModel(viewModel: lovViewModel, closePopup: boolean = true): void {\r\n        this.model = this.viewModelsMain.find(vm => vm === viewModel).model;\r\n        this.modelChange.emit(this.model);\r\n        this._scrollIntoView();\r\n        if (closePopup) {\r\n            this.closePopup.emit();\r\n        }\r\n    }\r\n\r\n    // for single select\r\n    public selectOptionAndClosePopup(): void {\r\n        if (!this.model && this.searchTerm) {\r\n            const wishModel: lovViewModel = this.viewModelsMain.find(vmm => vmm.model[this.displayField] === this.searchTerm);\r\n            if (wishModel) {\r\n                this.selectViewModel(wishModel);\r\n            } else {\r\n                this.model = undefined;\r\n                this.modelChange.emit(this.model);\r\n                this.searchTerm = '';\r\n            }\r\n        } else {\r\n            this.closePopup.emit();\r\n        }\r\n    }\r\n\r\n    // for multi select\r\n    public selectOptions(): void {\r\n        this.model = this.viewModelsMain.filter(v => v.checked).map(m => m.model);\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public selectNextOption(back: boolean = false): void {\r\n        let nextModel: any;\r\n        if (!this.highLightModel) {\r\n            nextModel = this.viewModels[back ? this.viewModels.length - 1 : 0];\r\n        } else {\r\n            const currentViewModelIdx: number = this.viewModels.findIndex(vm => vm === this.highLightModel);\r\n            if (back) {\r\n                nextModel = this.viewModels[currentViewModelIdx <= 0 ? this.viewModels.length - 1 : currentViewModelIdx - 1];\r\n            } else {\r\n                nextModel = this.viewModels[currentViewModelIdx >= this.viewModels.length - 1 ? 0 : currentViewModelIdx + 1];\r\n            }\r\n        }\r\n        this.highLightModel = nextModel;\r\n        if (!this.multiselect) {\r\n            this.selectViewModel(nextModel, false);\r\n        }\r\n    }\r\n\r\n    private _prepareViewModelsMain(): void {\r\n        this.viewModelsMain.length = 0;\r\n        this.collection.forEach(m => {\r\n            this.viewModelsMain.push({checked: false, model: m});\r\n        })\r\n    }\r\n\r\n    private _prepareViewModels(): void {\r\n        this.viewModels.length = 0;\r\n        this.viewModels = this.viewModelsMain.filter(\r\n            vm => vm.model[this.displayField] && vm.model[this.displayField].toLowerCase().includes(this.searchTerm ? this.searchTerm.toLowerCase() : \"\"))\r\n    }\r\n\r\n    private _scrollIntoView(): void {\r\n        const activeIndex: number = this.viewModels.findIndex(vmm => vmm === this.highLightModel);\r\n        if (!this._lovItems || this._lovItems.length <= 0 || activeIndex < 0 || !this.dropDownList) {\r\n            return;\r\n        }\r\n        const activeItem = this._lovItems[activeIndex].nativeElement ? this._lovItems[activeIndex].nativeElement : undefined;\r\n        const scrollParent = this.dropDownList.nativeElement ? this.dropDownList.nativeElement : undefined;\r\n        this._scrollActiveItemIntoView(activeItem, scrollParent);\r\n    }\r\n\r\n    private _scrollActiveItemIntoView(activeItem: any, scrollParent: any): void {\r\n        if (!activeItem || !scrollParent) {\r\n            return;\r\n        }\r\n        const { offsetHeight, offsetTop } = activeItem;\r\n        const { offsetHeight: parentOffsetHeight, scrollTop } = scrollParent;\r\n\r\n        const isAbove = offsetTop < scrollTop;\r\n        const isBelow = offsetTop + offsetHeight > scrollTop + parentOffsetHeight;\r\n\r\n        if (isAbove) {\r\n            scrollParent.scrollTo(0, offsetTop);\r\n        } else if (isBelow) {\r\n            scrollParent.scrollTo(0, offsetTop - parentOffsetHeight + offsetHeight);\r\n        }\r\n    }\r\n}\r\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values-popup.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values-popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n    ViewChildren,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport {InputSearchComponent} from '../input-search/input-search.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\n\r\nexport interface lovViewModel {\r\n    checked: boolean\r\n    model: any\r\n}\r\n\r\n@Component({\r\n    selector: 'co-list-of-values-popup',\r\n    template: `\r\n        <div class=\"lov-options\" [overlay]=\"parentForOverlay\" [inheritWidth]=\"true\" [ngClass]=\"customCssClass\" id=\"lov-popup\"\r\n             role=\"listbox\" [tabindex]=\"-1\"\r\n             (clickOutside)=\"closePopup.emit($event)\">\r\n            <co-input-search *ngIf=\"multiselect\"\r\n                             tabindex=\"-1\"\r\n                             [(model)]=\"searchTerm\"\r\n                             [placeholder]=\"searchPlaceholder\"\r\n                             (keydown)=\"handleInputKeyDown($event)\"\r\n                             (modelChange)=\"filterViewModels()\"></co-input-search>\r\n            <ul class=\"dropdown-list\" #dropDownList>\r\n                <li #lovItem *ngFor=\"let viewModel of viewModels; let index = index\" [class.selected]=\"viewModel === highLightModel\"\r\n                    (click)=\"selectViewModel(viewModel, !multiselect)\" role=\"option\">\r\n                    <ng-container *ngIf=\"!multiselect\">\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"multiselect\">\r\n                        <co-input-checkbox [model]=\"viewModel.checked\" (modelChange)=\"selectViewModel(viewModel, false)\"></co-input-checkbox>\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesPopupComponent implements OnInit {\r\n    @ViewChildren('lovItem', { read: ElementRef }) set lovItems(children) {\r\n        this._lovItems = children.toArray();\r\n        this._scrollIntoView();\r\n    }\r\n\r\n    @ViewChild('dropDownList', { read: ElementRef })\r\n    public dropDownList: ElementRef;\r\n\r\n    @ViewChild(InputSearchComponent) set inputSearch(component: InputSearchComponent) {\r\n        this._searchInput = component;\r\n        if (this._searchInput) {\r\n            this._searchInput.requestFocus();\r\n        }\r\n    }\r\n\r\n    @Input()\r\n    public model: any;\r\n\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 searchPlaceholder: 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 parentForOverlay: ElementRef;\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n        this._prepareViewModelsMain();\r\n        this._prepareViewModels();\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Output()\r\n    public modelChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @Output()\r\n    public closePopup: EventEmitter<Event> = new EventEmitter<Event>();\r\n\r\n    @Output()\r\n    public keyDown: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\r\n\r\n    @HostBinding('class.co-list-of-values-popup')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public set searchTerm(value: string) {\r\n        this._searchTerm = value;\r\n        this.model = undefined;\r\n        this.highLightModel = undefined;\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get searchTerm(): string {\r\n        return this._searchTerm;\r\n    }\r\n\r\n    public viewModels: lovViewModel[] = [];\r\n    public viewModelsMain: lovViewModel[] = [];\r\n    public highLightModel: lovViewModel;\r\n\r\n    private _collection: any[] = [];\r\n    private _searchTerm: string = '';\r\n    private _lovItems: ElementRef[] = [];\r\n    private _searchInput: InputSearchComponent;\r\n\r\n    constructor(private _elementRef: ElementRef) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        if (this.model) {\r\n            if (!this.multiselect) {\r\n                this._scrollIntoView();\r\n            } else {\r\n                for (let i = 0; i < this.model.length; i++) {\r\n                    const viewModel: lovViewModel = this.viewModelsMain.find(v => JSON.stringify(v.model) === JSON.stringify(this.model[i]));\r\n                    if (viewModel) {\r\n                        viewModel.checked = true;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n        if (event) {\r\n            switch (event.code) {\r\n                case KeyboardKey.Down:\r\n                    this.selectNextOption();\r\n                    return false;\r\n                case KeyboardKey.Up:\r\n                    this.selectNextOption(true);\r\n                    return false;\r\n                case KeyboardKey.SpaceBar:\r\n                    if (this.highLightModel) {\r\n                        this.selectViewModel(this.highLightModel, false);\r\n                    } else {\r\n                        this.keyDown.next(event);\r\n                    }\r\n                    return false;\r\n                default:\r\n                    this.keyDown.next(event);\r\n                    return true;\r\n            }\r\n        }\r\n    }\r\n\r\n    public filterViewModels(): void {\r\n        if (!this.collection) {\r\n            return;\r\n        }\r\n        this._prepareViewModels();\r\n    }\r\n\r\n    public selectViewModel(viewModel: lovViewModel, closePopup: boolean = true): void {\r\n        if (!this.multiselect) {\r\n            this.selectModelByViewModel(viewModel, closePopup);\r\n        } else {\r\n            const idx: number = this.viewModels.findIndex(vm => vm === viewModel);\r\n            this.viewModels[idx].checked = !this.viewModels[idx].checked;\r\n            this.selectOptions();\r\n        }\r\n    }\r\n\r\n    public selectModelByViewModel(viewModel: lovViewModel, closePopup: boolean = true): void {\r\n        this.model = this.viewModelsMain.find(vm => vm === viewModel).model;\r\n        this.modelChange.emit(this.model);\r\n        this._scrollIntoView();\r\n        if (closePopup) {\r\n            this.closePopup.emit();\r\n        }\r\n    }\r\n\r\n    // for single select\r\n    public selectOptionAndClosePopup(): void {\r\n        if (!this.model && this.searchTerm) {\r\n            const wishModel: lovViewModel = this.viewModelsMain.find(vmm => vmm.model[this.displayField] === this.searchTerm);\r\n            if (wishModel) {\r\n                this.selectViewModel(wishModel);\r\n            } else {\r\n                this.model = undefined;\r\n                this.modelChange.emit(this.model);\r\n                this.searchTerm = '';\r\n            }\r\n        } else {\r\n            this.closePopup.emit();\r\n        }\r\n    }\r\n\r\n    // for multi select\r\n    public selectOptions(): void {\r\n        this.model = this.viewModelsMain.filter(v => v.checked).map(m => m.model);\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public selectNextOption(back: boolean = false): void {\r\n        let nextModel: any;\r\n        if (!this.highLightModel) {\r\n            nextModel = this.viewModels[back ? this.viewModels.length - 1 : 0];\r\n        } else {\r\n            const currentViewModelIdx: number = this.viewModels.findIndex(vm => vm === this.highLightModel);\r\n            if (back) {\r\n                nextModel = this.viewModels[currentViewModelIdx <= 0 ? this.viewModels.length - 1 : currentViewModelIdx - 1];\r\n            } else {\r\n                nextModel = this.viewModels[currentViewModelIdx >= this.viewModels.length - 1 ? 0 : currentViewModelIdx + 1];\r\n            }\r\n        }\r\n        this.highLightModel = nextModel;\r\n        if (!this.multiselect) {\r\n            this.selectViewModel(nextModel, false);\r\n        } else {\r\n            this._scrollIntoView();\r\n        }\r\n    }\r\n\r\n    private _prepareViewModelsMain(): void {\r\n        this.viewModelsMain.length = 0;\r\n        this.collection.forEach(m => {\r\n            this.viewModelsMain.push({checked: false, model: m});\r\n        })\r\n    }\r\n\r\n    private _prepareViewModels(): void {\r\n        this.viewModels.length = 0;\r\n        this.viewModels = this.viewModelsMain.filter(\r\n            vm => vm.model[this.displayField] && vm.model[this.displayField].toLowerCase().includes(this.searchTerm ? this.searchTerm.toLowerCase() : \"\"))\r\n    }\r\n\r\n    private _scrollIntoView(): void {\r\n        const activeIndex: number = this.viewModels.findIndex(vmm => vmm === this.highLightModel);\r\n        if (!this._lovItems || this._lovItems.length <= 0 || activeIndex < 0 || !this.dropDownList) {\r\n            return;\r\n        }\r\n        const activeItem = this._lovItems[activeIndex].nativeElement ? this._lovItems[activeIndex].nativeElement : undefined;\r\n        const scrollParent = this.dropDownList.nativeElement ? this.dropDownList.nativeElement : undefined;\r\n        this._scrollActiveItemIntoView(activeItem, scrollParent);\r\n    }\r\n\r\n    private _scrollActiveItemIntoView(activeItem: any, scrollParent: any): void {\r\n        if (!activeItem || !scrollParent) {\r\n            return;\r\n        }\r\n        let { offsetHeight, offsetTop } = activeItem;\r\n        let { offsetHeight: parentOffsetHeight, scrollTop, offsetTop: parentOffsetTop } = scrollParent;\r\n        offsetTop = offsetTop - parentOffsetTop;\r\n\r\n        const isAbove = offsetTop < scrollTop;\r\n        const isBelow = offsetTop + offsetHeight > scrollTop + parentOffsetHeight;\r\n\r\n        if (isAbove) {\r\n            scrollParent.scrollTo(0, offsetTop);\r\n        } else if (isBelow) {\r\n            scrollParent.scrollTo(0, offsetTop - parentOffsetHeight + offsetHeight);\r\n        }\r\n    }\r\n}\r\n"]}
@@ -11,7 +11,6 @@ export class ListOfValuesComponent extends BaseInputComponent {
11
11
  this.multiselect = false;
12
12
  this.displayField = 'description';
13
13
  this.searchDisabled = false;
14
- this.closeAfterOptionChosen = true;
15
14
  this.isSelectOpen = false;
16
15
  this.state = 'default';
17
16
  this.selectedModels = [];
@@ -41,6 +40,9 @@ export class ListOfValuesComponent extends BaseInputComponent {
41
40
  if (this._lovPopupComponentRef) {
42
41
  this._lovPopupComponentRef.instance.searchTerm = model;
43
42
  }
43
+ if (!this.selectedModel && model) {
44
+ this.openPopup();
45
+ }
44
46
  this.selectedModel = model;
45
47
  }
46
48
  handleInputKeyDown(event) {
@@ -98,8 +100,10 @@ export class ListOfValuesComponent extends BaseInputComponent {
98
100
  collection: this.collection
99
101
  }, {
100
102
  modelChange: (value) => this.optionChosen(value),
101
- closePopup: () => this.closePopup()
103
+ closePopup: () => this.closePopup(),
104
+ keyDown: (event) => this.handleInputKeyDown(event)
102
105
  });
106
+ this.keepFocussed = true;
103
107
  }
104
108
  removeOptionFromModel(chip) {
105
109
  if (this.multiselect) {
@@ -115,15 +119,13 @@ export class ListOfValuesComponent extends BaseInputComponent {
115
119
  }
116
120
  else {
117
121
  this.selectedModel = option[this.displayField];
118
- if (this.closeAfterOptionChosen) {
119
- this.toggleSelect();
120
- }
121
122
  }
122
123
  }
123
124
  this.model = option;
124
125
  this.modelChange.emit(this.model);
125
126
  }
126
127
  closePopup() {
128
+ this.keepFocussed = false;
127
129
  this.isSelectOpen = false;
128
130
  this.overlayService.removeComponent(this._lovPopupComponentRef);
129
131
  this._lovPopupComponentRef = undefined;
@@ -181,6 +183,8 @@ ListOfValuesComponent.decorators = [
181
183
  [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
182
184
  [showClearButton]="true"
183
185
  [useContent]="multiselect"
186
+ [customHeight]="multiselect"
187
+ [keepFocussed]="keepFocussed"
184
188
  (modelChange)="handleInputModelChange($event)"
185
189
  (click)="openPopup()"
186
190
  (rightIconClick)="toggleSelect()"
@@ -188,15 +192,15 @@ ListOfValuesComponent.decorators = [
188
192
  (clearIconClick)="clearModel($event)"
189
193
  (blur)="checkModel()"
190
194
  >
191
- </co-input-text>
192
- <ng-container *ngIf="multiselect">
193
- <div class="multiselect-chips-wrapper">
194
- <div class="chips" *ngFor="let chip of model">
195
- <span class="chips-description" [textContent]="chip[displayField]"></span>
196
- <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
195
+ <ng-container *ngIf="multiselect">
196
+ <div class="multiselect-chips-wrapper">
197
+ <div class="chips" *ngFor="let chip of model">
198
+ <span class="chips-description" [textContent]="chip[displayField]"></span>
199
+ <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
200
+ </div>
197
201
  </div>
198
- </div>
199
- </ng-container>
202
+ </ng-container>
203
+ </co-input-text>
200
204
  `,
201
205
  providers: [
202
206
  OverlayService
@@ -215,7 +219,6 @@ ListOfValuesComponent.propDecorators = {
215
219
  label: [{ type: Input }],
216
220
  customCssClass: [{ type: Input }],
217
221
  searchDisabled: [{ type: Input }],
218
- closeAfterOptionChosen: [{ type: Input }],
219
222
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values',] }]
220
223
  };
221
- //# 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    @Input()\r\n    public closeAfterOptionChosen: 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        }\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                if (this.closeAfterOptionChosen) {\r\n                  this.toggleSelect();\r\n                }\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"]}
224
+ //# 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                       [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\">\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    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        if (!this.selectedModel && model) {\r\n            this.openPopup();\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    }\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"]}
@@ -1874,6 +1874,7 @@ class BaseInputComponent {
1874
1874
  this.customWidth = false;
1875
1875
  this.customHeight = false;
1876
1876
  this.noTriangleGraphic = false;
1877
+ this.keepFocussed = false;
1877
1878
  this.halfWidth = false;
1878
1879
  this.fullWidth = false;
1879
1880
  this.excludeUserModelChange = false;
@@ -2241,7 +2242,7 @@ class BaseInputComponent {
2241
2242
  }
2242
2243
  doBlur(event) {
2243
2244
  setTimeout(() => {
2244
- if (this.keepFocus) {
2245
+ if (this.keepFocus || this.keepFocussed) {
2245
2246
  if (event) {
2246
2247
  event.preventDefault;
2247
2248
  }
@@ -2591,6 +2592,7 @@ BaseInputComponent.propDecorators = {
2591
2592
  customWidth: [{ type: Input }, { type: HostBinding, args: ["class.custom-width",] }],
2592
2593
  customHeight: [{ type: Input }, { type: HostBinding, args: ['class.custom-height',] }],
2593
2594
  noTriangleGraphic: [{ type: Input }],
2595
+ keepFocussed: [{ type: Input }],
2594
2596
  halfWidth: [{ type: Input }, { type: HostBinding, args: ["class.half-width",] }],
2595
2597
  fullWidth: [{ type: Input }, { type: HostBinding, args: ["class.full-width-important",] }],
2596
2598
  excludeUserModelChange: [{ type: Input }],
@@ -2630,6 +2632,9 @@ __decorate([
2630
2632
  __decorate([
2631
2633
  InputBoolean()
2632
2634
  ], BaseInputComponent.prototype, "noTriangleGraphic", void 0);
2635
+ __decorate([
2636
+ InputBoolean()
2637
+ ], BaseInputComponent.prototype, "keepFocussed", void 0);
2633
2638
  __decorate([
2634
2639
  InputBoolean()
2635
2640
  ], BaseInputComponent.prototype, "halfWidth", void 0);
@@ -5721,8 +5726,8 @@ InputTextComponent.decorators = [
5721
5726
  <label *ngIf="showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)"
5722
5727
  [textContent]="placeholder"></label>
5723
5728
  <input #input
5729
+ [class.input-input-hidden]="useContent"
5724
5730
  [ngClass]="align"
5725
- [hidden]="useContent"
5726
5731
  [type]="digitsOnly ? 'number' : type"
5727
5732
  [pattern]="type === 'date' ? pattern : undefined"
5728
5733
  [ngModel]="model"
@@ -5733,6 +5738,11 @@ InputTextComponent.decorators = [
5733
5738
  (ngModelChange)="modelChange.emit($event)"
5734
5739
  (keydown)="digitsOnly ? excludeNonDigitChars($event) : true"
5735
5740
  >
5741
+ <ng-container *ngIf="useContent">
5742
+ <div class="input-content-wrapper">
5743
+ <ng-content></ng-content>
5744
+ </div>
5745
+ </ng-container>
5736
5746
  <co-icon [class.show]="showClearButton && hasValue && focused && !readonly" class="input-text-clear-button" [icon]="icons.CrossSkinny" (click)="clearInput($event)"></co-icon>
5737
5747
  <div class="required-indicator"></div>
5738
5748
  </div>
@@ -10306,12 +10316,14 @@ ViewModeButtonsModule.decorators = [
10306
10316
  ];
10307
10317
 
10308
10318
  class ListOfValuesPopupComponent {
10309
- constructor() {
10319
+ constructor(_elementRef) {
10320
+ this._elementRef = _elementRef;
10310
10321
  this.multiselect = false;
10311
10322
  this.displayField = 'description';
10312
10323
  this.searchDisabled = false;
10313
10324
  this.modelChange = new EventEmitter();
10314
10325
  this.closePopup = new EventEmitter();
10326
+ this.keyDown = new EventEmitter();
10315
10327
  this.viewModels = [];
10316
10328
  this.viewModelsMain = [];
10317
10329
  this._collection = [];
@@ -10376,8 +10388,14 @@ class ListOfValuesPopupComponent {
10376
10388
  case KeyboardKey.SpaceBar:
10377
10389
  if (this.highLightModel) {
10378
10390
  this.selectViewModel(this.highLightModel, false);
10379
- return false;
10380
10391
  }
10392
+ else {
10393
+ this.keyDown.next(event);
10394
+ }
10395
+ return false;
10396
+ default:
10397
+ this.keyDown.next(event);
10398
+ return true;
10381
10399
  }
10382
10400
  }
10383
10401
  }
@@ -10445,6 +10463,9 @@ class ListOfValuesPopupComponent {
10445
10463
  if (!this.multiselect) {
10446
10464
  this.selectViewModel(nextModel, false);
10447
10465
  }
10466
+ else {
10467
+ this._scrollIntoView();
10468
+ }
10448
10469
  }
10449
10470
  _prepareViewModelsMain() {
10450
10471
  this.viewModelsMain.length = 0;
@@ -10469,8 +10490,9 @@ class ListOfValuesPopupComponent {
10469
10490
  if (!activeItem || !scrollParent) {
10470
10491
  return;
10471
10492
  }
10472
- const { offsetHeight, offsetTop } = activeItem;
10473
- const { offsetHeight: parentOffsetHeight, scrollTop } = scrollParent;
10493
+ let { offsetHeight, offsetTop } = activeItem;
10494
+ let { offsetHeight: parentOffsetHeight, scrollTop, offsetTop: parentOffsetTop } = scrollParent;
10495
+ offsetTop = offsetTop - parentOffsetTop;
10474
10496
  const isAbove = offsetTop < scrollTop;
10475
10497
  const isBelow = offsetTop + offsetHeight > scrollTop + parentOffsetHeight;
10476
10498
  if (isAbove) {
@@ -10486,16 +10508,17 @@ ListOfValuesPopupComponent.decorators = [
10486
10508
  selector: 'co-list-of-values-popup',
10487
10509
  template: `
10488
10510
  <div class="lov-options" [overlay]="parentForOverlay" [inheritWidth]="true" [ngClass]="customCssClass" id="lov-popup"
10489
- [tabIndex]="-1" role="listbox"
10511
+ role="listbox" [tabindex]="-1"
10490
10512
  (clickOutside)="closePopup.emit($event)">
10491
- <co-input-search *ngIf="multiselect"
10513
+ <co-input-search *ngIf="multiselect"
10514
+ tabindex="-1"
10492
10515
  [(model)]="searchTerm"
10493
10516
  [placeholder]="searchPlaceholder"
10494
10517
  (keydown)="handleInputKeyDown($event)"
10495
10518
  (modelChange)="filterViewModels()"></co-input-search>
10496
10519
  <ul class="dropdown-list" #dropDownList>
10497
10520
  <li #lovItem *ngFor="let viewModel of viewModels; let index = index" [class.selected]="viewModel === highLightModel"
10498
- (click)="selectViewModel(viewModel, false)" role="option">
10521
+ (click)="selectViewModel(viewModel, !multiselect)" role="option">
10499
10522
  <ng-container *ngIf="!multiselect">
10500
10523
  <span class="lov-options-text" [textContent]="viewModel.model[displayField]"></span>
10501
10524
  </ng-container>
@@ -10510,6 +10533,9 @@ ListOfValuesPopupComponent.decorators = [
10510
10533
  encapsulation: ViewEncapsulation.None
10511
10534
  },] }
10512
10535
  ];
10536
+ ListOfValuesPopupComponent.ctorParameters = () => [
10537
+ { type: ElementRef }
10538
+ ];
10513
10539
  ListOfValuesPopupComponent.propDecorators = {
10514
10540
  lovItems: [{ type: ViewChildren, args: ['lovItem', { read: ElementRef },] }],
10515
10541
  dropDownList: [{ type: ViewChild, args: ['dropDownList', { read: ElementRef },] }],
@@ -10524,6 +10550,7 @@ ListOfValuesPopupComponent.propDecorators = {
10524
10550
  collection: [{ type: Input }],
10525
10551
  modelChange: [{ type: Output }],
10526
10552
  closePopup: [{ type: Output }],
10553
+ keyDown: [{ type: Output }],
10527
10554
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values-popup',] }]
10528
10555
  };
10529
10556
 
@@ -10534,7 +10561,6 @@ class ListOfValuesComponent extends BaseInputComponent {
10534
10561
  this.multiselect = false;
10535
10562
  this.displayField = 'description';
10536
10563
  this.searchDisabled = false;
10537
- this.closeAfterOptionChosen = true;
10538
10564
  this.isSelectOpen = false;
10539
10565
  this.state = 'default';
10540
10566
  this.selectedModels = [];
@@ -10564,6 +10590,9 @@ class ListOfValuesComponent extends BaseInputComponent {
10564
10590
  if (this._lovPopupComponentRef) {
10565
10591
  this._lovPopupComponentRef.instance.searchTerm = model;
10566
10592
  }
10593
+ if (!this.selectedModel && model) {
10594
+ this.openPopup();
10595
+ }
10567
10596
  this.selectedModel = model;
10568
10597
  }
10569
10598
  handleInputKeyDown(event) {
@@ -10621,8 +10650,10 @@ class ListOfValuesComponent extends BaseInputComponent {
10621
10650
  collection: this.collection
10622
10651
  }, {
10623
10652
  modelChange: (value) => this.optionChosen(value),
10624
- closePopup: () => this.closePopup()
10653
+ closePopup: () => this.closePopup(),
10654
+ keyDown: (event) => this.handleInputKeyDown(event)
10625
10655
  });
10656
+ this.keepFocussed = true;
10626
10657
  }
10627
10658
  removeOptionFromModel(chip) {
10628
10659
  if (this.multiselect) {
@@ -10638,15 +10669,13 @@ class ListOfValuesComponent extends BaseInputComponent {
10638
10669
  }
10639
10670
  else {
10640
10671
  this.selectedModel = option[this.displayField];
10641
- if (this.closeAfterOptionChosen) {
10642
- this.toggleSelect();
10643
- }
10644
10672
  }
10645
10673
  }
10646
10674
  this.model = option;
10647
10675
  this.modelChange.emit(this.model);
10648
10676
  }
10649
10677
  closePopup() {
10678
+ this.keepFocussed = false;
10650
10679
  this.isSelectOpen = false;
10651
10680
  this.overlayService.removeComponent(this._lovPopupComponentRef);
10652
10681
  this._lovPopupComponentRef = undefined;
@@ -10704,6 +10733,8 @@ ListOfValuesComponent.decorators = [
10704
10733
  [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
10705
10734
  [showClearButton]="true"
10706
10735
  [useContent]="multiselect"
10736
+ [customHeight]="multiselect"
10737
+ [keepFocussed]="keepFocussed"
10707
10738
  (modelChange)="handleInputModelChange($event)"
10708
10739
  (click)="openPopup()"
10709
10740
  (rightIconClick)="toggleSelect()"
@@ -10711,15 +10742,15 @@ ListOfValuesComponent.decorators = [
10711
10742
  (clearIconClick)="clearModel($event)"
10712
10743
  (blur)="checkModel()"
10713
10744
  >
10714
- </co-input-text>
10715
- <ng-container *ngIf="multiselect">
10716
- <div class="multiselect-chips-wrapper">
10717
- <div class="chips" *ngFor="let chip of model">
10718
- <span class="chips-description" [textContent]="chip[displayField]"></span>
10719
- <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
10745
+ <ng-container *ngIf="multiselect">
10746
+ <div class="multiselect-chips-wrapper">
10747
+ <div class="chips" *ngFor="let chip of model">
10748
+ <span class="chips-description" [textContent]="chip[displayField]"></span>
10749
+ <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
10750
+ </div>
10720
10751
  </div>
10721
- </div>
10722
- </ng-container>
10752
+ </ng-container>
10753
+ </co-input-text>
10723
10754
  `,
10724
10755
  providers: [
10725
10756
  OverlayService
@@ -10738,7 +10769,6 @@ ListOfValuesComponent.propDecorators = {
10738
10769
  label: [{ type: Input }],
10739
10770
  customCssClass: [{ type: Input }],
10740
10771
  searchDisabled: [{ type: Input }],
10741
- closeAfterOptionChosen: [{ type: Input }],
10742
10772
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values',] }]
10743
10773
  };
10744
10774