@colijnit/corecomponents_v12 12.1.4 → 12.1.5

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.
@@ -11,6 +11,7 @@ export class ListOfValuesComponent extends BaseInputComponent {
11
11
  this.multiselect = false;
12
12
  this.displayField = 'description';
13
13
  this.searchDisabled = false;
14
+ this.closeAfterOptionChosen = true;
14
15
  this.isSelectOpen = false;
15
16
  this.state = 'default';
16
17
  this.selectedModels = [];
@@ -114,6 +115,9 @@ export class ListOfValuesComponent extends BaseInputComponent {
114
115
  }
115
116
  else {
116
117
  this.selectedModel = option[this.displayField];
118
+ if (this.closeAfterOptionChosen) {
119
+ this.toggleSelect();
120
+ }
117
121
  }
118
122
  }
119
123
  this.model = option;
@@ -211,6 +215,7 @@ ListOfValuesComponent.propDecorators = {
211
215
  label: [{ type: Input }],
212
216
  customCssClass: [{ type: Input }],
213
217
  searchDisabled: [{ type: Input }],
218
+ closeAfterOptionChosen: [{ type: Input }],
214
219
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values',] }]
215
220
  };
216
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ComponentRef, ElementRef, HostBinding, Input, OnInit, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {ListOfValuesPopupComponent} from './list-of-values-popup.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\n\r\n@Component({\r\n    selector: 'co-list-of-values',\r\n    template: `\r\n        <co-input-text aria-haspopup=\"listbox\" [attr.aria-expanded]=\"isSelectOpen\" aria-controls=\"lov-popup\" role=\"combobox\"\r\n                       class=\"no-focus-line\"\r\n                       overlayParent\r\n                       #parentForOverlay=\"overlayParent\" type=\"text\" [id]=\"label\"\r\n                       [model]=\"multiselect ? selectedModels : selectedModel\"\r\n                       [placeholder]=\"label\"\r\n                       [readonly]=\"readonly\"\r\n                       [disabled]=\"disabled\"\r\n                       [required]=\"required\"\r\n                       [noClickFocus]=\"false\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [rightIcon]=\"isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular\"\r\n                       [showClearButton]=\"true\"\r\n                       [useContent]=\"multiselect\"\r\n                       (modelChange)=\"handleInputModelChange($event)\"\r\n                       (click)=\"openPopup()\"\r\n                       (rightIconClick)=\"toggleSelect()\"\r\n                       (keydown)=\"handleInputKeyDown($event)\"\r\n                       (clearIconClick)=\"clearModel($event)\"\r\n                       (blur)=\"checkModel()\"\r\n        >\r\n        </co-input-text>\r\n        <ng-container *ngIf=\"multiselect\">\r\n            <div class=\"multiselect-chips-wrapper\">\r\n                <div class=\"chips\" *ngFor=\"let chip of model\">\r\n                    <span class=\"chips-description\" [textContent]=\"chip[displayField]\"></span>\r\n                    <co-icon class=\"remove-chip-icon\" [icon]=\"icons.CrossSkinny\" (click)=\"removeOptionFromModel(chip)\"></co-icon>\r\n                </div>\r\n            </div>\r\n        </ng-container>\r\n    `,\r\n    providers: [\r\n        OverlayService\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesComponent extends BaseInputComponent<any> implements OnInit {\r\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n    @Input()\r\n    public set model(value: any) {\r\n        super.model = value;\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public get model(): any {\r\n        return super.model;\r\n    }\r\n\r\n    @ViewChild('parentForOverlay', {read: ElementRef})\r\n    public parentForOverlay: ElementRef;\r\n\r\n    @HostBinding('class.custom-height')\r\n    @HostBinding('class.multi-select')\r\n    @Input()\r\n    public multiselect: boolean = false;\r\n\r\n    @Input()\r\n    public displayField: string = 'description';\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Input()\r\n    public leftIconData: SafeHtml | undefined;\r\n\r\n    @Input()\r\n    public searchPlaceholder: string;\r\n\r\n    @Input()\r\n    public label: string;\r\n\r\n    @Input()\r\n    public customCssClass: string;\r\n\r\n    @Input()\r\n    public searchDisabled: boolean = false;\r\n\r\n    @HostBinding('class.co-list-of-values')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public isSelectOpen: boolean = false;\r\n    public state: string = 'default';\r\n    public selectedModel: string;\r\n    public selectedModels: string[] = [];\r\n\r\n    private _collection: any[] = [];\r\n\r\n    private _lovPopupComponentRef: ComponentRef<any>;\r\n\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public handleInputModelChange(model: string): void {\r\n        if (this._lovPopupComponentRef) {\r\n            this._lovPopupComponentRef.instance.searchTerm = model;\r\n        }\r\n        this.selectedModel = model;\r\n    }\r\n\r\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n        if (event) {\r\n            if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {\r\n                this.openPopup();\r\n                return false;\r\n            }\r\n            if (this._lovPopupComponentRef) {\r\n                switch (event.code) {\r\n                    case KeyboardKey.Down:\r\n                        this._lovPopupComponentRef.instance.selectNextOption();\r\n                        return false;\r\n                    case KeyboardKey.Up:\r\n                        this._lovPopupComponentRef.instance.selectNextOption(true);\r\n                        return false;\r\n                    case KeyboardKey.Enter:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                        return false;\r\n                    case KeyboardKey.Tab:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public clearModel(event: MouseEvent): void {\r\n        this.setModel(undefined);\r\n    }\r\n\r\n    public toggleSelect(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = !this.isSelectOpen;\r\n        if (this.isSelectOpen) {\r\n            this.openPopup();\r\n        } else {\r\n            this.closePopup();\r\n        }\r\n        this.state = (this.state === 'default' ? 'rotated' : 'default');\r\n    }\r\n\r\n    public openPopup(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = true;\r\n        this._lovPopupComponentRef = this.overlayService.createComponent(ListOfValuesPopupComponent, {\r\n                parentForOverlay: this.elementRef,\r\n                customCssClass: this.customCssClass,\r\n                searchDisabled: this.searchDisabled,\r\n                searchPlaceholder: this.searchPlaceholder,\r\n                displayField: this.displayField,\r\n                multiselect: this.multiselect,\r\n                model: this.model,\r\n                collection: this.collection\r\n            }, {\r\n                modelChange: (value) => this.optionChosen(value),\r\n                closePopup: () => this.closePopup()\r\n            });\r\n    }\r\n\r\n    public removeOptionFromModel(chip: any): void {\r\n        if (this.multiselect) {\r\n            const idx: number = this.model.findIndex(m => m === chip);\r\n            this.model.splice(idx, 1);\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    public optionChosen(option: any): void {\r\n        if (option) {\r\n            if (this.multiselect) {\r\n                this.selectedModels = option.map(o => o[this.displayField]);\r\n            } else {\r\n                this.selectedModel = option[this.displayField];\r\n            }\r\n        }\r\n        this.model = option;\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public closePopup(): void {\r\n        this.isSelectOpen = false;\r\n        this.overlayService.removeComponent(this._lovPopupComponentRef);\r\n        this._lovPopupComponentRef = undefined;\r\n        this.focused = false;\r\n    }\r\n\r\n    public checkModel(): void {\r\n        if (!this.multiselect && this.selectedModel && this.collection) {\r\n            const model: any = this.collection.find(c => c[this.displayField] === this.selectedModel);\r\n            if (model) {\r\n                this.model = model;\r\n            } else {\r\n                this.model = undefined;\r\n            }\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    private _setSelectedModel(): void {\r\n        if (this.multiselect) {\r\n            if (this.model) {\r\n                this.selectedModels.length = 0;\r\n                this.model.forEach(m => {\r\n                    this.selectedModels.push(m[this.displayField]);\r\n                });\r\n            } else {\r\n                this.selectedModels.length = 0;\r\n            }\r\n        } else {\r\n            if (this.model) {\r\n                this.selectedModel = this.model[this.displayField];\r\n            } else {\r\n                this.selectedModel = \"\";\r\n            }\r\n        }\r\n    }\r\n\r\n}\r\n"]}
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"]}
@@ -4,6 +4,7 @@ export class OverlayDirective {
4
4
  this.keepInView = false;
5
5
  this.inheritWidth = false;
6
6
  this.rightAlign = false;
7
+ this.fullSize = false;
7
8
  this.handleScroll = (event) => {
8
9
  this._checkAndPlaceElement();
9
10
  };
@@ -57,11 +58,18 @@ export class OverlayDirective {
57
58
  _checkAndPlaceElement() {
58
59
  if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {
59
60
  const elementRect = this._elementRef.nativeElement.getBoundingClientRect();
60
- const parentRect = this._parent.nativeElement.getBoundingClientRect();
61
+ const parentBoundingRect = this._parent.nativeElement.getBoundingClientRect();
62
+ const parentRect = {
63
+ bottom: this._parent.nativeElement.offsetTop + parentBoundingRect.height,
64
+ right: this._parent.nativeElement.offsetLeft + parentBoundingRect.width,
65
+ left: this._parent.nativeElement.offsetLeft,
66
+ top: this._parent.nativeElement.offsetTop
67
+ };
61
68
  this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);
62
69
  }
63
70
  }
64
71
  _placeElement(bottom, right, parentRect, elementRect) {
72
+ this._elementRef.nativeElement.style.position = "fixed";
65
73
  if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom
66
74
  this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + "px";
67
75
  this._elementRef.nativeElement.classList.add('top');
@@ -76,18 +84,23 @@ export class OverlayDirective {
76
84
  if (this.rightAlign) {
77
85
  this._elementRef.nativeElement.style.left = (parentRect.right - elementRect.width) + "px";
78
86
  }
87
+ else if (this.fullSize) {
88
+ this._elementRef.nativeElement.style.left = "0px";
89
+ }
79
90
  else {
80
91
  this._elementRef.nativeElement.style.left = parentRect.left + "px";
81
92
  }
82
93
  if (this.keepInView) {
83
- if (elementRect.right > window.innerWidth) {
94
+ const viewToKeepIn = this.view ? this.view : window;
95
+ const viewWidth = viewToKeepIn.innerWidth || viewToKeepIn.clientWidth;
96
+ if (elementRect.right > viewWidth) {
84
97
  //see if we can move it to the left
85
- if ((window.innerWidth - elementRect.width) > 0) {
86
- this._elementRef.nativeElement.style.left = (window.innerWidth - elementRect.width) + "px";
98
+ if (((viewWidth - elementRect.width) > 0) && !this.fullSize) {
99
+ this._elementRef.nativeElement.style.left = (viewWidth - elementRect.width) + "px";
87
100
  }
88
101
  else { //resize so it fits into view
89
- this._elementRef.nativeElement.style.width = window.innerWidth + "px";
90
- this._elementRef.nativeElement.style.left = 0;
102
+ this._elementRef.nativeElement.style.width = viewWidth + "px";
103
+ this._elementRef.nativeElement.style.left = viewToKeepIn.offsetLeft + "px";
91
104
  }
92
105
  }
93
106
  }
@@ -103,8 +116,10 @@ OverlayDirective.ctorParameters = () => [
103
116
  ];
104
117
  OverlayDirective.propDecorators = {
105
118
  parent: [{ type: Input, args: ["overlay",] }],
119
+ view: [{ type: Input }],
106
120
  keepInView: [{ type: Input }],
107
121
  inheritWidth: [{ type: Input }],
108
- rightAlign: [{ type: Input }]
122
+ rightAlign: [{ type: Input }],
123
+ fullSize: [{ type: Input }]
109
124
  };
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/overlay/overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, OnDestroy, OnInit} from '@angular/core';\r\nimport {OverlayParentDirective} from './overlay-parent.directive';\r\n\r\n@Directive({\r\n  selector: \"[overlay]\"\r\n})\r\nexport class OverlayDirective implements OnDestroy, OnInit {\r\n\r\n  @Input(\"overlay\")\r\n  public set parent(value: OverlayParentDirective | ElementRef) {\r\n    if (value) {\r\n      this._parent = value instanceof ElementRef ? value : value.elementRef;\r\n    } else {\r\n      if (this._parent && this._resizeObserver) {\r\n        this._resizeObserver.disconnect();\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public keepInView: boolean = false;\r\n\r\n  @Input()\r\n  public inheritWidth: boolean = false;\r\n\r\n  @Input()\r\n  public rightAlign: boolean = false;\r\n\r\n  private _elementRef: ElementRef;\r\n  private _resizeObserver: ResizeObserver;\r\n  private _intersectionObserver: IntersectionObserver;\r\n  private _parent: ElementRef;\r\n\r\n  constructor(\r\n      elementRef: ElementRef\r\n  ) {\r\n    this._elementRef = elementRef;\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    document.removeEventListener(\"scroll\", this.handleScroll, true);\r\n    if (this._intersectionObserver) {\r\n      this._intersectionObserver.disconnect();\r\n    }\r\n    if (this._resizeObserver) {\r\n      this._resizeObserver.disconnect();\r\n    }\r\n    this._elementRef = undefined;\r\n    this._parent = undefined;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this._elementRef || !this._elementRef.nativeElement) {\r\n      return;\r\n    }\r\n    document.addEventListener(\"scroll\", this.handleScroll, true);\r\n    this._checkAndPlaceElement();\r\n    this._resizeObserver = new ResizeObserver(\r\n        (entries) => {\r\n          this._checkAndPlaceElement();\r\n        }\r\n    );\r\n    this._intersectionObserver = new IntersectionObserver(\r\n        (entries: IntersectionObserverEntry[]) => {\r\n          if (entries && entries.length > 0) {\r\n            if (entries[0].isIntersecting === false) {\r\n              this._elementRef.nativeElement.style.opacity = 0; // hide cause parent is not visible\r\n            } else {\r\n              this._elementRef.nativeElement.style.opacity = 1;\r\n            }\r\n          }\r\n        }, {\r\n          root: null\r\n        }\r\n    );\r\n    this._intersectionObserver.observe(this._parent.nativeElement); // observe parent for visibility\r\n    this._resizeObserver.observe(document.body);\r\n  }\r\n\r\n  public handleScroll = (event: Event) => {\r\n    this._checkAndPlaceElement();\r\n  }\r\n\r\n  private _checkAndPlaceElement(): void {\r\n    if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {\r\n      const elementRect: ClientRect = this._elementRef.nativeElement.getBoundingClientRect();\r\n      const parentRect: ClientRect = this._parent.nativeElement.getBoundingClientRect();\r\n      this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);\r\n    }\r\n  }\r\n\r\n  private _placeElement(bottom: number, right: number, parentRect: ClientRect, elementRect: ClientRect): void {\r\n    if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom\r\n      this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + \"px\";\r\n      this._elementRef.nativeElement.classList.add('top');\r\n    } else {\r\n      this._elementRef.nativeElement.classList.remove('top');\r\n      this._elementRef.nativeElement.style.top = parentRect.bottom + \"px\";\r\n    }\r\n    if (this.inheritWidth) {\r\n      this._elementRef.nativeElement.style.width = parentRect.width + \"px\";\r\n    }\r\n    if (this.rightAlign) {\r\n      this._elementRef.nativeElement.style.left = (parentRect.right - elementRect.width) + \"px\";\r\n    } else {\r\n      this._elementRef.nativeElement.style.left = parentRect.left + \"px\";\r\n    }\r\n    if (this.keepInView) {\r\n      if (elementRect.right > window.innerWidth) {\r\n        //see if we can move it to the left\r\n        if ((window.innerWidth - elementRect.width) > 0) {\r\n          this._elementRef.nativeElement.style.left = (window.innerWidth - elementRect.width) + \"px\";\r\n        } else { //resize so it fits into view\r\n          this._elementRef.nativeElement.style.width = window.innerWidth + \"px\";\r\n          this._elementRef.nativeElement.style.left = 0;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/overlay/overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, OnDestroy, OnInit} from '@angular/core';\r\nimport {OverlayParentDirective} from './overlay-parent.directive';\r\n\r\n@Directive({\r\n  selector: \"[overlay]\"\r\n})\r\nexport class OverlayDirective implements OnDestroy, OnInit {\r\n\r\n  @Input(\"overlay\")\r\n  public set parent(value: OverlayParentDirective | ElementRef) {\r\n    if (value) {\r\n      this._parent = value instanceof ElementRef ? value : value.elementRef;\r\n    } else {\r\n      if (this._parent && this._resizeObserver) {\r\n        this._resizeObserver.disconnect();\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public view: HTMLElement;\r\n\r\n  @Input()\r\n  public keepInView: boolean = false;\r\n\r\n  @Input()\r\n  public inheritWidth: boolean = false;\r\n\r\n  @Input()\r\n  public rightAlign: boolean = false;\r\n\r\n  @Input()\r\n  public fullSize: boolean = false;\r\n\r\n  private _elementRef: ElementRef;\r\n  private _resizeObserver: ResizeObserver;\r\n  private _intersectionObserver: IntersectionObserver;\r\n  private _parent: ElementRef;\r\n\r\n  constructor(\r\n      elementRef: ElementRef\r\n  ) {\r\n    this._elementRef = elementRef;\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    document.removeEventListener(\"scroll\", this.handleScroll, true);\r\n    if (this._intersectionObserver) {\r\n      this._intersectionObserver.disconnect();\r\n    }\r\n    if (this._resizeObserver) {\r\n      this._resizeObserver.disconnect();\r\n    }\r\n    this._elementRef = undefined;\r\n    this._parent = undefined;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this._elementRef || !this._elementRef.nativeElement) {\r\n      return;\r\n    }\r\n    document.addEventListener(\"scroll\", this.handleScroll, true);\r\n    this._checkAndPlaceElement();\r\n    this._resizeObserver = new ResizeObserver(\r\n        (entries) => {\r\n          this._checkAndPlaceElement();\r\n        }\r\n    );\r\n    this._intersectionObserver = new IntersectionObserver(\r\n        (entries: IntersectionObserverEntry[]) => {\r\n          if (entries && entries.length > 0) {\r\n            if (entries[0].isIntersecting === false) {\r\n              this._elementRef.nativeElement.style.opacity = 0; // hide cause parent is not visible\r\n            } else {\r\n              this._elementRef.nativeElement.style.opacity = 1;\r\n            }\r\n          }\r\n        }, {\r\n          root: null\r\n        }\r\n    );\r\n    this._intersectionObserver.observe(this._parent.nativeElement); // observe parent for visibility\r\n    this._resizeObserver.observe(document.body);\r\n  }\r\n\r\n  public handleScroll = (event: Event) => {\r\n    this._checkAndPlaceElement();\r\n  }\r\n\r\n  private _checkAndPlaceElement(): void {\r\n    if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {\r\n      const elementRect: ClientRect = this._elementRef.nativeElement.getBoundingClientRect();\r\n      const parentBoundingRect: ClientRect = this._parent.nativeElement.getBoundingClientRect();\r\n      const parentRect: {} = {\r\n        bottom: this._parent.nativeElement.offsetTop + parentBoundingRect.height,\r\n        right: this._parent.nativeElement.offsetLeft + parentBoundingRect.width,\r\n        left: this._parent.nativeElement.offsetLeft,\r\n        top: this._parent.nativeElement.offsetTop\r\n      }\r\n      this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);\r\n    }\r\n  }\r\n\r\n  private _placeElement(bottom: number, right: number, parentRect: any, elementRect: ClientRect): void {\r\n    this._elementRef.nativeElement.style.position = \"fixed\";\r\n    if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom\r\n      this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + \"px\";\r\n      this._elementRef.nativeElement.classList.add('top');\r\n    } else {\r\n      this._elementRef.nativeElement.classList.remove('top');\r\n      this._elementRef.nativeElement.style.top = parentRect.bottom + \"px\";\r\n    }\r\n    if (this.inheritWidth) {\r\n      this._elementRef.nativeElement.style.width = parentRect.width + \"px\";\r\n    }\r\n    if (this.rightAlign) {\r\n      this._elementRef.nativeElement.style.left = (parentRect.right - elementRect.width) + \"px\";\r\n    } else if (this.fullSize) {\r\n      this._elementRef.nativeElement.style.left = \"0px\";\r\n    } else {\r\n      this._elementRef.nativeElement.style.left = parentRect.left + \"px\";\r\n    }\r\n    if (this.keepInView) {\r\n      const viewToKeepIn: any = this.view ? this.view : window;\r\n      const viewWidth: number = viewToKeepIn.innerWidth || viewToKeepIn.clientWidth;\r\n      if (elementRect.right > viewWidth) {\r\n        //see if we can move it to the left\r\n        if (((viewWidth - elementRect.width) > 0) && !this.fullSize) {\r\n          this._elementRef.nativeElement.style.left = (viewWidth - elementRect.width) + \"px\";\r\n        } else { //resize so it fits into view\r\n          this._elementRef.nativeElement.style.width = viewWidth + \"px\";\r\n          this._elementRef.nativeElement.style.left = viewToKeepIn.offsetLeft + \"px\";\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
@@ -5382,6 +5382,7 @@ class OverlayDirective {
5382
5382
  this.keepInView = false;
5383
5383
  this.inheritWidth = false;
5384
5384
  this.rightAlign = false;
5385
+ this.fullSize = false;
5385
5386
  this.handleScroll = (event) => {
5386
5387
  this._checkAndPlaceElement();
5387
5388
  };
@@ -5435,11 +5436,18 @@ class OverlayDirective {
5435
5436
  _checkAndPlaceElement() {
5436
5437
  if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {
5437
5438
  const elementRect = this._elementRef.nativeElement.getBoundingClientRect();
5438
- const parentRect = this._parent.nativeElement.getBoundingClientRect();
5439
+ const parentBoundingRect = this._parent.nativeElement.getBoundingClientRect();
5440
+ const parentRect = {
5441
+ bottom: this._parent.nativeElement.offsetTop + parentBoundingRect.height,
5442
+ right: this._parent.nativeElement.offsetLeft + parentBoundingRect.width,
5443
+ left: this._parent.nativeElement.offsetLeft,
5444
+ top: this._parent.nativeElement.offsetTop
5445
+ };
5439
5446
  this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);
5440
5447
  }
5441
5448
  }
5442
5449
  _placeElement(bottom, right, parentRect, elementRect) {
5450
+ this._elementRef.nativeElement.style.position = "fixed";
5443
5451
  if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom
5444
5452
  this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + "px";
5445
5453
  this._elementRef.nativeElement.classList.add('top');
@@ -5454,18 +5462,23 @@ class OverlayDirective {
5454
5462
  if (this.rightAlign) {
5455
5463
  this._elementRef.nativeElement.style.left = (parentRect.right - elementRect.width) + "px";
5456
5464
  }
5465
+ else if (this.fullSize) {
5466
+ this._elementRef.nativeElement.style.left = "0px";
5467
+ }
5457
5468
  else {
5458
5469
  this._elementRef.nativeElement.style.left = parentRect.left + "px";
5459
5470
  }
5460
5471
  if (this.keepInView) {
5461
- if (elementRect.right > window.innerWidth) {
5472
+ const viewToKeepIn = this.view ? this.view : window;
5473
+ const viewWidth = viewToKeepIn.innerWidth || viewToKeepIn.clientWidth;
5474
+ if (elementRect.right > viewWidth) {
5462
5475
  //see if we can move it to the left
5463
- if ((window.innerWidth - elementRect.width) > 0) {
5464
- this._elementRef.nativeElement.style.left = (window.innerWidth - elementRect.width) + "px";
5476
+ if (((viewWidth - elementRect.width) > 0) && !this.fullSize) {
5477
+ this._elementRef.nativeElement.style.left = (viewWidth - elementRect.width) + "px";
5465
5478
  }
5466
5479
  else { //resize so it fits into view
5467
- this._elementRef.nativeElement.style.width = window.innerWidth + "px";
5468
- this._elementRef.nativeElement.style.left = 0;
5480
+ this._elementRef.nativeElement.style.width = viewWidth + "px";
5481
+ this._elementRef.nativeElement.style.left = viewToKeepIn.offsetLeft + "px";
5469
5482
  }
5470
5483
  }
5471
5484
  }
@@ -5481,9 +5494,11 @@ OverlayDirective.ctorParameters = () => [
5481
5494
  ];
5482
5495
  OverlayDirective.propDecorators = {
5483
5496
  parent: [{ type: Input, args: ["overlay",] }],
5497
+ view: [{ type: Input }],
5484
5498
  keepInView: [{ type: Input }],
5485
5499
  inheritWidth: [{ type: Input }],
5486
- rightAlign: [{ type: Input }]
5500
+ rightAlign: [{ type: Input }],
5501
+ fullSize: [{ type: Input }]
5487
5502
  };
5488
5503
 
5489
5504
  class OverlayParentDirective {
@@ -10452,6 +10467,7 @@ class ListOfValuesComponent extends BaseInputComponent {
10452
10467
  this.multiselect = false;
10453
10468
  this.displayField = 'description';
10454
10469
  this.searchDisabled = false;
10470
+ this.closeAfterOptionChosen = true;
10455
10471
  this.isSelectOpen = false;
10456
10472
  this.state = 'default';
10457
10473
  this.selectedModels = [];
@@ -10555,6 +10571,9 @@ class ListOfValuesComponent extends BaseInputComponent {
10555
10571
  }
10556
10572
  else {
10557
10573
  this.selectedModel = option[this.displayField];
10574
+ if (this.closeAfterOptionChosen) {
10575
+ this.toggleSelect();
10576
+ }
10558
10577
  }
10559
10578
  }
10560
10579
  this.model = option;
@@ -10652,6 +10671,7 @@ ListOfValuesComponent.propDecorators = {
10652
10671
  label: [{ type: Input }],
10653
10672
  customCssClass: [{ type: Input }],
10654
10673
  searchDisabled: [{ type: Input }],
10674
+ closeAfterOptionChosen: [{ type: Input }],
10655
10675
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values',] }]
10656
10676
  };
10657
10677