@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.
- package/bundles/colijnit-corecomponents_v12.umd.js +35 -13
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/base/base-input.component.js +7 -2
- package/esm2015/lib/components/input-search/input-search.component.js +2 -2
- package/esm2015/lib/components/input-text/input-text.component.js +7 -2
- package/esm2015/lib/components/list-of-values/list-of-values-popup.component.js +25 -8
- package/esm2015/lib/components/list-of-values/list-of-values.component.js +18 -15
- package/fesm2015/colijnit-corecomponents_v12.js +53 -23
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/base/base-input.component.d.ts +1 -0
- package/lib/components/grid-toolbar/style/_material-definition.scss +1 -1
- package/lib/components/input-text/style/_layout.scss +9 -0
- package/lib/components/input-text/style/_material-definition.scss +1 -1
- package/lib/components/list-of-values/list-of-values-popup.component.d.ts +3 -0
- package/lib/components/list-of-values/list-of-values.component.d.ts +0 -1
- package/lib/components/list-of-values/style/_layout.scss +22 -7
- package/lib/components/list-of-values/style/_material-definition.scss +0 -10
- package/lib/style/_variables.scss +1 -0
- package/package.json +1 -1
|
@@ -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
|
-
|
|
169
|
-
|
|
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
|
-
[
|
|
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,
|
|
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":"AAAA,OAAO,EACH,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EAEL,MAAM,EACN,SAAS,EACT,YAAY,EACZ,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,oBAAoB,EAAC,MAAM,wCAAwC,CAAC;AAC5E,OAAO,EAAC,WAAW,EAAC,MAAM,mCAAmC,CAAC;AAmC9D,MAAM,OAAO,0BAA0B;IAmFnC,YAAoB,WAAuB;QAAvB,gBAAW,GAAX,WAAW,CAAY;QA/DpC,gBAAW,GAAY,KAAK,CAAC;QAG7B,iBAAY,GAAW,aAAa,CAAC;QASrC,mBAAc,GAAY,KAAK,CAAC;QAkBhC,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;QAGzD,eAAU,GAAwB,IAAI,YAAY,EAAS,CAAC;QAG5D,YAAO,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAkBzE,eAAU,GAAmB,EAAE,CAAC;QAChC,mBAAc,GAAmB,EAAE,CAAC;QAGnC,gBAAW,GAAU,EAAE,CAAC;QACxB,gBAAW,GAAW,EAAE,CAAC;QACzB,cAAS,GAAiB,EAAE,CAAC;IAIrC,CAAC;IAnFD,IAAmD,QAAQ,CAAC,QAAQ;QAChE,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC;QACpC,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAKD,IAAqC,WAAW,CAAC,SAA+B;QAC5E,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAC9B,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;SACpC;IACL,CAAC;IAuBD,IACW,UAAU,CAAC,KAAY;QAC9B,IAAI,CAAC,WAAW,GAAG,KAAK,IAAI,EAAE,CAAC;QAC/B,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAED,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAYM,SAAS;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAW,UAAU,CAAC,KAAa;QAC/B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QAChC,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAED,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAcD,QAAQ;QACJ,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;gBACnB,IAAI,CAAC,eAAe,EAAE,CAAC;aAC1B;iBAAM;gBACH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACxC,MAAM,SAAS,GAAiB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACzH,IAAI,SAAS,EAAE;wBACX,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC;qBAC5B;iBACJ;aACJ;SACJ;IACL,CAAC;IAEM,kBAAkB,CAAC,KAAoB;QAC1C,IAAI,KAAK,EAAE;YACP,QAAQ,KAAK,CAAC,IAAI,EAAE;gBAChB,KAAK,WAAW,CAAC,IAAI;oBACjB,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,OAAO,KAAK,CAAC;gBACjB,KAAK,WAAW,CAAC,EAAE;oBACf,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;oBAC5B,OAAO,KAAK,CAAC;gBACjB,KAAK,WAAW,CAAC,QAAQ;oBACrB,IAAI,IAAI,CAAC,cAAc,EAAE;wBACrB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;qBACpD;yBAAM;wBACH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBAC5B;oBACD,OAAO,KAAK,CAAC;gBACjB;oBACI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBACzB,OAAO,IAAI,CAAC;aACnB;SACJ;IACL,CAAC;IAEM,gBAAgB;QACnB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAClB,OAAO;SACV;QACD,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAEM,eAAe,CAAC,SAAuB,EAAE,aAAsB,IAAI;QACtE,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,sBAAsB,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;SACtD;aAAM;YACH,MAAM,GAAG,GAAW,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC;YACtE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;YAC7D,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;IACL,CAAC;IAEM,sBAAsB,CAAC,SAAuB,EAAE,aAAsB,IAAI;QAC7E,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC,KAAK,CAAC;QACpE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,UAAU,EAAE;YACZ,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;SAC1B;IACL,CAAC;IAED,oBAAoB;IACb,yBAAyB;QAC5B,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE;YAChC,MAAM,SAAS,GAAiB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,CAAC,UAAU,CAAC,CAAC;YAClH,IAAI,SAAS,EAAE;gBACX,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;aACnC;iBAAM;gBACH,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;gBACvB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAClC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;aACxB;SACJ;aAAM;YACH,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;SAC1B;IACL,CAAC;IAED,mBAAmB;IACZ,aAAa;QAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC1E,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEM,gBAAgB,CAAC,OAAgB,KAAK;QACzC,IAAI,SAAc,CAAC;QACnB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACtB,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACtE;aAAM;YACH,MAAM,mBAAmB,GAAW,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;YAChG,IAAI,IAAI,EAAE;gBACN,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,mBAAmB,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,mBAAmB,GAAG,CAAC,CAAC,CAAC;aAChH;iBAAM;gBACH,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,mBAAmB,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,mBAAmB,GAAG,CAAC,CAAC,CAAC;aAChH;SACJ;QACD,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;SAC1C;aAAM;YACH,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;IACL,CAAC;IAEO,sBAAsB;QAC1B,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;QAC/B,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACxB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;QACzD,CAAC,CAAC,CAAA;IACN,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CACxC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IACtJ,CAAC;IAEO,eAAe;QACnB,MAAM,WAAW,GAAW,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1F,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,IAAI,WAAW,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACxF,OAAO;SACV;QACD,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;QACrH,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;QACnG,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;IAC7D,CAAC;IAEO,yBAAyB,CAAC,UAAe,EAAE,YAAiB;QAChE,IAAI,CAAC,UAAU,IAAI,CAAC,YAAY,EAAE;YAC9B,OAAO;SACV;QACD,IAAI,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC;QAC7C,IAAI,EAAE,YAAY,EAAE,kBAAkB,EAAE,SAAS,EAAE,SAAS,EAAE,eAAe,EAAE,GAAG,YAAY,CAAC;QAC/F,SAAS,GAAG,SAAS,GAAG,eAAe,CAAC;QAExC,MAAM,OAAO,GAAG,SAAS,GAAG,SAAS,CAAC;QACtC,MAAM,OAAO,GAAG,SAAS,GAAG,YAAY,GAAG,SAAS,GAAG,kBAAkB,CAAC;QAE1E,IAAI,OAAO,EAAE;YACT,YAAY,CAAC,QAAQ,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;SACvC;aAAM,IAAI,OAAO,EAAE;YAChB,YAAY,CAAC,QAAQ,CAAC,CAAC,EAAE,SAAS,GAAG,kBAAkB,GAAG,YAAY,CAAC,CAAC;SAC3E;IACL,CAAC;;;YAnQJ,SAAS,SAAC;gBACP,QAAQ,EAAE,yBAAyB;gBACnC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;KAuBT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;YA7CG,UAAU;;;uBA+CT,YAAY,SAAC,SAAS,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;2BAK5C,SAAS,SAAC,cAAc,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;0BAG9C,SAAS,SAAC,oBAAoB;oBAO9B,KAAK;0BAGL,KAAK;2BAGL,KAAK;gCAGL,KAAK;6BAGL,KAAK;6BAGL,KAAK;+BAGL,KAAK;yBAGL,KAAK;0BAYL,MAAM;yBAGN,MAAM;sBAGN,MAAM;wBAGN,WAAW,SAAC,+BAA+B","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
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
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
|
-
</
|
|
199
|
-
</
|
|
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
|
-
|
|
10473
|
-
|
|
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
|
-
[
|
|
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,
|
|
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
|
-
|
|
10715
|
-
|
|
10716
|
-
|
|
10717
|
-
|
|
10718
|
-
|
|
10719
|
-
|
|
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
|
-
</
|
|
10722
|
-
</
|
|
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
|
|