ecabs-components 0.0.65 → 0.0.66
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/base/directives/tooltip-if-truncated.directive.mjs +29 -0
- package/esm2020/lib/base/directives/tooltip-if-truncated.directive.module.mjs +22 -0
- package/esm2020/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.mjs +19 -43
- package/esm2020/lib/ecabs-select/ecabs-select.component.mjs +17 -5
- package/esm2020/lib/ecabs-select/ecabs-select.module.mjs +18 -10
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/ecabs-components.mjs +99 -62
- package/fesm2015/ecabs-components.mjs.map +1 -1
- package/fesm2020/ecabs-components.mjs +97 -61
- package/fesm2020/ecabs-components.mjs.map +1 -1
- package/lib/base/directives/tooltip-if-truncated.directive.d.ts +12 -0
- package/lib/base/directives/tooltip-if-truncated.directive.module.d.ts +8 -0
- package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.d.ts +2 -6
- package/lib/ecabs-select/ecabs-select.component.d.ts +1 -0
- package/lib/ecabs-select/ecabs-select.module.d.ts +5 -3
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Directive, HostListener, Input } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/material/tooltip";
|
|
4
|
+
export class TooltipIfTruncatedDirective {
|
|
5
|
+
constructor(matTooltip, elementRef) {
|
|
6
|
+
this.matTooltip = matTooltip;
|
|
7
|
+
this.elementRef = elementRef;
|
|
8
|
+
}
|
|
9
|
+
onMouseOver() {
|
|
10
|
+
const element = this.classNameTruncatedTooltip?.length > 0
|
|
11
|
+
? this.elementRef.nativeElement.getElementsByClassName(this.classNameTruncatedTooltip)[0]
|
|
12
|
+
: this.elementRef.nativeElement;
|
|
13
|
+
this.matTooltip.disabled = element?.scrollWidth <= element?.clientWidth;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
TooltipIfTruncatedDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TooltipIfTruncatedDirective, deps: [{ token: i1.MatTooltip }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
17
|
+
TooltipIfTruncatedDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: TooltipIfTruncatedDirective, selector: "[matTooltip][appTooltipIfTruncated]", inputs: { classNameTruncatedTooltip: "classNameTruncatedTooltip" }, host: { listeners: { "mouseover": "onMouseOver()" } }, ngImport: i0 });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TooltipIfTruncatedDirective, decorators: [{
|
|
19
|
+
type: Directive,
|
|
20
|
+
args: [{
|
|
21
|
+
selector: '[matTooltip][appTooltipIfTruncated]',
|
|
22
|
+
}]
|
|
23
|
+
}], ctorParameters: function () { return [{ type: i1.MatTooltip }, { type: i0.ElementRef }]; }, propDecorators: { classNameTruncatedTooltip: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], onMouseOver: [{
|
|
26
|
+
type: HostListener,
|
|
27
|
+
args: ['mouseover']
|
|
28
|
+
}] } });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1pZi10cnVuY2F0ZWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvZGlyZWN0aXZlcy90b29sdGlwLWlmLXRydW5jYXRlZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFNM0UsTUFBTSxPQUFPLDJCQUEyQjtJQUd0QyxZQUE4QixVQUFzQixFQUFtQixVQUFtQztRQUE1RSxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQW1CLGVBQVUsR0FBVixVQUFVLENBQXlCO0lBQUssQ0FBQztJQUdoSCxXQUFXO1FBQ1QsTUFBTSxPQUFPLEdBQ1gsSUFBSSxDQUFDLHlCQUF5QixFQUFFLE1BQU0sR0FBRyxDQUFDO1lBQ3hDLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBRSxJQUFJLENBQUMseUJBQXlCLENBQUUsQ0FBRSxDQUFDLENBQUU7WUFDN0YsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO1FBQ3BDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxHQUFHLE9BQU8sRUFBRSxXQUFXLElBQUksT0FBTyxFQUFFLFdBQVcsQ0FBQztJQUMxRSxDQUFDOzt3SEFaVSwyQkFBMkI7NEdBQTNCLDJCQUEyQjsyRkFBM0IsMkJBQTJCO2tCQUh2QyxTQUFTO21CQUFFO29CQUNWLFFBQVEsRUFBRSxxQ0FBcUM7aUJBQ2hEOzBIQUVVLHlCQUF5QjtzQkFBakMsS0FBSztnQkFLTixXQUFXO3NCQURWLFlBQVk7dUJBQUUsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXAgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcFwiO1xyXG5cclxuQERpcmVjdGl2ZSgge1xyXG4gIHNlbGVjdG9yOiAnW21hdFRvb2x0aXBdW2FwcFRvb2x0aXBJZlRydW5jYXRlZF0nLFxyXG59IClcclxuZXhwb3J0IGNsYXNzIFRvb2x0aXBJZlRydW5jYXRlZERpcmVjdGl2ZSB7XHJcbiAgQElucHV0KCkgY2xhc3NOYW1lVHJ1bmNhdGVkVG9vbHRpcDogc3RyaW5nO1xyXG5cclxuICBjb25zdHJ1Y3RvciggcHJpdmF0ZSByZWFkb25seSBtYXRUb29sdGlwOiBNYXRUb29sdGlwLCBwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+ICkgeyB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoICdtb3VzZW92ZXInIClcclxuICBvbk1vdXNlT3ZlcigpOiB2b2lkIHtcclxuICAgIGNvbnN0IGVsZW1lbnQgPVxyXG4gICAgICB0aGlzLmNsYXNzTmFtZVRydW5jYXRlZFRvb2x0aXA/Lmxlbmd0aCA+IDBcclxuICAgICAgICA/IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmdldEVsZW1lbnRzQnlDbGFzc05hbWUoIHRoaXMuY2xhc3NOYW1lVHJ1bmNhdGVkVG9vbHRpcCApWyAwIF1cclxuICAgICAgICA6IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xyXG4gICAgdGhpcy5tYXRUb29sdGlwLmRpc2FibGVkID0gZWxlbWVudD8uc2Nyb2xsV2lkdGggPD0gZWxlbWVudD8uY2xpZW50V2lkdGg7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { TooltipIfTruncatedDirective } from './tooltip-if-truncated.directive';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class TooltipIfTruncatedDirectiveModule {
|
|
6
|
+
}
|
|
7
|
+
TooltipIfTruncatedDirectiveModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TooltipIfTruncatedDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
TooltipIfTruncatedDirectiveModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TooltipIfTruncatedDirectiveModule, declarations: [TooltipIfTruncatedDirective], imports: [CommonModule], exports: [TooltipIfTruncatedDirective] });
|
|
9
|
+
TooltipIfTruncatedDirectiveModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TooltipIfTruncatedDirectiveModule, imports: [CommonModule] });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TooltipIfTruncatedDirectiveModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
imports: [CommonModule],
|
|
14
|
+
declarations: [
|
|
15
|
+
TooltipIfTruncatedDirective,
|
|
16
|
+
],
|
|
17
|
+
exports: [
|
|
18
|
+
TooltipIfTruncatedDirective,
|
|
19
|
+
],
|
|
20
|
+
}]
|
|
21
|
+
}] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1pZi10cnVuY2F0ZWQuZGlyZWN0aXZlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9iYXNlL2RpcmVjdGl2ZXMvdG9vbHRpcC1pZi10cnVuY2F0ZWQuZGlyZWN0aXZlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7QUFZL0UsTUFBTSxPQUFPLGlDQUFpQzs7OEhBQWpDLGlDQUFpQzsrSEFBakMsaUNBQWlDLGlCQU4xQywyQkFBMkIsYUFGbEIsWUFBWSxhQUtyQiwyQkFBMkI7K0hBR2xCLGlDQUFpQyxZQVJqQyxZQUFZOzJGQVFaLGlDQUFpQztrQkFUN0MsUUFBUTttQkFBRTtvQkFDVCxPQUFPLEVBQUUsQ0FBRSxZQUFZLENBQUU7b0JBQ3pCLFlBQVksRUFBRTt3QkFDWiwyQkFBMkI7cUJBQzVCO29CQUNELE9BQU8sRUFBRTt3QkFDUCwyQkFBMkI7cUJBQzVCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVG9vbHRpcElmVHJ1bmNhdGVkRGlyZWN0aXZlIH0gZnJvbSAnLi90b29sdGlwLWlmLXRydW5jYXRlZC5kaXJlY3RpdmUnO1xyXG5cclxuXHJcbkBOZ01vZHVsZSgge1xyXG4gIGltcG9ydHM6IFsgQ29tbW9uTW9kdWxlIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBUb29sdGlwSWZUcnVuY2F0ZWREaXJlY3RpdmUsXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBUb29sdGlwSWZUcnVuY2F0ZWREaXJlY3RpdmUsXHJcbiAgXSxcclxufSApXHJcbmV4cG9ydCBjbGFzcyBUb29sdGlwSWZUcnVuY2F0ZWREaXJlY3RpdmVNb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -15,11 +15,10 @@ import * as i7 from "../base/directives/digits-only.directive";
|
|
|
15
15
|
import * as i8 from "../base/directives/number-border.directive";
|
|
16
16
|
import * as i9 from "../base/directives/date-mask.directive";
|
|
17
17
|
export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
18
|
-
constructor(injector, decimalPipe
|
|
18
|
+
constructor(injector, decimalPipe) {
|
|
19
19
|
super();
|
|
20
20
|
this.injector = injector;
|
|
21
21
|
this.decimalPipe = decimalPipe;
|
|
22
|
-
this.cd = cd;
|
|
23
22
|
this.touchUi = false;
|
|
24
23
|
this.hideSeconds = true;
|
|
25
24
|
this.cancleLabel = 'Cancel';
|
|
@@ -32,8 +31,6 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
32
31
|
this.header = EcabsDateTimePickerHeaderComponent;
|
|
33
32
|
this.maxValueHours = 23;
|
|
34
33
|
this.maxValueMinutesSeconds = 59;
|
|
35
|
-
this.preventCallSetterPickerValue = false;
|
|
36
|
-
this.runTimeout = false;
|
|
37
34
|
this.onChange = () => { };
|
|
38
35
|
this.onTouch = () => { };
|
|
39
36
|
}
|
|
@@ -68,40 +65,19 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
68
65
|
}
|
|
69
66
|
}
|
|
70
67
|
set value(val) {
|
|
71
|
-
if (val && this.val
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
this.
|
|
68
|
+
if (val && this.val !== new Date(val)) {
|
|
69
|
+
this.val = new Date(val);
|
|
70
|
+
this.pickerValue = this.formatDateTime(val);
|
|
71
|
+
this.onChange(val);
|
|
72
|
+
this.onTouch(val);
|
|
76
73
|
}
|
|
77
74
|
}
|
|
78
75
|
set pickerValue(val) {
|
|
79
76
|
if (val) {
|
|
80
77
|
const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
|
|
81
78
|
if (isValid(date) && this._pickerValue !== val) {
|
|
82
|
-
if (this.minDate && date < this.minDate) {
|
|
83
|
-
this.setValues(this.minDate);
|
|
84
|
-
this._pickerValue = val;
|
|
85
|
-
this.preventCallSetterPickerValue = true;
|
|
86
|
-
this.value = this.minDate;
|
|
87
|
-
this.runTimeout = true;
|
|
88
|
-
this.refreshPickerValue(this.minDate);
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
if (this.maxDate && date > this.maxDate) {
|
|
92
|
-
this.setValues(this.maxDate);
|
|
93
|
-
this._pickerValue = val;
|
|
94
|
-
this.preventCallSetterPickerValue = true;
|
|
95
|
-
this.value = this.maxDate;
|
|
96
|
-
this.runTimeout = true;
|
|
97
|
-
this.refreshPickerValue(this.maxDate);
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
this.runTimeout = false;
|
|
101
79
|
this._pickerValue = val;
|
|
102
|
-
this.preventCallSetterPickerValue = true;
|
|
103
80
|
this.value = date;
|
|
104
|
-
this.setValues(date);
|
|
105
81
|
}
|
|
106
82
|
}
|
|
107
83
|
}
|
|
@@ -132,17 +108,19 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
132
108
|
onApply() {
|
|
133
109
|
if (this._date && this._seconds && this._minutes && this._hours) {
|
|
134
110
|
const date = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);
|
|
111
|
+
if (this.minDate && date < this.minDate) {
|
|
112
|
+
this.setValues(this.minDate);
|
|
113
|
+
this.value = this.minDate;
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
if (this.maxDate && date > this.maxDate) {
|
|
117
|
+
this.setValues(this.maxDate);
|
|
118
|
+
this.value = this.maxDate;
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
135
121
|
this.value = date;
|
|
136
122
|
}
|
|
137
123
|
}
|
|
138
|
-
refreshPickerValue(date) {
|
|
139
|
-
setTimeout(() => {
|
|
140
|
-
if (this.runTimeout) {
|
|
141
|
-
this._pickerValue = this.formatDateTime(date);
|
|
142
|
-
this.cd.detectChanges();
|
|
143
|
-
}
|
|
144
|
-
}, 3000);
|
|
145
|
-
}
|
|
146
124
|
formatDateTime(date) {
|
|
147
125
|
let result = '';
|
|
148
126
|
if (date && isValid(new Date(date))) {
|
|
@@ -156,15 +134,13 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
156
134
|
return this.decimalPipe.transform(num, '2.0-0') ?? '00';
|
|
157
135
|
}
|
|
158
136
|
setValues(date) {
|
|
159
|
-
this.onChange(date);
|
|
160
|
-
this.onTouch(date);
|
|
161
137
|
this._date = date;
|
|
162
138
|
this.hours = date.getHours().toString();
|
|
163
139
|
this.minutes = date.getMinutes().toString();
|
|
164
140
|
this.seconds = date.getSeconds().toString();
|
|
165
141
|
}
|
|
166
142
|
}
|
|
167
|
-
EcabsDateTimePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }
|
|
143
|
+
EcabsDateTimePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
168
144
|
EcabsDateTimePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: EcabsDateTimePickerComponent, selector: "ecabs-date-time-picker", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", hideSeconds: "hideSeconds", cancleLabel: "cancleLabel", applyLabel: "applyLabel", selectDateLabel: "selectDateLabel" }, outputs: { onblur: "onblur" }, providers: [
|
|
169
145
|
{
|
|
170
146
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -183,7 +159,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
183
159
|
},
|
|
184
160
|
DecimalPipe,
|
|
185
161
|
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper w-full\">\r\n <input\r\n class=\"fake-input\"\r\n [id]=\"_date\"\r\n [(ngModel)]=\"_date\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"picker\"\r\n [min]=\"minDate\"\r\n [max]=\"maxDate\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <mat-datepicker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\">\r\n <mat-datepicker-actions>\r\n <div class=\"actions\">\r\n <div class=\"time-inputs time--inputs\">\r\n <input\r\n class=\"form-field__input time\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [id]=\"hours\"\r\n [value]=\"_hours\"\r\n [maxValue]=\"maxValueHours\"\r\n [(ngModel)]=\"hours\"\r\n />\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"minutes\"\r\n [(ngModel)]=\"minutes\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n\r\n <ng-container *ngIf=\"!hideSeconds\">\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"seconds\"\r\n [(ngModel)]=\"seconds\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n </ng-container>\r\n </div>\r\n\r\n <div class=\"grid-picker-actions\">\r\n <button type=\"button\" mat-stroked-button class=\"w-full\" color=\"primary\" matDatepickerCancel>\r\n {{ cancleLabel }}\r\n </button>\r\n\r\n <button\r\n type=\"button\"\r\n mat-button\r\n class=\"w-full ml-0\"\r\n color=\"primary\"\r\n matDatepickerApply\r\n (click)=\"onApply()\"\r\n >\r\n {{ applyLabel }}\r\n </button>\r\n </div>\r\n </div>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n <input\r\n class=\"form-field__input w-full date-input\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"pickerValue\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n appMaskDate\r\n [isDateTimeMask]=\"true\"\r\n [considerSeconds]=\"!hideSeconds\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <button type=\"button\" mat-icon-button class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n <mat-icon>calendar_today</mat-icon>\r\n </button>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: [".time--inputs:before,.time--inputs:after{position:absolute;content:\"\"}.datepicker-toggle{transform:translate(-1.25rem);left:-.125rem}.time{width:3.375rem}.fake-input{visibility:hidden;width:0;padding:0;margin:0}.date-input{margin:0rem -1.25rem 0rem .125rem}.time--inputs{position:relative;margin-top:2.4rem;margin-bottom:2.4rem}.time--inputs:before,.time--inputs:after{height:1px;right:0;left:0;background-color:var(--color-gray-300)}.time--inputs:before{top:-1.6rem}.time--inputs:after{bottom:-1.6rem}:host ::ng-deep .form-field{margin-right:-1.25rem;margin-left:-.125rem}.font-bold{font-weight:700}.actions{display:flex;flex-direction:column;width:100%!important;row-gap:1rem}.time-inputs{display:flex;gap:.5rem;justify-content:center;align-items:center}\n"] }]
|
|
186
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }
|
|
162
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }]; }, propDecorators: { minDate: [{
|
|
187
163
|
type: Input
|
|
188
164
|
}], maxDate: [{
|
|
189
165
|
type: Input
|
|
@@ -200,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
200
176
|
}], onblur: [{
|
|
201
177
|
type: Output
|
|
202
178
|
}] } });
|
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Injector, Input, Output } from '@angular/core';\r\nimport { format, isValid, parse, setHours, setMinutes, setSeconds } from 'date-fns';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport { EcabsDateTimePickerHeaderComponent } from './components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component';\r\n\r\n@Component( {\r\n  selector: 'ecabs-date-time-picker',\r\n  templateUrl: './ecabs-date-time-picker.component.html',\r\n  styleUrls: [ './ecabs-date-time-picker.component.scss' ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateTimePickerComponent,\r\n      multi: true,\r\n    },\r\n    DecimalPipe,\r\n  ],\r\n} )\r\nexport class EcabsDateTimePickerComponent extends ElementBaseComponent implements ControlValueAccessor, AfterViewInit {\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() hideSeconds = true;\r\n  @Input() cancleLabel = 'Cancel';\r\n  @Input() applyLabel = 'Apply';\r\n  @Input() selectDateLabel = 'Select date and time';\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  _hours = '12';\r\n  _minutes = '00';\r\n  _seconds = '00';\r\n  _date: Date;\r\n  _pickerValue: string;\r\n  val: Date;\r\n  header = EcabsDateTimePickerHeaderComponent;\r\n  maxValueHours = 23;\r\n  maxValueMinutesSeconds = 59;\r\n  preventCallSetterPickerValue = false;\r\n  runTimeout = false;\r\n\r\n  get value(): Date {\r\n    return this.val;\r\n  }\r\n\r\n  get pickerValue(): string {\r\n    return this._pickerValue;\r\n  }\r\n\r\n  get hours(): string {\r\n    return this._hours;\r\n  }\r\n\r\n  get minutes(): string {\r\n    return this._minutes;\r\n  }\r\n\r\n  get seconds(): string {\r\n    return this._seconds;\r\n  }\r\n\r\n  set hours( value: string ) {\r\n    if ( value !== undefined && this._hours !== value ) {\r\n      this._hours = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set minutes( value: string ) {\r\n    if ( value !== undefined && this._minutes !== value ) {\r\n      this._minutes = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set seconds( value: string ) {\r\n    if ( value !== undefined && this._seconds !== value ) {\r\n      this._seconds = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set value(val) {\r\n    if (val && this.val?.getTime() !== new Date(val).getTime()) {\r\n      if (!this.preventCallSetterPickerValue) {\r\n        this.pickerValue = this.formatDateTime(val);\r\n      }\r\n      this.preventCallSetterPickerValue = false;\r\n    }\r\n  }\r\n\r\n  set pickerValue(val: string) {\r\n    if (val) {\r\n      const date = parse(\r\n        val.replace('_', ''),\r\n        this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`,\r\n        new Date(),\r\n      );\r\n      if (isValid(date) && this._pickerValue !== val) {\r\n        if (this.minDate && date < this.minDate) {\r\n          this.setValues(this.minDate);\r\n          this._pickerValue = val;\r\n          this.preventCallSetterPickerValue = true;\r\n          this.value = this.minDate;\r\n          this.runTimeout = true;\r\n          this.refreshPickerValue(this.minDate);\r\n\r\n          return;\r\n        }\r\n\r\n        if (this.maxDate && date > this.maxDate) {\r\n          this.setValues(this.maxDate);\r\n          this._pickerValue = val;\r\n          this.preventCallSetterPickerValue = true;\r\n          this.value = this.maxDate;\r\n          this.runTimeout = true;\r\n          this.refreshPickerValue(this.maxDate);\r\n\r\n          return;\r\n        }\r\n\r\n        this.runTimeout = false;\r\n        this._pickerValue = val;\r\n        this.preventCallSetterPickerValue = true;\r\n        this.value = date;\r\n        this.setValues(date);\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor( private readonly injector: Injector, private readonly decimalPipe: DecimalPipe, private cd: ChangeDetectorRef) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null );\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n\r\n      setTimeout( () => {\r\n        const controlDate = !!this.control.value ? new Date( this.control.value ) : new Date();\r\n\r\n        if ( controlDate ) {\r\n          this.setValues( controlDate );\r\n        }\r\n      }, 10 );\r\n    }\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange( fn: any ): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched( fn: any ): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  blurChange( e: any ): void {\r\n    this.onblur.emit( e );\r\n  }\r\n\r\n  onApply(): void {\r\n    if (this._date && this._seconds && this._minutes && this._hours) {\r\n      const date = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);\r\n      this.value = date;\r\n    }\r\n  }\r\n\r\n  refreshPickerValue(date: Date): void {\r\n    setTimeout(() => {\r\n      if (this.runTimeout) {\r\n        this._pickerValue = this.formatDateTime(date);\r\n        this.cd.detectChanges();\r\n      }\r\n    }, 3000);\r\n  }\r\n\r\n  private formatDateTime( date: Date ): string {\r\n    let result = '';\r\n\r\n    if ( date && isValid( new Date( date ) ) ) {\r\n      result = this.hideSeconds\r\n        ? format( new Date( date ), `dd/MM/yyyy, HH:mm` )\r\n        : format( new Date( date ), `dd/MM/yyyy, HH:mm:ss` );\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  private roundNumber( num: number ): string | null {\r\n    return this.decimalPipe.transform( num, '2.0-0' ) ?? '00';\r\n  }\r\n\r\n  private setValues( date: Date ): void {\r\n    this.onChange(date);\r\n    this.onTouch(date);\r\n    this._date = date;\r\n    this.hours = date.getHours().toString();\r\n    this.minutes = date.getMinutes().toString();\r\n    this.seconds = date.getSeconds().toString();\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      class=\"fake-input\"\r\n      [id]=\"_date\"\r\n      [(ngModel)]=\"_date\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\">\r\n      <mat-datepicker-actions>\r\n        <div class=\"actions\">\r\n          <div class=\"time-inputs time--inputs\">\r\n            <input\r\n              class=\"form-field__input time\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [id]=\"hours\"\r\n              [value]=\"_hours\"\r\n              [maxValue]=\"maxValueHours\"\r\n              [(ngModel)]=\"hours\"\r\n            />\r\n            <span class=\"font-bold\">:</span>\r\n            <input\r\n              class=\"form-field__input time\"\r\n              [id]=\"minutes\"\r\n              [(ngModel)]=\"minutes\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [maxValue]=\"maxValueMinutesSeconds\"\r\n            />\r\n\r\n            <ng-container *ngIf=\"!hideSeconds\">\r\n              <span class=\"font-bold\">:</span>\r\n              <input\r\n                class=\"form-field__input time\"\r\n                [id]=\"seconds\"\r\n                [(ngModel)]=\"seconds\"\r\n                appDigitsOnly\r\n                appNumberBorder\r\n                [digitsOnly]=\"true\"\r\n                [maxValue]=\"maxValueMinutesSeconds\"\r\n              />\r\n            </ng-container>\r\n          </div>\r\n\r\n          <div class=\"grid-picker-actions\">\r\n            <button type=\"button\" mat-stroked-button class=\"w-full\" color=\"primary\" matDatepickerCancel>\r\n              {{ cancleLabel }}\r\n            </button>\r\n\r\n            <button\r\n              type=\"button\"\r\n              mat-button\r\n              class=\"w-full ml-0\"\r\n              color=\"primary\"\r\n              matDatepickerApply\r\n              (click)=\"onApply()\"\r\n            >\r\n            {{ applyLabel }}\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n    <input\r\n      class=\"form-field__input w-full date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"pickerValue\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      appMaskDate\r\n      [isDateTimeMask]=\"true\"\r\n      [considerSeconds]=\"!hideSeconds\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <button type=\"button\" mat-icon-button class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n      <mat-icon>calendar_today</mat-icon>\r\n    </button>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\r\nimport { AfterViewInit, Component, EventEmitter, Injector, Input, Output } from '@angular/core';\r\nimport { format, isValid, parse, setHours, setMinutes, setSeconds } from 'date-fns';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport { EcabsDateTimePickerHeaderComponent } from './components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component';\r\n\r\n@Component( {\r\n  selector: 'ecabs-date-time-picker',\r\n  templateUrl: './ecabs-date-time-picker.component.html',\r\n  styleUrls: [ './ecabs-date-time-picker.component.scss' ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateTimePickerComponent,\r\n      multi: true,\r\n    },\r\n    DecimalPipe,\r\n  ],\r\n} )\r\nexport class EcabsDateTimePickerComponent extends ElementBaseComponent implements ControlValueAccessor, AfterViewInit {\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() hideSeconds = true;\r\n  @Input() cancleLabel = 'Cancel';\r\n  @Input() applyLabel = 'Apply';\r\n  @Input() selectDateLabel = 'Select date and time';\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  _hours = '12';\r\n  _minutes = '00';\r\n  _seconds = '00';\r\n  _date: Date;\r\n  _pickerValue: string;\r\n  val: Date;\r\n  header = EcabsDateTimePickerHeaderComponent;\r\n  maxValueHours = 23;\r\n  maxValueMinutesSeconds = 59;\r\n\r\n  get value(): Date {\r\n    return this.val;\r\n  }\r\n\r\n  get pickerValue(): string {\r\n    return this._pickerValue;\r\n  }\r\n\r\n  get hours(): string {\r\n    return this._hours;\r\n  }\r\n\r\n  get minutes(): string {\r\n    return this._minutes;\r\n  }\r\n\r\n  get seconds(): string {\r\n    return this._seconds;\r\n  }\r\n\r\n  set hours( value: string ) {\r\n    if ( value !== undefined && this._hours !== value ) {\r\n      this._hours = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set minutes( value: string ) {\r\n    if ( value !== undefined && this._minutes !== value ) {\r\n      this._minutes = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set seconds( value: string ) {\r\n    if ( value !== undefined && this._seconds !== value ) {\r\n      this._seconds = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set value( val ) {\r\n    if ( val && this.val !== new Date( val ) ) {\r\n      this.val = new Date( val );\r\n      this.pickerValue = this.formatDateTime( val );\r\n      this.onChange( val );\r\n      this.onTouch( val );\r\n    }\r\n  }\r\n\r\n  set pickerValue( val: string ) {\r\n    if ( val ) {\r\n      const date = parse(\r\n        val.replace( '_', '' ),\r\n        this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`,\r\n        new Date()\r\n      );\r\n      if ( isValid( date ) && this._pickerValue !== val ) {\r\n        this._pickerValue = val;\r\n        this.value = date;\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor( private readonly injector: Injector, private readonly decimalPipe: DecimalPipe ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null );\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n\r\n      setTimeout( () => {\r\n        const controlDate = !!this.control.value ? new Date( this.control.value ) : new Date();\r\n\r\n        if ( controlDate ) {\r\n          this.setValues( controlDate );\r\n        }\r\n      }, 10 );\r\n    }\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange( fn: any ): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched( fn: any ): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  blurChange( e: any ): void {\r\n    this.onblur.emit( e );\r\n  }\r\n\r\n  onApply(): void {\r\n    if ( this._date && this._seconds && this._minutes && this._hours ) {\r\n      const date = setSeconds( setMinutes( setHours( new Date( this._date ), +this._hours ), +this._minutes ), +this._seconds );\r\n\r\n      if ( this.minDate && date < this.minDate ) {\r\n        this.setValues( this.minDate );\r\n        this.value = this.minDate;\r\n\r\n        return;\r\n      }\r\n\r\n      if ( this.maxDate && date > this.maxDate ) {\r\n        this.setValues( this.maxDate );\r\n        this.value = this.maxDate;\r\n\r\n        return;\r\n      }\r\n\r\n      this.value = date;\r\n    }\r\n  }\r\n\r\n  private formatDateTime( date: Date ): string {\r\n    let result = '';\r\n\r\n    if ( date && isValid( new Date( date ) ) ) {\r\n      result = this.hideSeconds\r\n        ? format( new Date( date ), `dd/MM/yyyy, HH:mm` )\r\n        : format( new Date( date ), `dd/MM/yyyy, HH:mm:ss` );\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  private roundNumber( num: number ): string | null {\r\n    return this.decimalPipe.transform( num, '2.0-0' ) ?? '00';\r\n  }\r\n\r\n  private setValues( date: Date ): void {\r\n    this._date = date;\r\n    this.hours = date.getHours().toString();\r\n    this.minutes = date.getMinutes().toString();\r\n    this.seconds = date.getSeconds().toString();\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      class=\"fake-input\"\r\n      [id]=\"_date\"\r\n      [(ngModel)]=\"_date\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\">\r\n      <mat-datepicker-actions>\r\n        <div class=\"actions\">\r\n          <div class=\"time-inputs time--inputs\">\r\n            <input\r\n              class=\"form-field__input time\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [id]=\"hours\"\r\n              [value]=\"_hours\"\r\n              [maxValue]=\"maxValueHours\"\r\n              [(ngModel)]=\"hours\"\r\n            />\r\n            <span class=\"font-bold\">:</span>\r\n            <input\r\n              class=\"form-field__input time\"\r\n              [id]=\"minutes\"\r\n              [(ngModel)]=\"minutes\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [maxValue]=\"maxValueMinutesSeconds\"\r\n            />\r\n\r\n            <ng-container *ngIf=\"!hideSeconds\">\r\n              <span class=\"font-bold\">:</span>\r\n              <input\r\n                class=\"form-field__input time\"\r\n                [id]=\"seconds\"\r\n                [(ngModel)]=\"seconds\"\r\n                appDigitsOnly\r\n                appNumberBorder\r\n                [digitsOnly]=\"true\"\r\n                [maxValue]=\"maxValueMinutesSeconds\"\r\n              />\r\n            </ng-container>\r\n          </div>\r\n\r\n          <div class=\"grid-picker-actions\">\r\n            <button type=\"button\" mat-stroked-button class=\"w-full\" color=\"primary\" matDatepickerCancel>\r\n              {{ cancleLabel }}\r\n            </button>\r\n\r\n            <button\r\n              type=\"button\"\r\n              mat-button\r\n              class=\"w-full ml-0\"\r\n              color=\"primary\"\r\n              matDatepickerApply\r\n              (click)=\"onApply()\"\r\n            >\r\n            {{ applyLabel }}\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n    <input\r\n      class=\"form-field__input w-full date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"pickerValue\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      appMaskDate\r\n      [isDateTimeMask]=\"true\"\r\n      [considerSeconds]=\"!hideSeconds\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <button type=\"button\" mat-icon-button class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n      <mat-icon>calendar_today</mat-icon>\r\n    </button>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
@@ -9,8 +9,10 @@ import * as i2 from "../base/element-wrapper/element-wrapper.component";
|
|
|
9
9
|
import * as i3 from "@angular/material/form-field";
|
|
10
10
|
import * as i4 from "@angular/material/select";
|
|
11
11
|
import * as i5 from "@angular/material/core";
|
|
12
|
-
import * as i6 from "@angular/
|
|
13
|
-
import * as i7 from "
|
|
12
|
+
import * as i6 from "@angular/material/tooltip";
|
|
13
|
+
import * as i7 from "@angular/forms";
|
|
14
|
+
import * as i8 from "ngx-mat-select-search";
|
|
15
|
+
import * as i9 from "../base/directives/tooltip-if-truncated.directive";
|
|
14
16
|
export class EcabsSelectComponent extends ElementBaseComponent {
|
|
15
17
|
constructor(injector, changeDetectorRef) {
|
|
16
18
|
super();
|
|
@@ -48,6 +50,16 @@ export class EcabsSelectComponent extends ElementBaseComponent {
|
|
|
48
50
|
get value() {
|
|
49
51
|
return this.val;
|
|
50
52
|
}
|
|
53
|
+
get trigger() {
|
|
54
|
+
if (this.getAllSelectedChecked()) {
|
|
55
|
+
return this.allLabel;
|
|
56
|
+
}
|
|
57
|
+
const firstChosenValue = this.val && this.multiple ? this.getLabel(this.val[0]) : this.getLabel(this.val);
|
|
58
|
+
return this.multiple && this.value?.length > 1
|
|
59
|
+
? `${firstChosenValue} (+${this.useSelectAllOption && this.allSelected?.selected ? this.value?.length - 2 : this.value?.length - 1}
|
|
60
|
+
${this.value?.length === 2 ? this.otherLabel : this.othersLabel})`
|
|
61
|
+
: firstChosenValue;
|
|
62
|
+
}
|
|
51
63
|
set value(val) {
|
|
52
64
|
if (this.val !== val) {
|
|
53
65
|
this.val = val;
|
|
@@ -258,7 +270,7 @@ EcabsSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", v
|
|
|
258
270
|
useExisting: EcabsSelectComponent,
|
|
259
271
|
multi: true,
|
|
260
272
|
},
|
|
261
|
-
], viewQueries: [{ propertyName: "allSelected", first: true, predicate: ["allSelected"], descendants: true }, { propertyName: "matSelectSearchComponent", first: true, predicate: MatSelectSearchComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <mat-form-field [ngClass]=\"{ disabled: useOnlyDisabledClass }\">\r\n <mat-select\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onSelectionChanged($event)\"\r\n
|
|
273
|
+
], viewQueries: [{ propertyName: "allSelected", first: true, predicate: ["allSelected"], descendants: true }, { propertyName: "matSelectSearchComponent", first: true, predicate: MatSelectSearchComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <mat-form-field [ngClass]=\"{ disabled: useOnlyDisabledClass }\">\r\n <mat-select\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onSelectionChanged($event)\"\r\n [matTooltip]=\"trigger\"\r\n appTooltipIfTruncated\r\n [classNameTruncatedTooltip]=\"'mat-select-value'\"\r\n >\r\n <mat-select-trigger>\r\n <span>{{ trigger }}</span>\r\n </mat-select-trigger>\r\n <mat-option *ngIf=\"useSearchOption\">\r\n <ngx-mat-select-search\r\n [formControl]=\"itemFilterCtrl\"\r\n [placeholderLabel]=\"searchFieldPlaceholder\"\r\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\r\n ></ngx-mat-select-search>\r\n </mat-option>\r\n <mat-option *ngIf=\"useNoneOption\" (click)=\"toggleNone()\">{{ noneLabel }}</mat-option>\r\n <mat-option #allSelected *ngIf=\"useSelectAllOption && showFilteredAllOption\" (click)=\"toggleAllSelection()\" [value]=\"selectAllValue\">{{\r\n allLabel\r\n }}</mat-option>\r\n <mat-option\r\n *ngFor=\"let item of filteredItems$ | async\"\r\n [value]=\"item.value\"\r\n (click)=\"togglePerOne()\"\r\n [matTooltip]=\"item.label\"\r\n appTooltipIfTruncated\r\n [classNameTruncatedTooltip]=\"'mat-option-text'\"\r\n >\r\n {{ item.label }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n</app-element-wrapper>\r\n", dependencies: [{ 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: "component", type: i2.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "indexAndLengthScreenReaderText", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toogleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i9.TooltipIfTruncatedDirective, selector: "[matTooltip][appTooltipIfTruncated]", inputs: ["classNameTruncatedTooltip"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
|
|
262
274
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EcabsSelectComponent, decorators: [{
|
|
263
275
|
type: Component,
|
|
264
276
|
args: [{ selector: 'ecabs-select', providers: [
|
|
@@ -267,7 +279,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
267
279
|
useExisting: EcabsSelectComponent,
|
|
268
280
|
multi: true,
|
|
269
281
|
},
|
|
270
|
-
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <mat-form-field [ngClass]=\"{ disabled: useOnlyDisabledClass }\">\r\n <mat-select\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onSelectionChanged($event)\"\r\n
|
|
282
|
+
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <mat-form-field [ngClass]=\"{ disabled: useOnlyDisabledClass }\">\r\n <mat-select\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onSelectionChanged($event)\"\r\n [matTooltip]=\"trigger\"\r\n appTooltipIfTruncated\r\n [classNameTruncatedTooltip]=\"'mat-select-value'\"\r\n >\r\n <mat-select-trigger>\r\n <span>{{ trigger }}</span>\r\n </mat-select-trigger>\r\n <mat-option *ngIf=\"useSearchOption\">\r\n <ngx-mat-select-search\r\n [formControl]=\"itemFilterCtrl\"\r\n [placeholderLabel]=\"searchFieldPlaceholder\"\r\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\r\n ></ngx-mat-select-search>\r\n </mat-option>\r\n <mat-option *ngIf=\"useNoneOption\" (click)=\"toggleNone()\">{{ noneLabel }}</mat-option>\r\n <mat-option #allSelected *ngIf=\"useSelectAllOption && showFilteredAllOption\" (click)=\"toggleAllSelection()\" [value]=\"selectAllValue\">{{\r\n allLabel\r\n }}</mat-option>\r\n <mat-option\r\n *ngFor=\"let item of filteredItems$ | async\"\r\n [value]=\"item.value\"\r\n (click)=\"togglePerOne()\"\r\n [matTooltip]=\"item.label\"\r\n appTooltipIfTruncated\r\n [classNameTruncatedTooltip]=\"'mat-option-text'\"\r\n >\r\n {{ item.label }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n</app-element-wrapper>\r\n" }]
|
|
271
283
|
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { items: [{
|
|
272
284
|
type: Input
|
|
273
285
|
}], multiple: [{
|
|
@@ -307,4 +319,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
307
319
|
type: ViewChild,
|
|
308
320
|
args: [MatSelectSearchComponent]
|
|
309
321
|
}] } });
|
|
310
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-select.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-select/ecabs-select.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-select/ecabs-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  UntypedFormControl,\r\n  NgControl,\r\n  NG_VALUE_ACCESSOR,\r\n} from '@angular/forms';\r\nimport {MatOption} from '@angular/material/core';\r\nimport {MatSelectSearchComponent} from 'ngx-mat-select-search';\r\nimport {\r\n  BehaviorSubject,\r\n  combineLatest,\r\n  debounceTime,\r\n  map,\r\n  Subscription,\r\n} from 'rxjs';\r\nimport ElementBaseComponent from '../base/element-base';\r\n\r\n@Component({\r\n  selector: 'ecabs-select',\r\n  templateUrl: './ecabs-select.component.html',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsSelectComponent,\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class EcabsSelectComponent\r\n  extends ElementBaseComponent\r\n  implements OnInit, OnChanges, AfterViewInit, OnDestroy {\r\n  @Input() items!: { label: string; value: any }[];\r\n  @Input() multiple = false;\r\n  @Input() useNoneOption: boolean = false;\r\n  @Input() useOnlyDisabledClass = false;\r\n  @Input() searchFieldPlaceholder: string = 'Search';\r\n  @Input() useSearchOption = false;\r\n  @Input() useSelectAllOption = false;\r\n  @Input() setAllOptionAfterChosenAllItems = true;\r\n  @Input() selectAllValue: any = 0;\r\n  @Input() noEntriesFoundLabel = 'No matching found';\r\n  @Input() noneLabel = 'None';\r\n  @Input() allLabel = 'All';\r\n  @Input() otherLabel = 'Other';\r\n  @Input() othersLabel = 'Others';\r\n  @Output() updateFilterItems: EventEmitter<string> =\r\n    new EventEmitter<string>();\r\n  @Output() selectionChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @ViewChild('allSelected') allSelected!: MatOption;\r\n  @ViewChild(MatSelectSearchComponent)\r\n  matSelectSearchComponent!: MatSelectSearchComponent;\r\n\r\n  val!: any;\r\n  filteredItems$: BehaviorSubject<{ label: string; value: any }[]> = new BehaviorSubject<\r\n    { label: string; value: any }[]\r\n  >([]);\r\n  itemFilterCtrl: UntypedFormControl = new UntypedFormControl();\r\n  isClearAll = false;\r\n  showFilteredAllOption = true;\r\n  selectedItems: { label: string; value: any }[] = [];\r\n  notSelectedItems: { label: string; value: any }[] = [];\r\n  subscriptions = new Subscription();\r\n\r\n  get value(): any {\r\n    return this.val;\r\n  }\r\n\r\n  set value(val) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.setSelectedItems();\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly changeDetectorRef: ChangeDetectorRef\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const {items} = changes;\r\n\r\n    if (items && items.currentValue) {\r\n      this.filterItems();\r\n\r\n      if (this.multiple && this.useSelectAllOption && this.allSelected?.selected) {\r\n        setTimeout(() => {\r\n          this.control.patchValue([...this.filteredItems$.value.map((item) => item.value), this.selectAllValue], {\r\n            emitEvent: false,\r\n          });\r\n        }, 100);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(\r\n      NgControl,\r\n      null\r\n    ) as NgControl;\r\n\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n\r\n    if (this.matSelectSearchComponent) {\r\n      this.matSelectSearchComponent._showNoEntriesFound$ = combineLatest([\r\n        this.itemFilterCtrl.valueChanges,\r\n        this.filteredItems$,\r\n      ]).pipe(\r\n        map(\r\n          ([value, items]) =>\r\n            this.matSelectSearchComponent.noEntriesFoundLabel &&\r\n            value &&\r\n            items.length === 0\r\n        )\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.subscriptions.add(\r\n      this.itemFilterCtrl.valueChanges\r\n        .pipe(debounceTime(200))\r\n        .subscribe((value: any) => {\r\n          this.filterItems();\r\n          this.updateFilterItems.emit(value);\r\n\r\n          if (this.isClearAll) {\r\n            this.control.patchValue([], {emitEvent: false});\r\n            this.isClearAll = false;\r\n          }\r\n        })\r\n    );\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\r\n  onChange: any = () => {\r\n  };\r\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\r\n  onTouch: any = () => {\r\n  };\r\n\r\n  toggleAllSelection(): void {\r\n    if (this.allSelected.selected) {\r\n      if (this.useSearchOption) {\r\n        this.control.patchValue([...this.filteredItems$.value.map((item) => item.value), this.selectAllValue]);\r\n      } else {\r\n        this.control.patchValue([...this.items.map((item) => item.value), this.selectAllValue]);\r\n      }\r\n    } else {\r\n      this.control.patchValue([]);\r\n      this.isClearAll = true;\r\n    }\r\n  }\r\n\r\n  togglePerOne(): void {\r\n    setTimeout(() => {\r\n      if (this.allSelected) {\r\n        if (this.allSelected.selected) {\r\n          this.allSelected.deselect();\r\n        }\r\n        if (this.setAllOptionAfterChosenAllItems && this.control.value.length === this.items.length) {\r\n          this.allSelected.select();\r\n        }\r\n      }\r\n    });\r\n\r\n    this.isClearAll = false;\r\n  }\r\n\r\n  toggleNone(): void {\r\n    this.selectedItems = [];\r\n  }\r\n\r\n  getAllSelectedChecked(): boolean {\r\n    return this.allSelected !== undefined && this.allSelected.selected;\r\n  }\r\n\r\n  getLabel(val: any): string {\r\n    if (this.useSelectAllOption && this.allSelected?.selected && this.items && this.items.length > 0) {\r\n      return this.items[0].label;\r\n    }\r\n\r\n    let item: { label: string; value: any };\r\n\r\n    if (val !== undefined) {\r\n      if (this.useSearchOption) {\r\n        if (this.selectedItems && this.selectedItems.length > 0) {\r\n          // eslint-disable-next-line @typescript-eslint/no-shadow\r\n          item = this.selectedItems.find((item) => item.value === val);\r\n        }\r\n      } else {\r\n        if (this.items && this.items.length > 0) {\r\n          // eslint-disable-next-line @typescript-eslint/no-shadow\r\n          item = this.items.find((item) => item.value === val);\r\n        }\r\n      }\r\n\r\n      return item ? item.label : '';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n  onSelectionChanged($event: any): void {\r\n    this.selectionChange.emit($event);\r\n  }\r\n\r\n  private filterItems(): void {\r\n    this.setSelectedItems();\r\n\r\n    if (!this.items) {\r\n      return;\r\n    }\r\n\r\n    // get the search keyword\r\n    let search: string = this.itemFilterCtrl.value;\r\n\r\n    if (!search || search === '') {\r\n      if (this.useSearchOption && !this.items?.length) {\r\n        this.filteredItems$.next([...this.selectedItems]);\r\n      } else {\r\n        this.filteredItems$.next(this.items?.slice());\r\n      }\r\n\r\n      this.showFilteredAllOption = true;\r\n\r\n      return;\r\n    }\r\n\r\n    search = search.toLowerCase();\r\n\r\n    this.showFilteredAllOption =\r\n      this.allLabel.toLowerCase().includes(search.toLowerCase()) ||\r\n      (this.value instanceof Array && this.value.includes(this.selectAllValue)) ||\r\n      (!(this.value instanceof Array) && this.value === this.selectAllValue);\r\n    this.changeDetectorRef.detectChanges();\r\n\r\n    if (this.useSearchOption) {\r\n      const filteredItems =\r\n        this.notSelectedItems?.length > 0\r\n          ? this.notSelectedItems.filter((item) => item.label.toLowerCase().includes(search.toLowerCase()))\r\n          : [];\r\n      this.filteredItems$.next([...this.selectedItems, ...filteredItems]);\r\n    } else {\r\n      this.filteredItems$.next(\r\n        this.items?.length > 0\r\n          ? this.items.filter((item) => item.label.toLowerCase().includes(search.toLowerCase()))\r\n          : []\r\n      );\r\n    }\r\n  }\r\n\r\n  private setSelectedItems(): void {\r\n    if (this.useSearchOption) {\r\n      const selectedItems = [];\r\n\r\n      if (this.value) {\r\n        if (this.value instanceof Array) {\r\n          const skipSteps = this.value.includes(this.selectAllValue);\r\n\r\n          if (!skipSteps) {\r\n            this.value.forEach((value) => {\r\n              const index = this.selectedItems.findIndex((selectedItem) => selectedItem.value === value);\r\n\r\n              if (index !== -1) {\r\n                selectedItems.push(this.selectedItems[index]);\r\n              } else {\r\n                // eslint-disable-next-line @typescript-eslint/no-shadow\r\n                const item = this.items.find((item) => item.value === value);\r\n\r\n                if (item) {\r\n                  selectedItems.push(item);\r\n                }\r\n              }\r\n            });\r\n\r\n            this.selectedItems.forEach((selectedItem) => {\r\n              const index = this.value.find((value) => selectedItem.value === value);\r\n\r\n              if (index === -1) {\r\n                selectedItems.splice(index, 1);\r\n              }\r\n            });\r\n          }\r\n        } else {\r\n          const index = this.selectedItems.findIndex((selectedItem) => selectedItem.value === this.value);\r\n\r\n          if (index !== -1) {\r\n            selectedItems.push(this.selectedItems[index]);\r\n          } else {\r\n            // eslint-disable-next-line @typescript-eslint/no-shadow\r\n            const item = this.items.find((item) => item.value === this.value);\r\n\r\n            // eslint-disable-next-line max-depth\r\n            if (item) {\r\n              selectedItems.push(item);\r\n            }\r\n          }\r\n        }\r\n\r\n        this.selectedItems = [...selectedItems];\r\n        this.notSelectedItems = this.items?.filter(\r\n          (item) => this.selectedItems.findIndex((selectedItem) => selectedItem.value === item.value) === -1\r\n        );\r\n      } else {\r\n        this.notSelectedItems = this.items?.slice();\r\n      }\r\n    }\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <mat-form-field [ngClass]=\"{ disabled: useOnlyDisabledClass }\">\r\n    <mat-select\r\n      [(ngModel)]=\"value\"\r\n      (closed)=\"onTouch()\"\r\n      appearance=\"outline\"\r\n      [multiple]=\"multiple\"\r\n      [disabled]=\"disabled\"\r\n      [placeholder]=\"placeholder\"\r\n      (selectionChange)=\"onSelectionChanged($event)\"\r\n    >\r\n      <mat-select-trigger>\r\n        <span *ngIf=\"getAllSelectedChecked()\">{{ allLabel }}</span>\r\n        <span *ngIf=\"!getAllSelectedChecked()\"\r\n          >{{ val && multiple ? getLabel(val[0]) : getLabel(val) }}\r\n          <span *ngIf=\"multiple && value?.length > 1\" class=\"additional-selection\">\r\n            (+{{ useSelectAllOption && this.allSelected?.selected ? value?.length - 2 : value?.length - 1 }}\r\n            {{ (value?.length === 2 ? otherLabel : othersLabel) }})\r\n          </span>\r\n        </span>\r\n      </mat-select-trigger>\r\n      <mat-option *ngIf=\"useSearchOption\">\r\n        <ngx-mat-select-search\r\n        [formControl]=\"itemFilterCtrl\"\r\n          [placeholderLabel]=\"searchFieldPlaceholder\"\r\n          [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\r\n        ></ngx-mat-select-search>\r\n      </mat-option>\r\n      <mat-option *ngIf=\"useNoneOption\" (click)=\"toggleNone()\">{{ noneLabel }}</mat-option>\r\n      <mat-option #allSelected *ngIf=\"useSelectAllOption && showFilteredAllOption\" (click)=\"toggleAllSelection()\" [value]=\"selectAllValue\">{{\r\n        allLabel\r\n      }}</mat-option>\r\n      <mat-option *ngFor=\"let item of filteredItems$ | async\" [value]=\"item.value\" (click)=\"togglePerOne()\">\r\n        {{ item.label }}\r\n      </mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n</app-element-wrapper>\r\n"]}
|
|
322
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-select.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-select/ecabs-select.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-select/ecabs-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  UntypedFormControl,\r\n  NgControl,\r\n  NG_VALUE_ACCESSOR,\r\n} from '@angular/forms';\r\nimport { MatOption } from '@angular/material/core';\r\nimport { MatSelectSearchComponent } from 'ngx-mat-select-search';\r\nimport {\r\n  BehaviorSubject,\r\n  combineLatest,\r\n  debounceTime,\r\n  map,\r\n  Subscription,\r\n} from 'rxjs';\r\nimport ElementBaseComponent from '../base/element-base';\r\n\r\n@Component( {\r\n  selector: 'ecabs-select',\r\n  templateUrl: './ecabs-select.component.html',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsSelectComponent,\r\n      multi: true,\r\n    },\r\n  ],\r\n} )\r\nexport class EcabsSelectComponent\r\n  extends ElementBaseComponent\r\n  implements OnInit, OnChanges, AfterViewInit, OnDestroy {\r\n  @Input() items!: { label: string; value: any }[];\r\n  @Input() multiple = false;\r\n  @Input() useNoneOption: boolean = false;\r\n  @Input() useOnlyDisabledClass = false;\r\n  @Input() searchFieldPlaceholder: string = 'Search';\r\n  @Input() useSearchOption = false;\r\n  @Input() useSelectAllOption = false;\r\n  @Input() setAllOptionAfterChosenAllItems = true;\r\n  @Input() selectAllValue: any = 0;\r\n  @Input() noEntriesFoundLabel = 'No matching found';\r\n  @Input() noneLabel = 'None';\r\n  @Input() allLabel = 'All';\r\n  @Input() otherLabel = 'Other';\r\n  @Input() othersLabel = 'Others';\r\n  @Output() updateFilterItems: EventEmitter<string> =\r\n    new EventEmitter<string>();\r\n  @Output() selectionChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @ViewChild( 'allSelected' ) allSelected!: MatOption;\r\n  @ViewChild( MatSelectSearchComponent )\r\n  matSelectSearchComponent!: MatSelectSearchComponent;\r\n\r\n  val!: any;\r\n  filteredItems$: BehaviorSubject<{ label: string; value: any }[]> = new BehaviorSubject<\r\n    { label: string; value: any }[]\r\n  >( [] );\r\n  itemFilterCtrl: UntypedFormControl = new UntypedFormControl();\r\n  isClearAll = false;\r\n  showFilteredAllOption = true;\r\n  selectedItems: { label: string; value: any }[] = [];\r\n  notSelectedItems: { label: string; value: any }[] = [];\r\n  subscriptions = new Subscription();\r\n\r\n  get value(): any {\r\n    return this.val;\r\n  }\r\n\r\n  get trigger(): string {\r\n    if ( this.getAllSelectedChecked() ) {\r\n      return this.allLabel;\r\n    }\r\n    const firstChosenValue = this.val && this.multiple ? this.getLabel( this.val[ 0 ] ) : this.getLabel( this.val );\r\n\r\n    return this.multiple && this.value?.length > 1\r\n      ? `${ firstChosenValue } (+${ this.useSelectAllOption && this.allSelected?.selected ? this.value?.length - 2 : this.value?.length - 1\r\n      }\r\n          ${ this.value?.length === 2 ? this.otherLabel : this.othersLabel })`\r\n      : firstChosenValue;\r\n  }\r\n\r\n  set value( val ) {\r\n    if ( this.val !== val ) {\r\n      this.val = val;\r\n      this.setSelectedItems();\r\n      this.onChange( val );\r\n      this.onTouch( val );\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly changeDetectorRef: ChangeDetectorRef\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges( changes: SimpleChanges ): void {\r\n    const { items } = changes;\r\n\r\n    if ( items && items.currentValue ) {\r\n      this.filterItems();\r\n\r\n      if ( this.multiple && this.useSelectAllOption && this.allSelected?.selected ) {\r\n        setTimeout( () => {\r\n          this.control.patchValue( [ ...this.filteredItems$.value.map( ( item ) => item.value ), this.selectAllValue ], {\r\n            emitEvent: false,\r\n          } );\r\n        }, 100 );\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(\r\n      NgControl,\r\n      null\r\n    ) as NgControl;\r\n\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n\r\n    if ( this.matSelectSearchComponent ) {\r\n      this.matSelectSearchComponent._showNoEntriesFound$ = combineLatest( [\r\n        this.itemFilterCtrl.valueChanges,\r\n        this.filteredItems$,\r\n      ] ).pipe(\r\n        map(\r\n          ( [ value, items ] ) =>\r\n            this.matSelectSearchComponent.noEntriesFoundLabel &&\r\n            value &&\r\n            items.length === 0\r\n        )\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.subscriptions.add(\r\n      this.itemFilterCtrl.valueChanges\r\n        .pipe( debounceTime( 200 ) )\r\n        .subscribe( ( value: any ) => {\r\n          this.filterItems();\r\n          this.updateFilterItems.emit( value );\r\n\r\n          if ( this.isClearAll ) {\r\n            this.control.patchValue( [], { emitEvent: false } );\r\n            this.isClearAll = false;\r\n          }\r\n        } )\r\n    );\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\r\n  onChange: any = () => {\r\n  };\r\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\r\n  onTouch: any = () => {\r\n  };\r\n\r\n  toggleAllSelection(): void {\r\n    if ( this.allSelected.selected ) {\r\n      if ( this.useSearchOption ) {\r\n        this.control.patchValue( [ ...this.filteredItems$.value.map( ( item ) => item.value ), this.selectAllValue ] );\r\n      } else {\r\n        this.control.patchValue( [ ...this.items.map( ( item ) => item.value ), this.selectAllValue ] );\r\n      }\r\n    } else {\r\n      this.control.patchValue( [] );\r\n      this.isClearAll = true;\r\n    }\r\n  }\r\n\r\n  togglePerOne(): void {\r\n    setTimeout( () => {\r\n      if ( this.allSelected ) {\r\n        if ( this.allSelected.selected ) {\r\n          this.allSelected.deselect();\r\n        }\r\n        if ( this.setAllOptionAfterChosenAllItems && this.control.value.length === this.items.length ) {\r\n          this.allSelected.select();\r\n        }\r\n      }\r\n    } );\r\n\r\n    this.isClearAll = false;\r\n  }\r\n\r\n  toggleNone(): void {\r\n    this.selectedItems = [];\r\n  }\r\n\r\n  getAllSelectedChecked(): boolean {\r\n    return this.allSelected !== undefined && this.allSelected.selected;\r\n  }\r\n\r\n  getLabel( val: any ): string {\r\n    if ( this.useSelectAllOption && this.allSelected?.selected && this.items && this.items.length > 0 ) {\r\n      return this.items[ 0 ].label;\r\n    }\r\n\r\n    let item: { label: string; value: any };\r\n\r\n    if ( val !== undefined ) {\r\n      if ( this.useSearchOption ) {\r\n        if ( this.selectedItems && this.selectedItems.length > 0 ) {\r\n          // eslint-disable-next-line @typescript-eslint/no-shadow\r\n          item = this.selectedItems.find( ( item ) => item.value === val );\r\n        }\r\n      } else {\r\n        if ( this.items && this.items.length > 0 ) {\r\n          // eslint-disable-next-line @typescript-eslint/no-shadow\r\n          item = this.items.find( ( item ) => item.value === val );\r\n        }\r\n      }\r\n\r\n      return item ? item.label : '';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange( fn: any ): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched( fn: any ): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n  onSelectionChanged( $event: any ): void {\r\n    this.selectionChange.emit( $event );\r\n  }\r\n\r\n  private filterItems(): void {\r\n    this.setSelectedItems();\r\n\r\n    if ( !this.items ) {\r\n      return;\r\n    }\r\n\r\n    // get the search keyword\r\n    let search: string = this.itemFilterCtrl.value;\r\n\r\n    if ( !search || search === '' ) {\r\n      if ( this.useSearchOption && !this.items?.length ) {\r\n        this.filteredItems$.next( [ ...this.selectedItems ] );\r\n      } else {\r\n        this.filteredItems$.next( this.items?.slice() );\r\n      }\r\n\r\n      this.showFilteredAllOption = true;\r\n\r\n      return;\r\n    }\r\n\r\n    search = search.toLowerCase();\r\n\r\n    this.showFilteredAllOption =\r\n      this.allLabel.toLowerCase().includes( search.toLowerCase() ) ||\r\n      ( this.value instanceof Array && this.value.includes( this.selectAllValue ) ) ||\r\n      ( !( this.value instanceof Array ) && this.value === this.selectAllValue );\r\n    this.changeDetectorRef.detectChanges();\r\n\r\n    if ( this.useSearchOption ) {\r\n      const filteredItems =\r\n        this.notSelectedItems?.length > 0\r\n          ? this.notSelectedItems.filter( ( item ) => item.label.toLowerCase().includes( search.toLowerCase() ) )\r\n          : [];\r\n      this.filteredItems$.next( [ ...this.selectedItems, ...filteredItems ] );\r\n    } else {\r\n      this.filteredItems$.next(\r\n        this.items?.length > 0\r\n          ? this.items.filter( ( item ) => item.label.toLowerCase().includes( search.toLowerCase() ) )\r\n          : []\r\n      );\r\n    }\r\n  }\r\n\r\n  private setSelectedItems(): void {\r\n    if ( this.useSearchOption ) {\r\n      const selectedItems = [];\r\n\r\n      if ( this.value ) {\r\n        if ( this.value instanceof Array ) {\r\n          const skipSteps = this.value.includes( this.selectAllValue );\r\n\r\n          if ( !skipSteps ) {\r\n            this.value.forEach( ( value ) => {\r\n              const index = this.selectedItems.findIndex( ( selectedItem ) => selectedItem.value === value );\r\n\r\n              if ( index !== -1 ) {\r\n                selectedItems.push( this.selectedItems[ index ] );\r\n              } else {\r\n                // eslint-disable-next-line @typescript-eslint/no-shadow\r\n                const item = this.items.find( ( item ) => item.value === value );\r\n\r\n                if ( item ) {\r\n                  selectedItems.push( item );\r\n                }\r\n              }\r\n            } );\r\n\r\n            this.selectedItems.forEach( ( selectedItem ) => {\r\n              const index = this.value.find( ( value ) => selectedItem.value === value );\r\n\r\n              if ( index === -1 ) {\r\n                selectedItems.splice( index, 1 );\r\n              }\r\n            } );\r\n          }\r\n        } else {\r\n          const index = this.selectedItems.findIndex( ( selectedItem ) => selectedItem.value === this.value );\r\n\r\n          if ( index !== -1 ) {\r\n            selectedItems.push( this.selectedItems[ index ] );\r\n          } else {\r\n            // eslint-disable-next-line @typescript-eslint/no-shadow\r\n            const item = this.items.find( ( item ) => item.value === this.value );\r\n\r\n            // eslint-disable-next-line max-depth\r\n            if ( item ) {\r\n              selectedItems.push( item );\r\n            }\r\n          }\r\n        }\r\n\r\n        this.selectedItems = [ ...selectedItems ];\r\n        this.notSelectedItems = this.items?.filter(\r\n          ( item ) => this.selectedItems.findIndex( ( selectedItem ) => selectedItem.value === item.value ) === -1\r\n        );\r\n      } else {\r\n        this.notSelectedItems = this.items?.slice();\r\n      }\r\n    }\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <mat-form-field [ngClass]=\"{ disabled: useOnlyDisabledClass }\">\r\n    <mat-select\r\n      [(ngModel)]=\"value\"\r\n      (closed)=\"onTouch()\"\r\n      appearance=\"outline\"\r\n      [multiple]=\"multiple\"\r\n      [disabled]=\"disabled\"\r\n      [placeholder]=\"placeholder\"\r\n      (selectionChange)=\"onSelectionChanged($event)\"\r\n      [matTooltip]=\"trigger\"\r\n      appTooltipIfTruncated\r\n      [classNameTruncatedTooltip]=\"'mat-select-value'\"\r\n    >\r\n      <mat-select-trigger>\r\n        <span>{{ trigger }}</span>\r\n      </mat-select-trigger>\r\n      <mat-option *ngIf=\"useSearchOption\">\r\n        <ngx-mat-select-search\r\n          [formControl]=\"itemFilterCtrl\"\r\n          [placeholderLabel]=\"searchFieldPlaceholder\"\r\n          [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\r\n        ></ngx-mat-select-search>\r\n      </mat-option>\r\n      <mat-option *ngIf=\"useNoneOption\" (click)=\"toggleNone()\">{{ noneLabel }}</mat-option>\r\n      <mat-option #allSelected *ngIf=\"useSelectAllOption && showFilteredAllOption\" (click)=\"toggleAllSelection()\" [value]=\"selectAllValue\">{{\r\n        allLabel\r\n      }}</mat-option>\r\n      <mat-option\r\n        *ngFor=\"let item of filteredItems$ | async\"\r\n        [value]=\"item.value\"\r\n        (click)=\"togglePerOne()\"\r\n        [matTooltip]=\"item.label\"\r\n        appTooltipIfTruncated\r\n        [classNameTruncatedTooltip]=\"'mat-option-text'\"\r\n      >\r\n        {{ item.label }}\r\n      </mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n</app-element-wrapper>\r\n"]}
|
|
@@ -1,12 +1,14 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
4
|
-
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
|
-
import { EcabsSelectComponent } from './ecabs-select.component';
|
|
6
1
|
import { NgxMatSelectSearchModule } from 'ngx-mat-select-search';
|
|
7
|
-
import { MAT_SELECT_SCROLL_STRATEGY, MatSelectModule, } from '@angular/material/select';
|
|
8
2
|
import { Overlay } from '@angular/cdk/overlay';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { NgModule } from '@angular/core';
|
|
5
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
9
6
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
7
|
+
import { MAT_SELECT_SCROLL_STRATEGY, MatSelectModule } from '@angular/material/select';
|
|
8
|
+
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
9
|
+
import { EcabsSelectComponent } from './ecabs-select.component';
|
|
10
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
11
|
+
import { TooltipIfTruncatedDirectiveModule } from '../base/directives/tooltip-if-truncated.directive.module';
|
|
10
12
|
import * as i0 from "@angular/core";
|
|
11
13
|
export class EcabsSelectModule {
|
|
12
14
|
}
|
|
@@ -15,9 +17,11 @@ EcabsSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", versi
|
|
|
15
17
|
ElementWrapperModule,
|
|
16
18
|
MatSelectModule,
|
|
17
19
|
MatFormFieldModule,
|
|
20
|
+
MatTooltipModule,
|
|
18
21
|
FormsModule,
|
|
19
22
|
NgxMatSelectSearchModule,
|
|
20
|
-
ReactiveFormsModule
|
|
23
|
+
ReactiveFormsModule,
|
|
24
|
+
TooltipIfTruncatedDirectiveModule], exports: [EcabsSelectComponent] });
|
|
21
25
|
EcabsSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EcabsSelectModule, providers: [
|
|
22
26
|
{
|
|
23
27
|
provide: MAT_SELECT_SCROLL_STRATEGY,
|
|
@@ -28,9 +32,11 @@ EcabsSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versi
|
|
|
28
32
|
ElementWrapperModule,
|
|
29
33
|
MatSelectModule,
|
|
30
34
|
MatFormFieldModule,
|
|
35
|
+
MatTooltipModule,
|
|
31
36
|
FormsModule,
|
|
32
37
|
NgxMatSelectSearchModule,
|
|
33
|
-
ReactiveFormsModule
|
|
38
|
+
ReactiveFormsModule,
|
|
39
|
+
TooltipIfTruncatedDirectiveModule] });
|
|
34
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EcabsSelectModule, decorators: [{
|
|
35
41
|
type: NgModule,
|
|
36
42
|
args: [{
|
|
@@ -40,9 +46,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
40
46
|
ElementWrapperModule,
|
|
41
47
|
MatSelectModule,
|
|
42
48
|
MatFormFieldModule,
|
|
49
|
+
MatTooltipModule,
|
|
43
50
|
FormsModule,
|
|
44
51
|
NgxMatSelectSearchModule,
|
|
45
|
-
ReactiveFormsModule
|
|
52
|
+
ReactiveFormsModule,
|
|
53
|
+
TooltipIfTruncatedDirectiveModule
|
|
46
54
|
],
|
|
47
55
|
exports: [EcabsSelectComponent],
|
|
48
56
|
providers: [
|
|
@@ -57,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
57
65
|
export function scrollFactory(overlay) {
|
|
58
66
|
return () => overlay.scrollStrategies.block();
|
|
59
67
|
}
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtc2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1zZWxlY3QvZWNhYnMtc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVqRSxPQUFPLEVBQXVCLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFdkYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDdEYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sMERBQTBELENBQUM7O0FBd0I3RyxNQUFNLE9BQU8saUJBQWlCOzs4R0FBakIsaUJBQWlCOytHQUFqQixpQkFBaUIsaUJBckJaLG9CQUFvQixhQUVsQyxZQUFZO1FBQ1osb0JBQW9CO1FBQ3BCLGVBQWU7UUFDZixrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLFdBQVc7UUFDWCx3QkFBd0I7UUFDeEIsbUJBQW1CO1FBQ25CLGlDQUFpQyxhQUV4QixvQkFBb0I7K0dBU3BCLGlCQUFpQixhQVJqQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLDBCQUEwQjtZQUNuQyxVQUFVLEVBQUUsYUFBYTtZQUN6QixJQUFJLEVBQUUsQ0FBRSxPQUFPLENBQUU7U0FDbEI7S0FDRixZQWpCQyxZQUFZO1FBQ1osb0JBQW9CO1FBQ3BCLGVBQWU7UUFDZixrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLFdBQVc7UUFDWCx3QkFBd0I7UUFDeEIsbUJBQW1CO1FBQ25CLGlDQUFpQzsyRkFXeEIsaUJBQWlCO2tCQXRCN0IsUUFBUTttQkFBRTtvQkFDVCxZQUFZLEVBQUUsQ0FBRSxvQkFBb0IsQ0FBRTtvQkFDdEMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixlQUFlO3dCQUNmLGtCQUFrQjt3QkFDbEIsZ0JBQWdCO3dCQUNoQixXQUFXO3dCQUNYLHdCQUF3Qjt3QkFDeEIsbUJBQW1CO3dCQUNuQixpQ0FBaUM7cUJBQ2xDO29CQUNELE9BQU8sRUFBRSxDQUFFLG9CQUFvQixDQUFFO29CQUNqQyxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLDBCQUEwQjs0QkFDbkMsVUFBVSxFQUFFLGFBQWE7NEJBQ3pCLElBQUksRUFBRSxDQUFFLE9BQU8sQ0FBRTt5QkFDbEI7cUJBQ0Y7aUJBQ0Y7O0FBRUQsTUFBTSxVQUFVLGFBQWEsQ0FBRSxPQUFnQjtJQUM3QyxPQUFPLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUNoRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmd4TWF0U2VsZWN0U2VhcmNoTW9kdWxlIH0gZnJvbSAnbmd4LW1hdC1zZWxlY3Qtc2VhcmNoJztcclxuXHJcbmltcG9ydCB7IEJsb2NrU2Nyb2xsU3RyYXRlZ3ksIE92ZXJsYXkgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgTUFUX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1ksIE1hdFNlbGVjdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XHJcblxyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic1NlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtc2VsZWN0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcclxuaW1wb3J0IHsgVG9vbHRpcElmVHJ1bmNhdGVkRGlyZWN0aXZlTW9kdWxlIH0gZnJvbSAnLi4vYmFzZS9kaXJlY3RpdmVzL3Rvb2x0aXAtaWYtdHJ1bmNhdGVkLmRpcmVjdGl2ZS5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKCB7XHJcbiAgZGVjbGFyYXRpb25zOiBbIEVjYWJzU2VsZWN0Q29tcG9uZW50IF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRWxlbWVudFdyYXBwZXJNb2R1bGUsXHJcbiAgICBNYXRTZWxlY3RNb2R1bGUsXHJcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXHJcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBOZ3hNYXRTZWxlY3RTZWFyY2hNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgVG9vbHRpcElmVHJ1bmNhdGVkRGlyZWN0aXZlTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbIEVjYWJzU2VsZWN0Q29tcG9uZW50IF0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE1BVF9TRUxFQ1RfU0NST0xMX1NUUkFURUdZLFxyXG4gICAgICB1c2VGYWN0b3J5OiBzY3JvbGxGYWN0b3J5LFxyXG4gICAgICBkZXBzOiBbIE92ZXJsYXkgXSxcclxuICAgIH0sXHJcbiAgXSxcclxufSApXHJcbmV4cG9ydCBjbGFzcyBFY2Fic1NlbGVjdE1vZHVsZSB7IH1cclxuZXhwb3J0IGZ1bmN0aW9uIHNjcm9sbEZhY3RvcnkoIG92ZXJsYXk6IE92ZXJsYXkgKTogKCkgPT4gQmxvY2tTY3JvbGxTdHJhdGVneSB7XHJcbiAgcmV0dXJuICgpID0+IG92ZXJsYXkuc2Nyb2xsU3RyYXRlZ2llcy5ibG9jaygpO1xyXG59XHJcbiJdfQ==
|