@festo-ui/angular 7.0.0-dev.383 → 7.0.0-dev.386

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.
@@ -0,0 +1,97 @@
1
+ import { NgIf } from '@angular/common';
2
+ import { Component, EventEmitter, HostBinding, HostListener, Input, Output, ViewEncapsulation } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class FngBottomSheetComponent {
5
+ constructor() {
6
+ this.hasBackdrop = true;
7
+ this.isExpanded = false;
8
+ this.hideCloseIcon = false;
9
+ this.expandFrom = 'center';
10
+ this.close = new EventEmitter();
11
+ this.isOpen = false;
12
+ this.isClosing = false;
13
+ this.startY = 0;
14
+ this.currentY = 0;
15
+ this.swiping = false;
16
+ }
17
+ get isExpandedState() {
18
+ return this.isExpanded;
19
+ }
20
+ ngOnInit() {
21
+ setTimeout(() => {
22
+ this.isOpen = true;
23
+ }, 0); // trigger the transition on open
24
+ }
25
+ onTouchStart(event) {
26
+ this.startY = event.touches[0].clientY;
27
+ this.swiping = true;
28
+ }
29
+ onTouchMove(event) {
30
+ if (!this.swiping)
31
+ return;
32
+ this.currentY = event.touches[0].clientY;
33
+ const deltaY = this.currentY - this.startY;
34
+ if (deltaY < -50 && !this.isExpanded) {
35
+ // swipe up to expand
36
+ this.isExpanded = true;
37
+ this.swiping = false;
38
+ }
39
+ else if (deltaY > 50 && this.isExpanded) {
40
+ // swipe down to collapse
41
+ this.isExpanded = false;
42
+ this.swiping = false;
43
+ }
44
+ else if (deltaY > 100 && !this.isExpanded) {
45
+ // swipe down to close
46
+ this.closeBottomSheet();
47
+ this.swiping = false;
48
+ }
49
+ }
50
+ onTouchEnd() {
51
+ this.swiping = false;
52
+ }
53
+ toggleExpand() {
54
+ this.isExpanded = !this.isExpanded;
55
+ }
56
+ closeBottomSheet() {
57
+ this.isClosing = true;
58
+ this.hasBackdrop = false;
59
+ setTimeout(() => {
60
+ this.isClosing = false;
61
+ this.isOpen = false;
62
+ this.close.emit();
63
+ }, 300); // wait for the transition to finish before closing
64
+ }
65
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FngBottomSheetComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
66
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.2", type: FngBottomSheetComponent, isStandalone: true, selector: "fng-bottom-sheet", inputs: { hasBackdrop: "hasBackdrop", isExpanded: "isExpanded", hideCloseIcon: "hideCloseIcon", expandFrom: "expandFrom" }, outputs: { close: "close" }, host: { listeners: { "touchstart": "onTouchStart($event)", "touchmove": "onTouchMove($event)", "touchend": "onTouchEnd()" }, properties: { "class.bottom-sheet--open": "this.isOpen", "class.bottom-sheet--expanded": "this.isExpandedState" } }, ngImport: i0, template: "<div class=\"fwe-bottom-sheet-backdrop\" [class.fwe-bottom-sheet-backdrop--visible]=\"hasBackdrop\"\n (click)=\"closeBottomSheet()\"></div>\n<div class=\"fwe-bottom-sheet-container\" [class.fwe-bottom-sheet-container--open]=\"isOpen\"\n [class.fwe-bottom-sheet-container--expanded]=\"isExpanded\"\n [class.fwe-bottom-sheet-container--expand-from-center]=\"expandFrom === 'center'\"\n [class.fwe-bottom-sheet-container--with-backdrop]=\"hasBackdrop\"\n [class.fwe-bottom-sheet-container--closing]=\"isClosing\"\n >\n <div class=\"fwe-bottom-sheet-header\">\n <div class=\"fwe-bottom-sheet-drag-handle-container\" (click)=\"toggleExpand()\">\n <div class=\"fwe-bottom-sheet-drag-handle\"></div>\n </div>\n <button *ngIf=\"!hideCloseIcon\" type=\"button\"\n class=\"fwe-bottom-sheet-close-btn\" (click)=\"closeBottomSheet()\">\n <span class=\"fwe-sr-only\">Close</span>\n </button>\n </div>\n <div class=\"fwe-bottom-sheet-content\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
67
+ }
68
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FngBottomSheetComponent, decorators: [{
69
+ type: Component,
70
+ args: [{ selector: 'fng-bottom-sheet', standalone: true, imports: [NgIf], encapsulation: ViewEncapsulation.None, template: "<div class=\"fwe-bottom-sheet-backdrop\" [class.fwe-bottom-sheet-backdrop--visible]=\"hasBackdrop\"\n (click)=\"closeBottomSheet()\"></div>\n<div class=\"fwe-bottom-sheet-container\" [class.fwe-bottom-sheet-container--open]=\"isOpen\"\n [class.fwe-bottom-sheet-container--expanded]=\"isExpanded\"\n [class.fwe-bottom-sheet-container--expand-from-center]=\"expandFrom === 'center'\"\n [class.fwe-bottom-sheet-container--with-backdrop]=\"hasBackdrop\"\n [class.fwe-bottom-sheet-container--closing]=\"isClosing\"\n >\n <div class=\"fwe-bottom-sheet-header\">\n <div class=\"fwe-bottom-sheet-drag-handle-container\" (click)=\"toggleExpand()\">\n <div class=\"fwe-bottom-sheet-drag-handle\"></div>\n </div>\n <button *ngIf=\"!hideCloseIcon\" type=\"button\"\n class=\"fwe-bottom-sheet-close-btn\" (click)=\"closeBottomSheet()\">\n <span class=\"fwe-sr-only\">Close</span>\n </button>\n </div>\n <div class=\"fwe-bottom-sheet-content\">\n <ng-content></ng-content>\n </div>\n</div>" }]
71
+ }], propDecorators: { hasBackdrop: [{
72
+ type: Input
73
+ }], isExpanded: [{
74
+ type: Input
75
+ }], hideCloseIcon: [{
76
+ type: Input
77
+ }], expandFrom: [{
78
+ type: Input
79
+ }], close: [{
80
+ type: Output
81
+ }], isOpen: [{
82
+ type: HostBinding,
83
+ args: ['class.bottom-sheet--open']
84
+ }], isExpandedState: [{
85
+ type: HostBinding,
86
+ args: ['class.bottom-sheet--expanded']
87
+ }], onTouchStart: [{
88
+ type: HostListener,
89
+ args: ['touchstart', ['$event']]
90
+ }], onTouchMove: [{
91
+ type: HostListener,
92
+ args: ['touchmove', ['$event']]
93
+ }], onTouchEnd: [{
94
+ type: HostListener,
95
+ args: ['touchend']
96
+ }] } });
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm90dG9tLXNoZWV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2JvdHRvbS1zaGVldC9ib3R0b20tc2hlZXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvYm90dG9tLXNoZWV0L2JvdHRvbS1zaGVldC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVVySCxNQUFNLE9BQU8sdUJBQXVCO0lBUnBDO1FBU1csZ0JBQVcsR0FBWSxJQUFJLENBQUM7UUFDNUIsZUFBVSxHQUFZLEtBQUssQ0FBQztRQUM1QixrQkFBYSxHQUFZLEtBQUssQ0FBQztRQUMvQixlQUFVLEdBQXdCLFFBQVEsQ0FBQztRQUUxQyxVQUFLLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUVGLFdBQU0sR0FBRyxLQUFLLENBQUM7UUFLeEQsY0FBUyxHQUFZLEtBQUssQ0FBQztRQUVuQixXQUFNLEdBQVcsQ0FBQyxDQUFDO1FBQ25CLGFBQVEsR0FBVyxDQUFDLENBQUM7UUFDckIsWUFBTyxHQUFZLEtBQUssQ0FBQztLQXNEbEM7SUE5REMsSUFBaUQsZUFBZTtRQUM5RCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQVFELFFBQVE7UUFDTixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUM7UUFDckIsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsaUNBQWlDO0lBQzFDLENBQUM7SUFHRCxZQUFZLENBQUMsS0FBaUI7UUFDNUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztRQUN2QyxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztJQUN0QixDQUFDO0lBR0QsV0FBVyxDQUFDLEtBQWlCO1FBQzNCLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTztZQUFFLE9BQU87UUFFMUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztRQUN6QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFFM0MsSUFBSSxNQUFNLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDckMscUJBQXFCO1lBQ3JCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLENBQUM7YUFBTSxJQUFJLE1BQU0sR0FBRyxFQUFFLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQzFDLHlCQUF5QjtZQUN6QixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztZQUN4QixJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztRQUN2QixDQUFDO2FBQU0sSUFBSSxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQzVDLHNCQUFzQjtZQUN0QixJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztRQUN2QixDQUFDO0lBQ0gsQ0FBQztJQUdELFVBQVU7UUFDUixJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUN2QixDQUFDO0lBRUQsWUFBWTtRQUNWLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxnQkFBZ0I7UUFDZCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN0QixJQUFJLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQztRQUN6QixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7WUFDdkIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7WUFDcEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNwQixDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxtREFBbUQ7SUFDOUQsQ0FBQzs4R0F0RVUsdUJBQXVCO2tHQUF2Qix1QkFBdUIsdWRDWHBDLHkvQkFvQk0sMEREZE0sSUFBSTs7MkZBS0gsdUJBQXVCO2tCQVJuQyxTQUFTOytCQUNFLGtCQUFrQixjQUNoQixJQUFJLFdBQ1AsQ0FBQyxJQUFJLENBQUMsaUJBR0EsaUJBQWlCLENBQUMsSUFBSTs4QkFHNUIsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFFSSxLQUFLO3NCQUFkLE1BQU07Z0JBRWtDLE1BQU07c0JBQTlDLFdBQVc7dUJBQUMsMEJBQTBCO2dCQUNVLGVBQWU7c0JBQS9ELFdBQVc7dUJBQUMsOEJBQThCO2dCQWlCM0MsWUFBWTtzQkFEWCxZQUFZO3VCQUFDLFlBQVksRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFPdEMsV0FBVztzQkFEVixZQUFZO3VCQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkF1QnJDLFVBQVU7c0JBRFQsWUFBWTt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZm5nLWJvdHRvbS1zaGVldCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0lmXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2JvdHRvbS1zaGVldC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9ib3R0b20tc2hlZXQuY29tcG9uZW50LnNjc3MnLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIEZuZ0JvdHRvbVNoZWV0Q29tcG9uZW50IHtcbiAgQElucHV0KCkgaGFzQmFja2Ryb3A6IGJvb2xlYW4gPSB0cnVlO1xuICBASW5wdXQoKSBpc0V4cGFuZGVkOiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIGhpZGVDbG9zZUljb246IGJvb2xlYW4gPSBmYWxzZTtcbiAgQElucHV0KCkgZXhwYW5kRnJvbTogJ2JvdHRvbScgfCAnY2VudGVyJyA9ICdjZW50ZXInO1xuXG4gIEBPdXRwdXQoKSBjbG9zZSA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmJvdHRvbS1zaGVldC0tb3BlbicpIGlzT3BlbiA9IGZhbHNlO1xuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmJvdHRvbS1zaGVldC0tZXhwYW5kZWQnKSBnZXQgaXNFeHBhbmRlZFN0YXRlKCkge1xuICAgIHJldHVybiB0aGlzLmlzRXhwYW5kZWQ7XG4gIH1cblxuICBpc0Nsb3Npbmc6IGJvb2xlYW4gPSBmYWxzZTtcblxuICBwcml2YXRlIHN0YXJ0WTogbnVtYmVyID0gMDtcbiAgcHJpdmF0ZSBjdXJyZW50WTogbnVtYmVyID0gMDtcbiAgcHJpdmF0ZSBzd2lwaW5nOiBib29sZWFuID0gZmFsc2U7XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLmlzT3BlbiA9IHRydWU7XG4gICAgfSwgMCk7IC8vIHRyaWdnZXIgdGhlIHRyYW5zaXRpb24gb24gb3BlblxuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcigndG91Y2hzdGFydCcsIFsnJGV2ZW50J10pXG4gIG9uVG91Y2hTdGFydChldmVudDogVG91Y2hFdmVudCkge1xuICAgIHRoaXMuc3RhcnRZID0gZXZlbnQudG91Y2hlc1swXS5jbGllbnRZO1xuICAgIHRoaXMuc3dpcGluZyA9IHRydWU7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCd0b3VjaG1vdmUnLCBbJyRldmVudCddKVxuICBvblRvdWNoTW92ZShldmVudDogVG91Y2hFdmVudCkge1xuICAgIGlmICghdGhpcy5zd2lwaW5nKSByZXR1cm47XG5cbiAgICB0aGlzLmN1cnJlbnRZID0gZXZlbnQudG91Y2hlc1swXS5jbGllbnRZO1xuICAgIGNvbnN0IGRlbHRhWSA9IHRoaXMuY3VycmVudFkgLSB0aGlzLnN0YXJ0WTtcblxuICAgIGlmIChkZWx0YVkgPCAtNTAgJiYgIXRoaXMuaXNFeHBhbmRlZCkge1xuICAgICAgLy8gc3dpcGUgdXAgdG8gZXhwYW5kXG4gICAgICB0aGlzLmlzRXhwYW5kZWQgPSB0cnVlO1xuICAgICAgdGhpcy5zd2lwaW5nID0gZmFsc2U7XG4gICAgfSBlbHNlIGlmIChkZWx0YVkgPiA1MCAmJiB0aGlzLmlzRXhwYW5kZWQpIHtcbiAgICAgIC8vIHN3aXBlIGRvd24gdG8gY29sbGFwc2VcbiAgICAgIHRoaXMuaXNFeHBhbmRlZCA9IGZhbHNlO1xuICAgICAgdGhpcy5zd2lwaW5nID0gZmFsc2U7XG4gICAgfSBlbHNlIGlmIChkZWx0YVkgPiAxMDAgJiYgIXRoaXMuaXNFeHBhbmRlZCkge1xuICAgICAgLy8gc3dpcGUgZG93biB0byBjbG9zZVxuICAgICAgdGhpcy5jbG9zZUJvdHRvbVNoZWV0KCk7XG4gICAgICB0aGlzLnN3aXBpbmcgPSBmYWxzZTtcbiAgICB9XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCd0b3VjaGVuZCcpXG4gIG9uVG91Y2hFbmQoKSB7XG4gICAgdGhpcy5zd2lwaW5nID0gZmFsc2U7XG4gIH1cblxuICB0b2dnbGVFeHBhbmQoKSB7XG4gICAgdGhpcy5pc0V4cGFuZGVkID0gIXRoaXMuaXNFeHBhbmRlZDtcbiAgfVxuXG4gIGNsb3NlQm90dG9tU2hlZXQoKSB7XG4gICAgdGhpcy5pc0Nsb3NpbmcgPSB0cnVlO1xuICAgIHRoaXMuaGFzQmFja2Ryb3AgPSBmYWxzZTtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHRoaXMuaXNDbG9zaW5nID0gZmFsc2U7XG4gICAgICB0aGlzLmlzT3BlbiA9IGZhbHNlO1xuICAgICAgdGhpcy5jbG9zZS5lbWl0KCk7XG4gICAgfSwgMzAwKTsgLy8gd2FpdCBmb3IgdGhlIHRyYW5zaXRpb24gdG8gZmluaXNoIGJlZm9yZSBjbG9zaW5nXG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJmd2UtYm90dG9tLXNoZWV0LWJhY2tkcm9wXCIgW2NsYXNzLmZ3ZS1ib3R0b20tc2hlZXQtYmFja2Ryb3AtLXZpc2libGVdPVwiaGFzQmFja2Ryb3BcIlxuICAoY2xpY2spPVwiY2xvc2VCb3R0b21TaGVldCgpXCI+PC9kaXY+XG48ZGl2IGNsYXNzPVwiZndlLWJvdHRvbS1zaGVldC1jb250YWluZXJcIiBbY2xhc3MuZndlLWJvdHRvbS1zaGVldC1jb250YWluZXItLW9wZW5dPVwiaXNPcGVuXCJcbiAgW2NsYXNzLmZ3ZS1ib3R0b20tc2hlZXQtY29udGFpbmVyLS1leHBhbmRlZF09XCJpc0V4cGFuZGVkXCJcbiAgW2NsYXNzLmZ3ZS1ib3R0b20tc2hlZXQtY29udGFpbmVyLS1leHBhbmQtZnJvbS1jZW50ZXJdPVwiZXhwYW5kRnJvbSA9PT0gJ2NlbnRlcidcIlxuICBbY2xhc3MuZndlLWJvdHRvbS1zaGVldC1jb250YWluZXItLXdpdGgtYmFja2Ryb3BdPVwiaGFzQmFja2Ryb3BcIlxuICBbY2xhc3MuZndlLWJvdHRvbS1zaGVldC1jb250YWluZXItLWNsb3NpbmddPVwiaXNDbG9zaW5nXCJcbiAgPlxuICA8ZGl2IGNsYXNzPVwiZndlLWJvdHRvbS1zaGVldC1oZWFkZXJcIj5cbiAgICA8ZGl2IGNsYXNzPVwiZndlLWJvdHRvbS1zaGVldC1kcmFnLWhhbmRsZS1jb250YWluZXJcIiAoY2xpY2spPVwidG9nZ2xlRXhwYW5kKClcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJmd2UtYm90dG9tLXNoZWV0LWRyYWctaGFuZGxlXCI+PC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGJ1dHRvbiAqbmdJZj1cIiFoaWRlQ2xvc2VJY29uXCIgdHlwZT1cImJ1dHRvblwiXG4gICAgICBjbGFzcz1cImZ3ZS1ib3R0b20tc2hlZXQtY2xvc2UtYnRuXCIgKGNsaWNrKT1cImNsb3NlQm90dG9tU2hlZXQoKVwiPlxuICAgICAgPHNwYW4gY2xhc3M9XCJmd2Utc3Itb25seVwiPkNsb3NlPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImZ3ZS1ib3R0b20tc2hlZXQtY29udGVudFwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2Rpdj4iXX0=
@@ -1,35 +1,36 @@
1
1
  import { NgModule } from '@angular/core';
2
- import { FngBreadcrumbComponent } from './breadcrumb/breadcrumb.component';
2
+ import { FngClickOutsideDirective } from '../directives/click-outside.directive';
3
3
  import { FngAccordionComponent, FngAccordionHeaderComponent, FngAccordionItemBodyComponent, FngAccordionItemComponent, FngAccordionItemHeaderComponent } from './accordion';
4
+ import { FngBottomSheetComponent } from './bottom-sheet/bottom-sheet.component';
5
+ import { FngBreadcrumbComponent } from './breadcrumb/breadcrumb.component';
4
6
  import { FngButtonComponent } from './buttons/button/button.component';
5
7
  import { FngLinkButtonComponent } from './buttons/link-button/link-button.component';
6
- import { FngChipComponent } from './chips/chip/chip.component';
7
8
  import { FngChipContainerComponent } from './chips/chip-container/chip-container.component';
9
+ import { FngChipComponent } from './chips/chip/chip.component';
8
10
  import { FngLoadingIndicatorComponent } from './loading-indicator/loading-indicator.component';
9
- import { FngMobileFlyoutComponent } from './mobile-flyout/mobile-flyout.component';
10
11
  import { FngMobileFlyoutItemComponent } from './mobile-flyout/mobile-flyout-item/mobile-flyout-item.component';
11
12
  import { FngMobileFlyoutPageComponent } from './mobile-flyout/mobile-flyout-page/mobile-flyout-page.component';
13
+ import { FngMobileFlyoutComponent } from './mobile-flyout/mobile-flyout.component';
12
14
  import { FngPaginationComponent } from './pagination/pagination.component';
13
- import { FngProgressComponent } from './progress/progress.component';
14
- import { FngSearchInputComponent } from './search-input/search-input.component';
15
- import { FngSnackbarContainerComponent } from './snackbar/snackbar-container.component';
16
- import { FngStepperHorizontalComponent } from './stepper-horizontal/stepper-horizontal.component';
17
- import { FngStepHorizontalComponent } from './stepper-horizontal/step-horizontal/step-horizontal.component';
18
- import { FngStepperVerticalComponent } from './stepper-vertical/stepper-vertical.component';
19
- import { FngStepVerticalComponent } from './stepper-vertical/step-vertical/step-vertical.component';
20
- import { FngTableHeaderCellDirective } from './table-header-cell/table-header-cell.directive';
21
- import { FngScrollableDirective } from './scroll';
22
- import { FngTabsComponent } from './tabs/tabs.component';
23
- import { FngTabPaneComponent } from './tabs/tab-pane/tab-pane.component';
24
15
  import { FngLegendComponent } from './popovers/legend/legend.component';
25
16
  import { FngLegendDirective } from './popovers/legend/legend.directive';
26
17
  import { FngPopoverContentComponent } from './popovers/popover-content/popover-content.component';
27
- import { FngPopoverComponent } from './popovers/popover/popover.component';
28
18
  import { FngPopoverContentDirective } from './popovers/popover-content/popover-content.directive';
29
19
  import { FngPopoverMenuComponent } from './popovers/popover-menu/popover-menu.component';
20
+ import { FngPopoverComponent } from './popovers/popover/popover.component';
30
21
  import { FngTooltipDirective } from './popovers/tooltip/tooltip.directive';
31
- import { FngClickOutsideDirective } from '../directives/click-outside.directive';
22
+ import { FngProgressComponent } from './progress/progress.component';
23
+ import { FngScrollableDirective } from './scroll';
24
+ import { FngSearchInputComponent } from './search-input/search-input.component';
32
25
  import { FngSidebarOverlayComponent } from './sidebar-overlay/sidebar-overlay.component';
26
+ import { FngSnackbarContainerComponent } from './snackbar/snackbar-container.component';
27
+ import { FngStepHorizontalComponent } from './stepper-horizontal/step-horizontal/step-horizontal.component';
28
+ import { FngStepperHorizontalComponent } from './stepper-horizontal/stepper-horizontal.component';
29
+ import { FngStepVerticalComponent } from './stepper-vertical/step-vertical/step-vertical.component';
30
+ import { FngStepperVerticalComponent } from './stepper-vertical/stepper-vertical.component';
31
+ import { FngTableHeaderCellDirective } from './table-header-cell/table-header-cell.directive';
32
+ import { FngTabPaneComponent } from './tabs/tab-pane/tab-pane.component';
33
+ import { FngTabsComponent } from './tabs/tabs.component';
33
34
  import * as i0 from "@angular/core";
34
35
  export class FestoAngularComponentsModule {
35
36
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FestoAngularComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
@@ -68,7 +69,8 @@ export class FestoAngularComponentsModule {
68
69
  FngTooltipDirective,
69
70
  FngLegendDirective,
70
71
  FngLegendComponent,
71
- FngSidebarOverlayComponent], exports: [FngClickOutsideDirective,
72
+ FngSidebarOverlayComponent,
73
+ FngBottomSheetComponent], exports: [FngClickOutsideDirective,
72
74
  FngBreadcrumbComponent,
73
75
  FngAccordionComponent,
74
76
  FngAccordionHeaderComponent,
@@ -103,7 +105,8 @@ export class FestoAngularComponentsModule {
103
105
  FngTooltipDirective,
104
106
  FngLegendDirective,
105
107
  FngLegendComponent,
106
- FngSidebarOverlayComponent] }); }
108
+ FngSidebarOverlayComponent,
109
+ FngBottomSheetComponent] }); }
107
110
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FestoAngularComponentsModule, imports: [FngPaginationComponent,
108
111
  FngMobileFlyoutPageComponent,
109
112
  FngMobileFlyoutItemComponent,
@@ -162,7 +165,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
162
165
  FngTooltipDirective,
163
166
  FngLegendDirective,
164
167
  FngLegendComponent,
165
- FngSidebarOverlayComponent
168
+ FngSidebarOverlayComponent,
169
+ FngBottomSheetComponent
166
170
  ],
167
171
  exports: [
168
172
  FngClickOutsideDirective,
@@ -200,8 +204,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
200
204
  FngTooltipDirective,
201
205
  FngLegendDirective,
202
206
  FngLegendComponent,
203
- FngSidebarOverlayComponent
207
+ FngSidebarOverlayComponent,
208
+ FngBottomSheetComponent
204
209
  ]
205
210
  }]
206
211
  }] });
207
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../projects/angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { FngBreadcrumbComponent } from './breadcrumb/breadcrumb.component';\nimport {\n  FngAccordionComponent,\n  FngAccordionHeaderComponent,\n  FngAccordionItemBodyComponent,\n  FngAccordionItemComponent,\n  FngAccordionItemHeaderComponent\n} from './accordion';\nimport { FngButtonComponent } from './buttons/button/button.component';\nimport { FngLinkButtonComponent } from './buttons/link-button/link-button.component';\nimport { FngChipComponent } from './chips/chip/chip.component';\nimport { FngChipContainerComponent } from './chips/chip-container/chip-container.component';\nimport { FngLoadingIndicatorComponent } from './loading-indicator/loading-indicator.component';\nimport { FngMobileFlyoutComponent } from './mobile-flyout/mobile-flyout.component';\nimport { FngMobileFlyoutItemComponent } from './mobile-flyout/mobile-flyout-item/mobile-flyout-item.component';\nimport { FngMobileFlyoutPageComponent } from './mobile-flyout/mobile-flyout-page/mobile-flyout-page.component';\nimport { FngPaginationComponent } from './pagination/pagination.component';\nimport { FngProgressComponent } from './progress/progress.component';\nimport { FngSearchInputComponent } from './search-input/search-input.component';\nimport { FngSnackbarContainerComponent } from './snackbar/snackbar-container.component';\nimport { FngStepperHorizontalComponent } from './stepper-horizontal/stepper-horizontal.component';\nimport { FngStepHorizontalComponent } from './stepper-horizontal/step-horizontal/step-horizontal.component';\nimport { FngStepperVerticalComponent } from './stepper-vertical/stepper-vertical.component';\nimport { FngStepVerticalComponent } from './stepper-vertical/step-vertical/step-vertical.component';\nimport { FngTableHeaderCellDirective } from './table-header-cell/table-header-cell.directive';\nimport { FngScrollableDirective } from './scroll';\nimport { FngTabsComponent } from './tabs/tabs.component';\nimport { FngTabPaneComponent } from './tabs/tab-pane/tab-pane.component';\nimport { FngLegendComponent } from './popovers/legend/legend.component';\nimport { FngLegendDirective } from './popovers/legend/legend.directive';\nimport { FngPopoverContentComponent } from './popovers/popover-content/popover-content.component';\nimport { FngPopoverComponent } from './popovers/popover/popover.component';\nimport { FngPopoverContentDirective } from './popovers/popover-content/popover-content.directive';\nimport { FngPopoverMenuComponent } from './popovers/popover-menu/popover-menu.component';\nimport { FngTooltipDirective } from './popovers/tooltip/tooltip.directive';\nimport { FngClickOutsideDirective } from '../directives/click-outside.directive';\nimport { FngSidebarOverlayComponent } from './sidebar-overlay/sidebar-overlay.component';\n\n@NgModule({\n  imports: [\n    FngClickOutsideDirective,\n    FngPaginationComponent,\n    FngMobileFlyoutPageComponent,\n    FngMobileFlyoutItemComponent,\n    FngMobileFlyoutComponent,\n    FngLoadingIndicatorComponent,\n    FngChipComponent,\n    FngChipContainerComponent,\n    FngTabsComponent,\n    FngTabPaneComponent,\n    FngBreadcrumbComponent,\n    FngAccordionComponent,\n    FngAccordionHeaderComponent,\n    FngAccordionItemComponent,\n    FngAccordionItemBodyComponent,\n    FngAccordionItemHeaderComponent,\n    FngButtonComponent,\n    FngLinkButtonComponent,\n    FngSearchInputComponent,\n    FngSnackbarContainerComponent,\n    FngStepHorizontalComponent,\n    FngStepperHorizontalComponent,\n    FngStepperVerticalComponent,\n    FngStepVerticalComponent,\n    FngTableHeaderCellDirective,\n    FngScrollableDirective,\n    FngProgressComponent,\n    FngLegendDirective,\n    FngPopoverComponent,\n    FngPopoverContentDirective,\n    FngPopoverContentComponent,\n    FngPopoverMenuComponent,\n    FngTooltipDirective,\n    FngLegendDirective,\n    FngLegendComponent,\n    FngSidebarOverlayComponent\n  ],\n  exports: [\n    FngClickOutsideDirective,\n    FngBreadcrumbComponent,\n    FngAccordionComponent,\n    FngAccordionHeaderComponent,\n    FngAccordionItemComponent,\n    FngAccordionItemBodyComponent,\n    FngAccordionItemHeaderComponent,\n    FngButtonComponent,\n    FngLinkButtonComponent,\n    FngChipContainerComponent,\n    FngChipComponent,\n    FngLoadingIndicatorComponent,\n    FngMobileFlyoutComponent,\n    FngMobileFlyoutItemComponent,\n    FngMobileFlyoutPageComponent,\n    FngPaginationComponent,\n    FngSearchInputComponent,\n    FngSnackbarContainerComponent,\n    FngStepHorizontalComponent,\n    FngStepperHorizontalComponent,\n    FngStepperVerticalComponent,\n    FngStepVerticalComponent,\n    FngTableHeaderCellDirective,\n    FngScrollableDirective,\n    FngProgressComponent,\n    FngTabsComponent,\n    FngTabPaneComponent,\n    FngLegendDirective,\n    FngPopoverComponent,\n    FngPopoverContentDirective,\n    FngPopoverContentComponent,\n    FngPopoverMenuComponent,\n    FngTooltipDirective,\n    FngLegendDirective,\n    FngLegendComponent,\n    FngSidebarOverlayComponent\n  ]\n})\nexport class FestoAngularComponentsModule {}\n"]}
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../projects/angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { FngClickOutsideDirective } from '../directives/click-outside.directive';\nimport {\n  FngAccordionComponent,\n  FngAccordionHeaderComponent,\n  FngAccordionItemBodyComponent,\n  FngAccordionItemComponent,\n  FngAccordionItemHeaderComponent\n} from './accordion';\nimport { FngBottomSheetComponent } from './bottom-sheet/bottom-sheet.component';\nimport { FngBreadcrumbComponent } from './breadcrumb/breadcrumb.component';\nimport { FngButtonComponent } from './buttons/button/button.component';\nimport { FngLinkButtonComponent } from './buttons/link-button/link-button.component';\nimport { FngChipContainerComponent } from './chips/chip-container/chip-container.component';\nimport { FngChipComponent } from './chips/chip/chip.component';\nimport { FngLoadingIndicatorComponent } from './loading-indicator/loading-indicator.component';\nimport { FngMobileFlyoutItemComponent } from './mobile-flyout/mobile-flyout-item/mobile-flyout-item.component';\nimport { FngMobileFlyoutPageComponent } from './mobile-flyout/mobile-flyout-page/mobile-flyout-page.component';\nimport { FngMobileFlyoutComponent } from './mobile-flyout/mobile-flyout.component';\nimport { FngPaginationComponent } from './pagination/pagination.component';\nimport { FngLegendComponent } from './popovers/legend/legend.component';\nimport { FngLegendDirective } from './popovers/legend/legend.directive';\nimport { FngPopoverContentComponent } from './popovers/popover-content/popover-content.component';\nimport { FngPopoverContentDirective } from './popovers/popover-content/popover-content.directive';\nimport { FngPopoverMenuComponent } from './popovers/popover-menu/popover-menu.component';\nimport { FngPopoverComponent } from './popovers/popover/popover.component';\nimport { FngTooltipDirective } from './popovers/tooltip/tooltip.directive';\nimport { FngProgressComponent } from './progress/progress.component';\nimport { FngScrollableDirective } from './scroll';\nimport { FngSearchInputComponent } from './search-input/search-input.component';\nimport { FngSidebarOverlayComponent } from './sidebar-overlay/sidebar-overlay.component';\nimport { FngSnackbarContainerComponent } from './snackbar/snackbar-container.component';\nimport { FngStepHorizontalComponent } from './stepper-horizontal/step-horizontal/step-horizontal.component';\nimport { FngStepperHorizontalComponent } from './stepper-horizontal/stepper-horizontal.component';\nimport { FngStepVerticalComponent } from './stepper-vertical/step-vertical/step-vertical.component';\nimport { FngStepperVerticalComponent } from './stepper-vertical/stepper-vertical.component';\nimport { FngTableHeaderCellDirective } from './table-header-cell/table-header-cell.directive';\nimport { FngTabPaneComponent } from './tabs/tab-pane/tab-pane.component';\nimport { FngTabsComponent } from './tabs/tabs.component';\n\n@NgModule({\n  imports: [\n    FngClickOutsideDirective,\n    FngPaginationComponent,\n    FngMobileFlyoutPageComponent,\n    FngMobileFlyoutItemComponent,\n    FngMobileFlyoutComponent,\n    FngLoadingIndicatorComponent,\n    FngChipComponent,\n    FngChipContainerComponent,\n    FngTabsComponent,\n    FngTabPaneComponent,\n    FngBreadcrumbComponent,\n    FngAccordionComponent,\n    FngAccordionHeaderComponent,\n    FngAccordionItemComponent,\n    FngAccordionItemBodyComponent,\n    FngAccordionItemHeaderComponent,\n    FngButtonComponent,\n    FngLinkButtonComponent,\n    FngSearchInputComponent,\n    FngSnackbarContainerComponent,\n    FngStepHorizontalComponent,\n    FngStepperHorizontalComponent,\n    FngStepperVerticalComponent,\n    FngStepVerticalComponent,\n    FngTableHeaderCellDirective,\n    FngScrollableDirective,\n    FngProgressComponent,\n    FngLegendDirective,\n    FngPopoverComponent,\n    FngPopoverContentDirective,\n    FngPopoverContentComponent,\n    FngPopoverMenuComponent,\n    FngTooltipDirective,\n    FngLegendDirective,\n    FngLegendComponent,\n    FngSidebarOverlayComponent,\n    FngBottomSheetComponent\n  ],\n  exports: [\n    FngClickOutsideDirective,\n    FngBreadcrumbComponent,\n    FngAccordionComponent,\n    FngAccordionHeaderComponent,\n    FngAccordionItemComponent,\n    FngAccordionItemBodyComponent,\n    FngAccordionItemHeaderComponent,\n    FngButtonComponent,\n    FngLinkButtonComponent,\n    FngChipContainerComponent,\n    FngChipComponent,\n    FngLoadingIndicatorComponent,\n    FngMobileFlyoutComponent,\n    FngMobileFlyoutItemComponent,\n    FngMobileFlyoutPageComponent,\n    FngPaginationComponent,\n    FngSearchInputComponent,\n    FngSnackbarContainerComponent,\n    FngStepHorizontalComponent,\n    FngStepperHorizontalComponent,\n    FngStepperVerticalComponent,\n    FngStepVerticalComponent,\n    FngTableHeaderCellDirective,\n    FngScrollableDirective,\n    FngProgressComponent,\n    FngTabsComponent,\n    FngTabPaneComponent,\n    FngLegendDirective,\n    FngPopoverComponent,\n    FngPopoverContentDirective,\n    FngPopoverContentComponent,\n    FngPopoverMenuComponent,\n    FngTooltipDirective,\n    FngLegendDirective,\n    FngLegendComponent,\n    FngSidebarOverlayComponent,\n    FngBottomSheetComponent\n  ]\n})\nexport class FestoAngularComponentsModule {}\n"]}
@@ -221,7 +221,7 @@ export class FngSelectComponent {
221
221
  useExisting: forwardRef(() => FngSelectComponent),
222
222
  multi: true
223
223
  }
224
- ], queries: [{ propertyName: "fngSelectOptions", predicate: FngSelectOptionComponent }], viewQueries: [{ propertyName: "elementRef", first: true, predicate: ["div"], descendants: true }], ngImport: i0, template: "<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n <div\n class=\"fwe-select\"\n (click)=\"toggle()\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [class.fwe-focus]=\"showOptions\"\n [class.fwe-required]=\"required\"\n [class.fwe-disabled]=\"disabled\"\n [class.fwe-pty]=\"empty\"\n >\n <div class=\"fwe-select-content\">\n <ng-container *ngIf=\"!multiple; else chips\">\n {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n </ng-container>\n <ng-template #chips>\n <div class=\"fwe-chip-container\">\n <div\n *ngFor=\"let v of value\"\n class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n [style.max-width.px]=\"triggerWidth\"\n [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n >\n {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayHasBackdrop\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"showOptions\"\n [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n (backdropClick)=\"close()\"\n >\n <div class=\"fng-select-panel-wrap\">\n <ul class=\"fwe-select-options-container\">\n <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n <li\n class=\"fwe-select-option\"\n *ngFor=\"let option of options; let i = index\"\n (click)=\"select(getOptionValue(i), $event)\"\n [title]=\"getOptionText(i) || option?.text\"\n >\n <span class=\"fwe-select-option-content\">\n <span\n *ngIf=\"multiple\"\n class=\"fng-select-pseudo-checkbox\"\n [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n ></span>\n <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n </span>\n </li>\n </ul>\n </div>\n </ng-template>\n <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n <div class=\"fwe-select-description\" *ngIf=\"hint\">\n {{ hint }}\n </div>\n <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n {{ error }}\n </div>\n</div>\n<div class=\"fwe-d-none\">\n <ng-content></ng-content>\n</div>\n", styles: [".fng-select-panel-open .fng-select-panel{opacity:1!important}fng-select{width:auto}fng-select.ng-invalid:not(.ng-pristine) .fwe-select:hover{border-color:var(--fwe-red)}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-invalid{display:block}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-description{display:none}.fng-select-panel{opacity:0!important}.fng-select-panel.fng-select-panel-options-3 .fwe-select-options-container{max-height:162px}.fng-select-panel.fng-select-panel-options-4 .fwe-select-options-container{max-height:210px}.fng-select-panel.fng-select-panel-options-5 .fwe-select-options-container{max-height:258px}.fng-select-panel.fng-select-panel-options-6 .fwe-select-options-container{max-height:306px}.fng-select-panel.fng-select-panel-options-7 .fwe-select-options-container{max-height:354px}.fng-select-panel.fng-select-panel-options-8 .fwe-select-options-container{max-height:402px}.fng-select-panel.fng-select-panel-options-9 .fwe-select-options-container{max-height:450px}.fng-select-panel.fng-select-panel-options-10 .fwe-select-options-container{max-height:498px}@-moz-document url-prefix(){.fng-select-panel .fwe-select-options-container{scrollbar-width:thin;scrollbar-color:var(--fwe-control-scrollbar) transparent}}@media (pointer: fine){.fng-select-panel .fwe-select-options-container::-webkit-scrollbar{width:14px}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-track{background:transparent}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-thumb{overflow:visible;background-color:var(--fwe-control-scrollbar);border:3px solid rgba(242,243,245,0);-webkit-background-clip:padding-box;background-clip:padding-box;border-radius:8px}}.fng-select-panel-wrap{flex-basis:100%}.fwe-select-options-container{position:relative;top:4px;left:0;max-height:258px;min-width:calc(100% + 0px)!important;max-width:280px;overflow:auto;font-size:var(--fwe-font-size-base);background-color:var(--fwe-white);border-radius:4px;padding:8px;margin:0;border:1px solid var(--fwe-gray-200);box-shadow:0 1px 4px #00000029;list-style:none;outline:0}.fwe-select-options-container .fwe-select-option{position:relative;line-height:24px;padding:12px 8px;min-height:24px;cursor:pointer}.fwe-select-options-container .fwe-select-option:hover{background-color:var(--fwe-gray-100)}.fwe-select-options-container .fwe-select-option:last-child{border-bottom:none}.fwe-select-options-container .fwe-select-option .fwe-select-option-content{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;line-height:24px;min-height:24px}.fng-select-pseudo-checkbox{width:16px;height:16px;border-radius:2px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;color:var(--fwe-control-border);border:1px solid;transition:none;margin-right:12px;top:-1px}.fng-select-pseudo-checkbox:after{color:var(--fwe-white);position:absolute;display:block;opacity:0;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked{background:var(--fwe-caerul);border:1px solid var(--fwe-caerul)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked:after{top:3px;left:2px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box}.chip-text-truncate{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip-removable:after{position:absolute;right:5px;top:4px;color:var(--fwe-text);font-family:var(--fwe-font-family-icons-16);font-size:var(--fwe-font-size-base);content:\"\\ea1c\";line-height:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fwe-select-wrapper{display:flex;width:inherit;min-width:48px}.fwe-select-wrapper:before{bottom:unset;top:24px}.fwe-select-wrapper.fng-hide-label{margin-top:18px}.fwe-select-wrapper.fng-hide-label:before{top:6px}.fwe-select-wrapper.fwe-disabled:before{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select{cursor:pointer;height:unset;min-height:33px}.fwe-select-wrapper .fwe-select .fwe-select-content{padding-right:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5rem}.fwe-select-wrapper .fwe-select.fwe-required:not(.fwe-disabled)~.fwe-select-label:after{position:relative;left:3px;display:inline-block;content:\"*\"}.fwe-select-wrapper .fwe-select.fwe-disabled{cursor:default;border-color:var(--fwe-control-disabled)!important}.fwe-select-wrapper .fwe-select.fwe-disabled~.fwe-select-label{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-select-content{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip{color:var(--fwe-text-disabled);border:1px solid var(--fwe-control-disabled);pointer-events:none}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip .chip-removable:after{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select-label:empty~.fwe-select-options-container,.fwe-select-wrapper .fwe-select-label.fwe-sr-only~.fwe-select-options-container{top:38px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: FngChipTextPipe, name: "fngChipText" }, { kind: "ngmodule", type: OverlayModule }, { kind: "directive", type: i2.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i2.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }], encapsulation: i0.ViewEncapsulation.None }); }
224
+ ], queries: [{ propertyName: "fngSelectOptions", predicate: FngSelectOptionComponent }], viewQueries: [{ propertyName: "elementRef", first: true, predicate: ["div"], descendants: true }], ngImport: i0, template: "<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n <div\n class=\"fwe-select\"\n (click)=\"toggle()\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [class.fwe-focus]=\"showOptions\"\n [class.fwe-required]=\"required\"\n [class.fwe-disabled]=\"disabled\"\n [class.fwe-pty]=\"empty\"\n >\n <div class=\"fwe-select-content\">\n <ng-container *ngIf=\"!multiple; else chips\">\n {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n </ng-container>\n <ng-template #chips>\n <div class=\"fwe-chip-container\">\n <div\n *ngFor=\"let v of value\"\n class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n [style.max-width.px]=\"triggerWidth\"\n [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n >\n {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayHasBackdrop\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"showOptions\"\n [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n (backdropClick)=\"close()\"\n >\n <div class=\"fng-select-panel-wrap\">\n <ul class=\"fwe-select-options-container\">\n <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n <li\n class=\"fwe-select-option\"\n *ngFor=\"let option of options; let i = index\"\n (click)=\"select(getOptionValue(i), $event)\"\n [title]=\"getOptionText(i) || option?.text\"\n >\n <span class=\"fwe-select-option-content\">\n <span\n *ngIf=\"multiple\"\n class=\"fng-select-pseudo-checkbox\"\n [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n ></span>\n <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n </span>\n </li>\n </ul>\n </div>\n </ng-template>\n <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n <div class=\"fwe-select-description\" *ngIf=\"hint\">\n {{ hint }}\n </div>\n <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n {{ error }}\n </div>\n</div>\n<div class=\"fwe-d-none\">\n <ng-content></ng-content>\n</div>\n", styles: [".fng-select-panel-open .fng-select-panel{opacity:1!important}fng-select{width:auto}fng-select.ng-invalid:not(.ng-pristine) .fwe-select:hover{border-color:var(--fwe-red)}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-invalid{display:block}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-description{display:none}.fng-select-panel{opacity:0!important}.fng-select-panel.fng-select-panel-options-3 .fwe-select-options-container{max-height:162px}.fng-select-panel.fng-select-panel-options-4 .fwe-select-options-container{max-height:210px}.fng-select-panel.fng-select-panel-options-5 .fwe-select-options-container{max-height:258px}.fng-select-panel.fng-select-panel-options-6 .fwe-select-options-container{max-height:306px}.fng-select-panel.fng-select-panel-options-7 .fwe-select-options-container{max-height:354px}.fng-select-panel.fng-select-panel-options-8 .fwe-select-options-container{max-height:402px}.fng-select-panel.fng-select-panel-options-9 .fwe-select-options-container{max-height:450px}.fng-select-panel.fng-select-panel-options-10 .fwe-select-options-container{max-height:498px}@-moz-document url-prefix(){.fng-select-panel .fwe-select-options-container{scrollbar-width:thin;scrollbar-color:var(--fwe-control-scrollbar) transparent}}@media (pointer: fine){.fng-select-panel .fwe-select-options-container::-webkit-scrollbar{width:14px}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-track{background:transparent}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-thumb{overflow:visible;background-color:var(--fwe-control-scrollbar);border:3px solid rgba(242,243,245,0);-webkit-background-clip:padding-box;background-clip:padding-box;border-radius:8px}}.fng-select-panel-wrap{flex-basis:100%}.fwe-select-options-container{position:relative;top:4px;left:0;max-height:258px;min-width:calc(100% + 0px)!important;max-width:280px;overflow:auto;font-size:var(--fwe-font-size-base);background-color:var(--fwe-white);border-radius:4px;padding:8px;margin:0;border:1px solid var(--fwe-gray-200);box-shadow:0 1px 4px #00000029;list-style:none;outline:0}.fwe-select-options-container .fwe-select-option{position:relative;line-height:24px;padding:12px 8px;min-height:24px;cursor:pointer}.fwe-select-options-container .fwe-select-option:hover{background-color:var(--fwe-gray-100)}.fwe-select-options-container .fwe-select-option:last-child{border-bottom:none}.fwe-select-options-container .fwe-select-option .fwe-select-option-content{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;line-height:24px;min-height:24px}.fng-select-pseudo-checkbox{width:16px;height:16px;border-radius:2px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;color:var(--fwe-control-border);border:1px solid;transition:none;margin-right:12px;top:-1px}.fng-select-pseudo-checkbox:after{color:var(--fwe-white);position:absolute;display:block;opacity:0;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked{background:var(--fwe-caerul);border:1px solid var(--fwe-caerul)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked:after{top:3px;left:2px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box}.chip-text-truncate{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip-removable:after{position:absolute;right:5px;top:4px;color:var(--fwe-text);font-family:var(--fwe-font-family-icons-16);font-size:var(--fwe-font-size-base);content:\"\\ea1c\";line-height:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fwe-select-wrapper{display:flex;width:inherit;min-width:48px}.fwe-select-wrapper:before{bottom:unset;top:24px}.fwe-select-wrapper.fng-hide-label{margin-top:18px}.fwe-select-wrapper.fng-hide-label:before{top:6px}.fwe-select-wrapper.fwe-disabled:before{color:var(--fwe-text-disabled);background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxMiAxMikiPjxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0xMiAtMTIpIj48ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIDApIj48cmVjdCB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIGZpbGw9Im5vbmUiLz48L2c+PGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNS41OTggOC41MTMpIj48cGF0aCBkPSJNNS42MzYsOS4xOTRsNi4yNzgsNi41NjQsNi4yNzgtNi41NjQtLjctLjczTDExLjkxNCwxNC4zLDYuMzMzLDguNDY0WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTUuNjM2IC04LjQ2NCkiIGZpbGw9IiNiOWJhYmIiLz48L2c+PC9nPjwvZz48L3N2Zz4=)}.fwe-select-wrapper .fwe-select{cursor:pointer;height:unset;min-height:33px}.fwe-select-wrapper .fwe-select .fwe-select-content{padding-right:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5rem}.fwe-select-wrapper .fwe-select.fwe-required:not(.fwe-disabled)~.fwe-select-label:after{position:relative;left:3px;display:inline-block;content:\"*\"}.fwe-select-wrapper .fwe-select.fwe-disabled{cursor:default;border-color:var(--fwe-control-disabled)!important}.fwe-select-wrapper .fwe-select.fwe-disabled~.fwe-select-label{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-select-content{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip{color:var(--fwe-text-disabled);border:1px solid var(--fwe-control-disabled);pointer-events:none}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip .chip-removable:after{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select-label:empty~.fwe-select-options-container,.fwe-select-wrapper .fwe-select-label.fwe-sr-only~.fwe-select-options-container{top:38px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: FngChipTextPipe, name: "fngChipText" }, { kind: "ngmodule", type: OverlayModule }, { kind: "directive", type: i2.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i2.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }], encapsulation: i0.ViewEncapsulation.None }); }
225
225
  }
226
226
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FngSelectComponent, decorators: [{
227
227
  type: Component,
@@ -231,7 +231,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
231
231
  useExisting: forwardRef(() => FngSelectComponent),
232
232
  multi: true
233
233
  }
234
- ], template: "<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n <div\n class=\"fwe-select\"\n (click)=\"toggle()\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [class.fwe-focus]=\"showOptions\"\n [class.fwe-required]=\"required\"\n [class.fwe-disabled]=\"disabled\"\n [class.fwe-pty]=\"empty\"\n >\n <div class=\"fwe-select-content\">\n <ng-container *ngIf=\"!multiple; else chips\">\n {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n </ng-container>\n <ng-template #chips>\n <div class=\"fwe-chip-container\">\n <div\n *ngFor=\"let v of value\"\n class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n [style.max-width.px]=\"triggerWidth\"\n [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n >\n {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayHasBackdrop\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"showOptions\"\n [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n (backdropClick)=\"close()\"\n >\n <div class=\"fng-select-panel-wrap\">\n <ul class=\"fwe-select-options-container\">\n <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n <li\n class=\"fwe-select-option\"\n *ngFor=\"let option of options; let i = index\"\n (click)=\"select(getOptionValue(i), $event)\"\n [title]=\"getOptionText(i) || option?.text\"\n >\n <span class=\"fwe-select-option-content\">\n <span\n *ngIf=\"multiple\"\n class=\"fng-select-pseudo-checkbox\"\n [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n ></span>\n <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n </span>\n </li>\n </ul>\n </div>\n </ng-template>\n <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n <div class=\"fwe-select-description\" *ngIf=\"hint\">\n {{ hint }}\n </div>\n <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n {{ error }}\n </div>\n</div>\n<div class=\"fwe-d-none\">\n <ng-content></ng-content>\n</div>\n", styles: [".fng-select-panel-open .fng-select-panel{opacity:1!important}fng-select{width:auto}fng-select.ng-invalid:not(.ng-pristine) .fwe-select:hover{border-color:var(--fwe-red)}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-invalid{display:block}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-description{display:none}.fng-select-panel{opacity:0!important}.fng-select-panel.fng-select-panel-options-3 .fwe-select-options-container{max-height:162px}.fng-select-panel.fng-select-panel-options-4 .fwe-select-options-container{max-height:210px}.fng-select-panel.fng-select-panel-options-5 .fwe-select-options-container{max-height:258px}.fng-select-panel.fng-select-panel-options-6 .fwe-select-options-container{max-height:306px}.fng-select-panel.fng-select-panel-options-7 .fwe-select-options-container{max-height:354px}.fng-select-panel.fng-select-panel-options-8 .fwe-select-options-container{max-height:402px}.fng-select-panel.fng-select-panel-options-9 .fwe-select-options-container{max-height:450px}.fng-select-panel.fng-select-panel-options-10 .fwe-select-options-container{max-height:498px}@-moz-document url-prefix(){.fng-select-panel .fwe-select-options-container{scrollbar-width:thin;scrollbar-color:var(--fwe-control-scrollbar) transparent}}@media (pointer: fine){.fng-select-panel .fwe-select-options-container::-webkit-scrollbar{width:14px}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-track{background:transparent}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-thumb{overflow:visible;background-color:var(--fwe-control-scrollbar);border:3px solid rgba(242,243,245,0);-webkit-background-clip:padding-box;background-clip:padding-box;border-radius:8px}}.fng-select-panel-wrap{flex-basis:100%}.fwe-select-options-container{position:relative;top:4px;left:0;max-height:258px;min-width:calc(100% + 0px)!important;max-width:280px;overflow:auto;font-size:var(--fwe-font-size-base);background-color:var(--fwe-white);border-radius:4px;padding:8px;margin:0;border:1px solid var(--fwe-gray-200);box-shadow:0 1px 4px #00000029;list-style:none;outline:0}.fwe-select-options-container .fwe-select-option{position:relative;line-height:24px;padding:12px 8px;min-height:24px;cursor:pointer}.fwe-select-options-container .fwe-select-option:hover{background-color:var(--fwe-gray-100)}.fwe-select-options-container .fwe-select-option:last-child{border-bottom:none}.fwe-select-options-container .fwe-select-option .fwe-select-option-content{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;line-height:24px;min-height:24px}.fng-select-pseudo-checkbox{width:16px;height:16px;border-radius:2px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;color:var(--fwe-control-border);border:1px solid;transition:none;margin-right:12px;top:-1px}.fng-select-pseudo-checkbox:after{color:var(--fwe-white);position:absolute;display:block;opacity:0;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked{background:var(--fwe-caerul);border:1px solid var(--fwe-caerul)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked:after{top:3px;left:2px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box}.chip-text-truncate{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip-removable:after{position:absolute;right:5px;top:4px;color:var(--fwe-text);font-family:var(--fwe-font-family-icons-16);font-size:var(--fwe-font-size-base);content:\"\\ea1c\";line-height:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fwe-select-wrapper{display:flex;width:inherit;min-width:48px}.fwe-select-wrapper:before{bottom:unset;top:24px}.fwe-select-wrapper.fng-hide-label{margin-top:18px}.fwe-select-wrapper.fng-hide-label:before{top:6px}.fwe-select-wrapper.fwe-disabled:before{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select{cursor:pointer;height:unset;min-height:33px}.fwe-select-wrapper .fwe-select .fwe-select-content{padding-right:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5rem}.fwe-select-wrapper .fwe-select.fwe-required:not(.fwe-disabled)~.fwe-select-label:after{position:relative;left:3px;display:inline-block;content:\"*\"}.fwe-select-wrapper .fwe-select.fwe-disabled{cursor:default;border-color:var(--fwe-control-disabled)!important}.fwe-select-wrapper .fwe-select.fwe-disabled~.fwe-select-label{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-select-content{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip{color:var(--fwe-text-disabled);border:1px solid var(--fwe-control-disabled);pointer-events:none}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip .chip-removable:after{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select-label:empty~.fwe-select-options-container,.fwe-select-wrapper .fwe-select-label.fwe-sr-only~.fwe-select-options-container{top:38px}\n"] }]
234
+ ], template: "<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n <div\n class=\"fwe-select\"\n (click)=\"toggle()\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [class.fwe-focus]=\"showOptions\"\n [class.fwe-required]=\"required\"\n [class.fwe-disabled]=\"disabled\"\n [class.fwe-pty]=\"empty\"\n >\n <div class=\"fwe-select-content\">\n <ng-container *ngIf=\"!multiple; else chips\">\n {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n </ng-container>\n <ng-template #chips>\n <div class=\"fwe-chip-container\">\n <div\n *ngFor=\"let v of value\"\n class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n [style.max-width.px]=\"triggerWidth\"\n [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n >\n {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayHasBackdrop\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"showOptions\"\n [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n (backdropClick)=\"close()\"\n >\n <div class=\"fng-select-panel-wrap\">\n <ul class=\"fwe-select-options-container\">\n <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n <li\n class=\"fwe-select-option\"\n *ngFor=\"let option of options; let i = index\"\n (click)=\"select(getOptionValue(i), $event)\"\n [title]=\"getOptionText(i) || option?.text\"\n >\n <span class=\"fwe-select-option-content\">\n <span\n *ngIf=\"multiple\"\n class=\"fng-select-pseudo-checkbox\"\n [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n ></span>\n <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n </span>\n </li>\n </ul>\n </div>\n </ng-template>\n <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n <div class=\"fwe-select-description\" *ngIf=\"hint\">\n {{ hint }}\n </div>\n <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n {{ error }}\n </div>\n</div>\n<div class=\"fwe-d-none\">\n <ng-content></ng-content>\n</div>\n", styles: [".fng-select-panel-open .fng-select-panel{opacity:1!important}fng-select{width:auto}fng-select.ng-invalid:not(.ng-pristine) .fwe-select:hover{border-color:var(--fwe-red)}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-invalid{display:block}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-description{display:none}.fng-select-panel{opacity:0!important}.fng-select-panel.fng-select-panel-options-3 .fwe-select-options-container{max-height:162px}.fng-select-panel.fng-select-panel-options-4 .fwe-select-options-container{max-height:210px}.fng-select-panel.fng-select-panel-options-5 .fwe-select-options-container{max-height:258px}.fng-select-panel.fng-select-panel-options-6 .fwe-select-options-container{max-height:306px}.fng-select-panel.fng-select-panel-options-7 .fwe-select-options-container{max-height:354px}.fng-select-panel.fng-select-panel-options-8 .fwe-select-options-container{max-height:402px}.fng-select-panel.fng-select-panel-options-9 .fwe-select-options-container{max-height:450px}.fng-select-panel.fng-select-panel-options-10 .fwe-select-options-container{max-height:498px}@-moz-document url-prefix(){.fng-select-panel .fwe-select-options-container{scrollbar-width:thin;scrollbar-color:var(--fwe-control-scrollbar) transparent}}@media (pointer: fine){.fng-select-panel .fwe-select-options-container::-webkit-scrollbar{width:14px}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-track{background:transparent}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-thumb{overflow:visible;background-color:var(--fwe-control-scrollbar);border:3px solid rgba(242,243,245,0);-webkit-background-clip:padding-box;background-clip:padding-box;border-radius:8px}}.fng-select-panel-wrap{flex-basis:100%}.fwe-select-options-container{position:relative;top:4px;left:0;max-height:258px;min-width:calc(100% + 0px)!important;max-width:280px;overflow:auto;font-size:var(--fwe-font-size-base);background-color:var(--fwe-white);border-radius:4px;padding:8px;margin:0;border:1px solid var(--fwe-gray-200);box-shadow:0 1px 4px #00000029;list-style:none;outline:0}.fwe-select-options-container .fwe-select-option{position:relative;line-height:24px;padding:12px 8px;min-height:24px;cursor:pointer}.fwe-select-options-container .fwe-select-option:hover{background-color:var(--fwe-gray-100)}.fwe-select-options-container .fwe-select-option:last-child{border-bottom:none}.fwe-select-options-container .fwe-select-option .fwe-select-option-content{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;line-height:24px;min-height:24px}.fng-select-pseudo-checkbox{width:16px;height:16px;border-radius:2px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;color:var(--fwe-control-border);border:1px solid;transition:none;margin-right:12px;top:-1px}.fng-select-pseudo-checkbox:after{color:var(--fwe-white);position:absolute;display:block;opacity:0;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked{background:var(--fwe-caerul);border:1px solid var(--fwe-caerul)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked:after{top:3px;left:2px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box}.chip-text-truncate{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip-removable:after{position:absolute;right:5px;top:4px;color:var(--fwe-text);font-family:var(--fwe-font-family-icons-16);font-size:var(--fwe-font-size-base);content:\"\\ea1c\";line-height:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fwe-select-wrapper{display:flex;width:inherit;min-width:48px}.fwe-select-wrapper:before{bottom:unset;top:24px}.fwe-select-wrapper.fng-hide-label{margin-top:18px}.fwe-select-wrapper.fng-hide-label:before{top:6px}.fwe-select-wrapper.fwe-disabled:before{color:var(--fwe-text-disabled);background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxMiAxMikiPjxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0xMiAtMTIpIj48ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIDApIj48cmVjdCB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIGZpbGw9Im5vbmUiLz48L2c+PGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNS41OTggOC41MTMpIj48cGF0aCBkPSJNNS42MzYsOS4xOTRsNi4yNzgsNi41NjQsNi4yNzgtNi41NjQtLjctLjczTDExLjkxNCwxNC4zLDYuMzMzLDguNDY0WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTUuNjM2IC04LjQ2NCkiIGZpbGw9IiNiOWJhYmIiLz48L2c+PC9nPjwvZz48L3N2Zz4=)}.fwe-select-wrapper .fwe-select{cursor:pointer;height:unset;min-height:33px}.fwe-select-wrapper .fwe-select .fwe-select-content{padding-right:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5rem}.fwe-select-wrapper .fwe-select.fwe-required:not(.fwe-disabled)~.fwe-select-label:after{position:relative;left:3px;display:inline-block;content:\"*\"}.fwe-select-wrapper .fwe-select.fwe-disabled{cursor:default;border-color:var(--fwe-control-disabled)!important}.fwe-select-wrapper .fwe-select.fwe-disabled~.fwe-select-label{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-select-content{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip{color:var(--fwe-text-disabled);border:1px solid var(--fwe-control-disabled);pointer-events:none}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip .chip-removable:after{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select-label:empty~.fwe-select-options-container,.fwe-select-wrapper .fwe-select-label.fwe-sr-only~.fwe-select-options-container{top:38px}\n"] }]
235
235
  }], ctorParameters: () => [{ type: undefined, decorators: [{
236
236
  type: Inject,
237
237
  args: [DOCUMENT]
@@ -272,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
272
272
  }], fngChange: [{
273
273
  type: Output
274
274
  }] } });
275
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/select/select.component.ts","../../../../../../projects/angular/src/lib/forms/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { takeUntil } from 'rxjs/operators';\nimport {\n  Component,\n  Input,\n  HostBinding,\n  OnInit,\n  ViewEncapsulation,\n  Renderer2,\n  Inject,\n  forwardRef,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  QueryList,\n  ContentChildren,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n  AfterContentInit\n} from '@angular/core';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FngSelectOptionComponent } from './select-option/select-option.component';\nimport { FngChipTextPipe } from './chip-text.pipe';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { Subject } from 'rxjs';\n\nexport interface FngSelectOption {\n  value: any;\n  text: string;\n}\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, FngChipTextPipe, FngSelectOptionComponent, OverlayModule],\n  selector: 'fng-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class FngSelectComponent implements ControlValueAccessor, OnInit, AfterViewInit, AfterContentInit {\n  static nextId = 0;\n\n  protected _disabled = false;\n  protected _required = false;\n  protected _value: any;\n  protected body: HTMLElement;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  set value(value: any) {\n    if (this.multiple === true) {\n      const index = this._value.indexOf(value);\n      if (index === -1) {\n        this._value.push(value);\n        this.checked.set(value, 'checked');\n      } else {\n        this._value.splice(index, 1);\n        this.checked.set(value, null);\n      }\n    } else {\n      this._value = value;\n    }\n\n    if (this.onChange != null) {\n      this.onChange(this.value);\n    }\n    this.fngChange.emit(this.value);\n  }\n\n  onChange: ((_: any) => void) | undefined;\n  onTouched: (() => void) | undefined;\n\n  touched = false;\n\n  @HostBinding()\n  id = `input-control-${++FngSelectComponent.nextId}`;\n\n  @Input() multiple: boolean = false;\n  @Input() size: number = 0;\n  @Input() options: any[] = [];\n  @Input() optionsValueKey: string | undefined;\n  @Input() optionsTextKey: string | undefined;\n  @Input() optionObjectAsValue: boolean | undefined;\n  @Input() error: string | undefined;\n  @Input() label = '';\n  @Input() hideLabel = false;\n  @Input() hint = '';\n  @Input() resetOption: string | undefined;\n  @ContentChildren(FngSelectOptionComponent) fngSelectOptions: QueryList<FngSelectOptionComponent> | undefined;\n  @ViewChild('div') elementRef: ElementRef | undefined;\n  @Output() fngChange = new EventEmitter<any>();\n\n  selectPanelClasses: string[] = ['fng-select-panel'];\n  showOptions = false;\n  empty: boolean = false;\n  triggerWidth: any;\n  checked = new Map();\n  hasProjectedOptions = false;\n  projectedHtml: any[] = [];\n  protected complete: Subject<boolean> = new Subject();\n\n  constructor(@Inject(DOCUMENT) protected document: any, protected renderer: Renderer2, public cd: ChangeDetectorRef) {\n    this.body = (this.document as Document).body;\n  }\n  ngAfterContentInit(): void {\n    // observe if any of the projected content (fng-select-option) changes\n    this.fngSelectOptions?.changes.pipe(takeUntil(this.complete)).subscribe(_ => {\n      // if content changes init again\n      this.options = [];\n      this.projectedHtml = [];\n      this.initProjectedOptions();\n    });\n  }\n\n  ngOnInit(): void {\n    if (this.size != null) {\n      this.selectPanelClasses.push('fng-select-panel-options-' + this.size);\n    }\n\n    if (this.multiple === true) {\n      this._value = [];\n      this.selectPanelClasses.push('fng-select-panel-multiple');\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n    this.initProjectedOptions();\n  }\n\n  ngOnDestroy(): void {\n    this.complete.next(true);\n    this.complete.unsubscribe();\n  }\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(shouldDisable: boolean): void {\n    this.disabled = shouldDisable;\n  }\n\n  writeValue(value: any | null): void {\n    if (value === undefined) {\n      return;\n    }\n\n    if (this.multiple === true) {\n      this._value = value;\n\n      // clear any previous state of overlay panel\n      this.checked.clear();\n\n      // set checkmarks in overlay panel, so that it is displayed correctly when user opens it\n      value?.forEach((v: any) => {\n        this.checked.set(v, 'checked');\n      });\n    } else {\n      this._value = value;\n    }\n  }\n\n  getOptionText(index: number) {\n    if (this.options[index] && this.optionsTextKey && this.options[index][this.optionsTextKey] != null) {\n      return this.options[index][this.optionsTextKey];\n    }\n    return undefined;\n  }\n\n  getOptionValue(index: number) {\n    // if set to true the complete option object is returned as value\n    if (this.optionObjectAsValue === true) {\n      return this.options[index];\n    }\n\n    // try to access standard property 'value'\n    const v = this.options[index]['value'];\n\n    if (v !== undefined) {\n      return v;\n    }\n\n    // try to map the value to a property of the option by given key\n    if (this.options[index] && this.optionsValueKey && this.options[index][this.optionsValueKey] != null) {\n      return this.options[index][this.optionsValueKey];\n    }\n    return undefined;\n  }\n\n  removeChip(event: any, chip: string) {\n    event.stopPropagation();\n    if (!this._disabled) {\n      this.markAsTouched();\n      this.value = chip;\n    }\n  }\n\n  onOpenedChange(isOpen: boolean) {\n    if (isOpen) {\n      this.renderer.addClass(this.body, 'fng-select-panel-open');\n    } else {\n      this.renderer.removeClass(this.body, 'fng-select-panel-open');\n    }\n  }\n\n  close() {\n    this.showOptions = false;\n    this.isEmpty();\n  }\n\n  toggle() {\n    if (false === this.disabled) {\n      this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n      this.showOptions = !this.showOptions;\n      this.onOpenedChange(this.showOptions);\n      this.isEmpty();\n    }\n  }\n\n  select(value: any, event: Event) {\n    if (!this._disabled) {\n      this.markAsTouched();\n      event.stopPropagation();\n      this.value = value;\n\n      if (this.multiple !== true) {\n        // closes overlay panel\n        this.toggle();\n      }\n    }\n  }\n\n  markAsTouched() {\n    if (!this.touched) {\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n      this.touched = true;\n    }\n  }\n\n  initProjectedOptions() {\n    if (this.fngSelectOptions?.length) {\n      this.hasProjectedOptions = true;\n      this.fngSelectOptions.forEach(component => {\n        component.update().then(el => {\n          if (el) {\n            this.options.push({ value: component.value, text: el.textContent?.trim() });\n            this.projectedHtml.push(el.innerHTML);\n            this.cd.detectChanges();\n          }\n        });\n      });\n    }\n    this.cd.detectChanges();\n  }\n\n  isEmpty() {\n    if (!this.showOptions && (!this._value || '' === this._value)) {\n      this.empty = true;\n    } else {\n      this.empty = false;\n    }\n  }\n}\n","<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n  <div\n    class=\"fwe-select\"\n    (click)=\"toggle()\"\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    [class.fwe-focus]=\"showOptions\"\n    [class.fwe-required]=\"required\"\n    [class.fwe-disabled]=\"disabled\"\n    [class.fwe-pty]=\"empty\"\n  >\n    <div class=\"fwe-select-content\">\n      <ng-container *ngIf=\"!multiple; else chips\">\n        {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n      </ng-container>\n      <ng-template #chips>\n        <div class=\"fwe-chip-container\">\n          <div\n            *ngFor=\"let v of value\"\n            class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n            [style.max-width.px]=\"triggerWidth\"\n            [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n          >\n            {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n            <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n          </div>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n  <ng-template\n    cdkConnectedOverlay\n    cdkConnectedOverlayHasBackdrop\n    cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n    [cdkConnectedOverlayOrigin]=\"trigger\"\n    [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n    [cdkConnectedOverlayOpen]=\"showOptions\"\n    [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n    (backdropClick)=\"close()\"\n  >\n    <div class=\"fng-select-panel-wrap\">\n      <ul class=\"fwe-select-options-container\">\n        <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n        <li\n          class=\"fwe-select-option\"\n          *ngFor=\"let option of options; let i = index\"\n          (click)=\"select(getOptionValue(i), $event)\"\n          [title]=\"getOptionText(i) || option?.text\"\n        >\n          <span class=\"fwe-select-option-content\">\n            <span\n              *ngIf=\"multiple\"\n              class=\"fng-select-pseudo-checkbox\"\n              [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n            ></span>\n            <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n            <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n          </span>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n  <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n  <div class=\"fwe-select-description\" *ngIf=\"hint\">\n    {{ hint }}\n  </div>\n  <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n    {{ error }}\n  </div>\n</div>\n<div class=\"fwe-d-none\">\n  <ng-content></ng-content>\n</div>\n"]}
275
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/select/select.component.ts","../../../../../../projects/angular/src/lib/forms/select/select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EACL,SAAS,EACT,KAAK,EACL,WAAW,EAEX,iBAAiB,EAEjB,MAAM,EACN,UAAU,EACV,SAAS,EAIT,eAAe,EACf,MAAM,EACN,YAAY,EAGb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,wBAAwB,EAAE,MAAM,yCAAyC,CAAC;AACnF,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;AAsB/B,MAAM,OAAO,kBAAkB;aACtB,WAAM,GAAG,CAAC,AAAJ,CAAK;IAOlB,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,KAAK,CAAC,KAAU;QAClB,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;YAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;gBACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YACrC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;gBAC7B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YAChC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACtB,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE,CAAC;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAkCD,YAAwC,QAAa,EAAY,QAAmB,EAAS,EAAqB;QAA1E,aAAQ,GAAR,QAAQ,CAAK;QAAY,aAAQ,GAAR,QAAQ,CAAW;QAAS,OAAE,GAAF,EAAE,CAAmB;QA7ExG,cAAS,GAAG,KAAK,CAAC;QAClB,cAAS,GAAG,KAAK,CAAC;QA+C5B,YAAO,GAAG,KAAK,CAAC;QAGhB,OAAE,GAAG,iBAAiB,EAAE,kBAAkB,CAAC,MAAM,EAAE,CAAC;QAE3C,aAAQ,GAAY,KAAK,CAAC;QAC1B,SAAI,GAAW,CAAC,CAAC;QACjB,YAAO,GAAU,EAAE,CAAC;QAKpB,UAAK,GAAG,EAAE,CAAC;QACX,cAAS,GAAG,KAAK,CAAC;QAClB,SAAI,GAAG,EAAE,CAAC;QAIT,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;QAE9C,uBAAkB,GAAa,CAAC,kBAAkB,CAAC,CAAC;QACpD,gBAAW,GAAG,KAAK,CAAC;QACpB,UAAK,GAAY,KAAK,CAAC;QAEvB,YAAO,GAAG,IAAI,GAAG,EAAE,CAAC;QACpB,wBAAmB,GAAG,KAAK,CAAC;QAC5B,kBAAa,GAAU,EAAE,CAAC;QAChB,aAAQ,GAAqB,IAAI,OAAO,EAAE,CAAC;QAGnD,IAAI,CAAC,IAAI,GAAI,IAAI,CAAC,QAAqB,CAAC,IAAI,CAAC;IAC/C,CAAC;IACD,kBAAkB;QAChB,sEAAsE;QACtE,IAAI,CAAC,gBAAgB,EAAE,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC1E,gCAAgC;YAChC,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC;YACtB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;QACxE,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,aAAa,EAAE,qBAAqB,EAAE,EAAE,KAAK,CAAC;QACnF,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,aAAsB;QACrC,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,KAAiB;QAC1B,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YAEpB,4CAA4C;YAC5C,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAErB,wFAAwF;YACxF,KAAK,EAAE,OAAO,CAAC,CAAC,CAAM,EAAE,EAAE;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACtB,CAAC;IACH,CAAC;IAED,aAAa,CAAC,KAAa;QACzB,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,IAAI,EAAE,CAAC;YACnG,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAClD,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,cAAc,CAAC,KAAa;QAC1B,iEAAiE;QACjE,IAAI,IAAI,CAAC,mBAAmB,KAAK,IAAI,EAAE,CAAC;YACtC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;QAED,0CAA0C;QAC1C,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC;QAEvC,IAAI,CAAC,KAAK,SAAS,EAAE,CAAC;YACpB,OAAO,CAAC,CAAC;QACX,CAAC;QAED,gEAAgE;QAChE,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,IAAI,EAAE,CAAC;YACrG,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACnD,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,UAAU,CAAC,KAAU,EAAE,IAAY;QACjC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,CAAC;IACH,CAAC;IAED,cAAc,CAAC,MAAe;QAC5B,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC;QAC7D,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC;QAChE,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,MAAM;QACJ,IAAI,KAAK,KAAK,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,aAAa,EAAE,qBAAqB,EAAE,EAAE,KAAK,CAAC;YACnF,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;YACrC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAU,EAAE,KAAY;QAC7B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YAEnB,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;gBAC3B,uBAAuB;gBACvB,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC;QACH,CAAC;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE,CAAC;gBAC3B,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,CAAC;YACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,IAAI,CAAC,gBAAgB,EAAE,MAAM,EAAE,CAAC;YAClC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;YAChC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBACxC,SAAS,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;oBAC3B,IAAI,EAAE,EAAE,CAAC;wBACP,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,WAAW,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;wBAC5E,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;wBACtC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;oBAC1B,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IAED,OAAO;QACL,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YAC9D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,CAAC;IACH,CAAC;8GAvPU,kBAAkB,kBAgFT,QAAQ;kGAhFjB,kBAAkB,6cARlB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;gBACjD,KAAK,EAAE,IAAI;aACZ;SACF,2DAqEgB,wBAAwB,gICnH3C,s4FAyEA,8sLDtCY,YAAY,yVAAE,eAAe,mDAA4B,aAAa;;2FAarE,kBAAkB;kBAf9B,SAAS;iCACI,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,EAAE,wBAAwB,EAAE,aAAa,CAAC,YACvE,YAAY,iBAGP,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACZ;qBACF;;0BAkFY,MAAM;2BAAC,QAAQ;iGAvExB,QAAQ;sBADX,KAAK;gBASF,QAAQ;sBADX,KAAK;gBAsCN,EAAE;sBADD,WAAW;gBAGH,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACqC,gBAAgB;sBAA1D,eAAe;uBAAC,wBAAwB;gBACvB,UAAU;sBAA3B,SAAS;uBAAC,KAAK;gBACN,SAAS;sBAAlB,MAAM","sourcesContent":["import { takeUntil } from 'rxjs/operators';\nimport {\n  Component,\n  Input,\n  HostBinding,\n  OnInit,\n  ViewEncapsulation,\n  Renderer2,\n  Inject,\n  forwardRef,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  QueryList,\n  ContentChildren,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n  AfterContentInit\n} from '@angular/core';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FngSelectOptionComponent } from './select-option/select-option.component';\nimport { FngChipTextPipe } from './chip-text.pipe';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { Subject } from 'rxjs';\n\nexport interface FngSelectOption {\n  value: any;\n  text: string;\n}\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, FngChipTextPipe, FngSelectOptionComponent, OverlayModule],\n  selector: 'fng-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class FngSelectComponent implements ControlValueAccessor, OnInit, AfterViewInit, AfterContentInit {\n  static nextId = 0;\n\n  protected _disabled = false;\n  protected _required = false;\n  protected _value: any;\n  protected body: HTMLElement;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  set value(value: any) {\n    if (this.multiple === true) {\n      const index = this._value.indexOf(value);\n      if (index === -1) {\n        this._value.push(value);\n        this.checked.set(value, 'checked');\n      } else {\n        this._value.splice(index, 1);\n        this.checked.set(value, null);\n      }\n    } else {\n      this._value = value;\n    }\n\n    if (this.onChange != null) {\n      this.onChange(this.value);\n    }\n    this.fngChange.emit(this.value);\n  }\n\n  onChange: ((_: any) => void) | undefined;\n  onTouched: (() => void) | undefined;\n\n  touched = false;\n\n  @HostBinding()\n  id = `input-control-${++FngSelectComponent.nextId}`;\n\n  @Input() multiple: boolean = false;\n  @Input() size: number = 0;\n  @Input() options: any[] = [];\n  @Input() optionsValueKey: string | undefined;\n  @Input() optionsTextKey: string | undefined;\n  @Input() optionObjectAsValue: boolean | undefined;\n  @Input() error: string | undefined;\n  @Input() label = '';\n  @Input() hideLabel = false;\n  @Input() hint = '';\n  @Input() resetOption: string | undefined;\n  @ContentChildren(FngSelectOptionComponent) fngSelectOptions: QueryList<FngSelectOptionComponent> | undefined;\n  @ViewChild('div') elementRef: ElementRef | undefined;\n  @Output() fngChange = new EventEmitter<any>();\n\n  selectPanelClasses: string[] = ['fng-select-panel'];\n  showOptions = false;\n  empty: boolean = false;\n  triggerWidth: any;\n  checked = new Map();\n  hasProjectedOptions = false;\n  projectedHtml: any[] = [];\n  protected complete: Subject<boolean> = new Subject();\n\n  constructor(@Inject(DOCUMENT) protected document: any, protected renderer: Renderer2, public cd: ChangeDetectorRef) {\n    this.body = (this.document as Document).body;\n  }\n  ngAfterContentInit(): void {\n    // observe if any of the projected content (fng-select-option) changes\n    this.fngSelectOptions?.changes.pipe(takeUntil(this.complete)).subscribe(_ => {\n      // if content changes init again\n      this.options = [];\n      this.projectedHtml = [];\n      this.initProjectedOptions();\n    });\n  }\n\n  ngOnInit(): void {\n    if (this.size != null) {\n      this.selectPanelClasses.push('fng-select-panel-options-' + this.size);\n    }\n\n    if (this.multiple === true) {\n      this._value = [];\n      this.selectPanelClasses.push('fng-select-panel-multiple');\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n    this.initProjectedOptions();\n  }\n\n  ngOnDestroy(): void {\n    this.complete.next(true);\n    this.complete.unsubscribe();\n  }\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(shouldDisable: boolean): void {\n    this.disabled = shouldDisable;\n  }\n\n  writeValue(value: any | null): void {\n    if (value === undefined) {\n      return;\n    }\n\n    if (this.multiple === true) {\n      this._value = value;\n\n      // clear any previous state of overlay panel\n      this.checked.clear();\n\n      // set checkmarks in overlay panel, so that it is displayed correctly when user opens it\n      value?.forEach((v: any) => {\n        this.checked.set(v, 'checked');\n      });\n    } else {\n      this._value = value;\n    }\n  }\n\n  getOptionText(index: number) {\n    if (this.options[index] && this.optionsTextKey && this.options[index][this.optionsTextKey] != null) {\n      return this.options[index][this.optionsTextKey];\n    }\n    return undefined;\n  }\n\n  getOptionValue(index: number) {\n    // if set to true the complete option object is returned as value\n    if (this.optionObjectAsValue === true) {\n      return this.options[index];\n    }\n\n    // try to access standard property 'value'\n    const v = this.options[index]['value'];\n\n    if (v !== undefined) {\n      return v;\n    }\n\n    // try to map the value to a property of the option by given key\n    if (this.options[index] && this.optionsValueKey && this.options[index][this.optionsValueKey] != null) {\n      return this.options[index][this.optionsValueKey];\n    }\n    return undefined;\n  }\n\n  removeChip(event: any, chip: string) {\n    event.stopPropagation();\n    if (!this._disabled) {\n      this.markAsTouched();\n      this.value = chip;\n    }\n  }\n\n  onOpenedChange(isOpen: boolean) {\n    if (isOpen) {\n      this.renderer.addClass(this.body, 'fng-select-panel-open');\n    } else {\n      this.renderer.removeClass(this.body, 'fng-select-panel-open');\n    }\n  }\n\n  close() {\n    this.showOptions = false;\n    this.isEmpty();\n  }\n\n  toggle() {\n    if (false === this.disabled) {\n      this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n      this.showOptions = !this.showOptions;\n      this.onOpenedChange(this.showOptions);\n      this.isEmpty();\n    }\n  }\n\n  select(value: any, event: Event) {\n    if (!this._disabled) {\n      this.markAsTouched();\n      event.stopPropagation();\n      this.value = value;\n\n      if (this.multiple !== true) {\n        // closes overlay panel\n        this.toggle();\n      }\n    }\n  }\n\n  markAsTouched() {\n    if (!this.touched) {\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n      this.touched = true;\n    }\n  }\n\n  initProjectedOptions() {\n    if (this.fngSelectOptions?.length) {\n      this.hasProjectedOptions = true;\n      this.fngSelectOptions.forEach(component => {\n        component.update().then(el => {\n          if (el) {\n            this.options.push({ value: component.value, text: el.textContent?.trim() });\n            this.projectedHtml.push(el.innerHTML);\n            this.cd.detectChanges();\n          }\n        });\n      });\n    }\n    this.cd.detectChanges();\n  }\n\n  isEmpty() {\n    if (!this.showOptions && (!this._value || '' === this._value)) {\n      this.empty = true;\n    } else {\n      this.empty = false;\n    }\n  }\n}\n","<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n  <div\n    class=\"fwe-select\"\n    (click)=\"toggle()\"\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    [class.fwe-focus]=\"showOptions\"\n    [class.fwe-required]=\"required\"\n    [class.fwe-disabled]=\"disabled\"\n    [class.fwe-pty]=\"empty\"\n  >\n    <div class=\"fwe-select-content\">\n      <ng-container *ngIf=\"!multiple; else chips\">\n        {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n      </ng-container>\n      <ng-template #chips>\n        <div class=\"fwe-chip-container\">\n          <div\n            *ngFor=\"let v of value\"\n            class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n            [style.max-width.px]=\"triggerWidth\"\n            [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n          >\n            {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n            <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n          </div>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n  <ng-template\n    cdkConnectedOverlay\n    cdkConnectedOverlayHasBackdrop\n    cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n    [cdkConnectedOverlayOrigin]=\"trigger\"\n    [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n    [cdkConnectedOverlayOpen]=\"showOptions\"\n    [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n    (backdropClick)=\"close()\"\n  >\n    <div class=\"fng-select-panel-wrap\">\n      <ul class=\"fwe-select-options-container\">\n        <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n        <li\n          class=\"fwe-select-option\"\n          *ngFor=\"let option of options; let i = index\"\n          (click)=\"select(getOptionValue(i), $event)\"\n          [title]=\"getOptionText(i) || option?.text\"\n        >\n          <span class=\"fwe-select-option-content\">\n            <span\n              *ngIf=\"multiple\"\n              class=\"fng-select-pseudo-checkbox\"\n              [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n            ></span>\n            <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n            <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n          </span>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n  <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n  <div class=\"fwe-select-description\" *ngIf=\"hint\">\n    {{ hint }}\n  </div>\n  <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n    {{ error }}\n  </div>\n</div>\n<div class=\"fwe-d-none\">\n  <ng-content></ng-content>\n</div>\n"]}