ecabs-components 1.0.29 → 1.0.30

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,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
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TooltipIfTruncatedDirective, deps: [{ token: i1.MatTooltip }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
16
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TooltipIfTruncatedDirective, selector: "[matTooltip][appTooltipIfTruncated]", inputs: { classNameTruncatedTooltip: "classNameTruncatedTooltip" }, host: { listeners: { "mouseover": "onMouseOver()" } }, ngImport: i0 }); }
17
+ }
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1pZi10cnVuY2F0ZWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvZGlyZWN0aXZlcy90b29sdGlwLWlmLXRydW5jYXRlZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFNM0UsTUFBTSxPQUFPLDJCQUEyQjtJQUd0QyxZQUE4QixVQUFzQixFQUFtQixVQUFtQztRQUE1RSxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQW1CLGVBQVUsR0FBVixVQUFVLENBQXlCO0lBQUssQ0FBQztJQUdoSCxXQUFXO1FBQ1QsTUFBTSxPQUFPLEdBQ1gsSUFBSSxDQUFDLHlCQUF5QixFQUFFLE1BQU0sR0FBRyxDQUFDO1lBQ3hDLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBRSxJQUFJLENBQUMseUJBQXlCLENBQUUsQ0FBRSxDQUFDLENBQUU7WUFDN0YsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO1FBQ3BDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxHQUFHLE9BQU8sRUFBRSxXQUFXLElBQUksT0FBTyxFQUFFLFdBQVcsQ0FBQztJQUMxRSxDQUFDOytHQVpVLDJCQUEyQjttR0FBM0IsMkJBQTJCOzs0RkFBM0IsMkJBQTJCO2tCQUh2QyxTQUFTO21CQUFFO29CQUNWLFFBQVEsRUFBRSxxQ0FBcUM7aUJBQ2hEOzBIQUVVLHlCQUF5QjtzQkFBakMsS0FBSztnQkFLTixXQUFXO3NCQURWLFlBQVk7dUJBQUUsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXAgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcFwiO1xyXG5cclxuQERpcmVjdGl2ZSgge1xyXG4gIHNlbGVjdG9yOiAnW21hdFRvb2x0aXBdW2FwcFRvb2x0aXBJZlRydW5jYXRlZF0nLFxyXG59IClcclxuZXhwb3J0IGNsYXNzIFRvb2x0aXBJZlRydW5jYXRlZERpcmVjdGl2ZSB7XHJcbiAgQElucHV0KCkgY2xhc3NOYW1lVHJ1bmNhdGVkVG9vbHRpcDogc3RyaW5nO1xyXG5cclxuICBjb25zdHJ1Y3RvciggcHJpdmF0ZSByZWFkb25seSBtYXRUb29sdGlwOiBNYXRUb29sdGlwLCBwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+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
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TooltipIfTruncatedDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: TooltipIfTruncatedDirectiveModule, declarations: [TooltipIfTruncatedDirective], imports: [CommonModule], exports: [TooltipIfTruncatedDirective] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TooltipIfTruncatedDirectiveModule, imports: [CommonModule] }); }
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1pZi10cnVuY2F0ZWQuZGlyZWN0aXZlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9iYXNlL2RpcmVjdGl2ZXMvdG9vbHRpcC1pZi10cnVuY2F0ZWQuZGlyZWN0aXZlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7QUFZL0UsTUFBTSxPQUFPLGlDQUFpQzsrR0FBakMsaUNBQWlDO2dIQUFqQyxpQ0FBaUMsaUJBTjFDLDJCQUEyQixhQUZsQixZQUFZLGFBS3JCLDJCQUEyQjtnSEFHbEIsaUNBQWlDLFlBUmpDLFlBQVk7OzRGQVFaLGlDQUFpQztrQkFUN0MsUUFBUTttQkFBRTtvQkFDVCxPQUFPLEVBQUUsQ0FBRSxZQUFZLENBQUU7b0JBQ3pCLFlBQVksRUFBRTt3QkFDWiwyQkFBMkI7cUJBQzVCO29CQUNELE9BQU8sRUFBRTt3QkFDUCwyQkFBMkI7cUJBQzVCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVG9vbHRpcElmVHJ1bmNhdGVkRGlyZWN0aXZlIH0gZnJvbSAnLi90b29sdGlwLWlmLXRydW5jYXRlZC5kaXJlY3RpdmUnO1xyXG5cclxuXHJcbkBOZ01vZHVsZSgge1xyXG4gIGltcG9ydHM6IFsgQ29tbW9uTW9kdWxlIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBUb29sdGlwSWZUcnVuY2F0ZWREaXJlY3RpdmUsXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBUb29sdGlwSWZUcnVuY2F0ZWREaXJlY3RpdmUsXHJcbiAgXSxcclxufSApXHJcbmV4cG9ydCBjbGFzcyBUb29sdGlwSWZUcnVuY2F0ZWREaXJlY3RpdmVNb2R1bGUgeyB9XHJcbiJdfQ==
@@ -46,48 +46,26 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
46
46
  }
47
47
  }
48
48
  set value(val) {
49
- if (val && this.val?.getTime() !== new Date(val).getTime()) {
50
- if (!this.preventCallSetterPickerValue) {
51
- this.pickerValue = this.formatDateTime(val);
52
- }
53
- this.preventCallSetterPickerValue = false;
49
+ if (val && this.val !== new Date(val)) {
50
+ this.val = new Date(val);
51
+ this.pickerValue = this.formatDateTime(val);
52
+ this.onChange(val);
53
+ this.onTouch(val);
54
54
  }
55
55
  }
56
56
  set pickerValue(val) {
57
57
  if (val) {
58
58
  const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
59
59
  if (isValid(date) && this._pickerValue !== val) {
60
- if (this.minDate && date < this.minDate) {
61
- this.setValues(this.minDate);
62
- this._pickerValue = val;
63
- this.preventCallSetterPickerValue = true;
64
- this.value = this.minDate;
65
- this.runTimeout = true;
66
- this.refreshPickerValue(this.minDate);
67
- return;
68
- }
69
- if (this.maxDate && date > this.maxDate) {
70
- this.setValues(this.maxDate);
71
- this._pickerValue = val;
72
- this.preventCallSetterPickerValue = true;
73
- this.value = this.maxDate;
74
- this.runTimeout = true;
75
- this.refreshPickerValue(this.maxDate);
76
- return;
77
- }
78
- this.runTimeout = false;
79
60
  this._pickerValue = val;
80
- this.preventCallSetterPickerValue = true;
81
61
  this.value = date;
82
- this.setValues(date);
83
62
  }
84
63
  }
85
64
  }
86
- constructor(injector, decimalPipe, cd) {
65
+ constructor(injector, decimalPipe) {
87
66
  super();
88
67
  this.injector = injector;
89
68
  this.decimalPipe = decimalPipe;
90
- this.cd = cd;
91
69
  this.touchUi = false;
92
70
  this.hideSeconds = true;
93
71
  this.cancleLabel = 'Cancel';
@@ -100,8 +78,6 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
100
78
  this.header = EcabsDateTimePickerHeaderComponent;
101
79
  this.maxValueHours = 23;
102
80
  this.maxValueMinutesSeconds = 59;
103
- this.preventCallSetterPickerValue = false;
104
- this.runTimeout = false;
105
81
  this.onChange = () => { };
106
82
  this.onTouch = () => { };
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,14 +134,12 @@ 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
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
142
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component }); }
167
143
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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: [
168
144
  {
169
145
  provide: NG_VALUE_ACCESSOR,
@@ -183,7 +159,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
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\">\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 cancel-button\" 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 apply-button\"\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:\"\"}:host ::ng-deep .form-field{margin-right:-1.25rem;margin-left:-.125rem}.datepicker-toggle{transform:translate(-1.25rem);background-color:inherit;left:-.125rem}.time{width:3.375rem}.fake-input{visibility:hidden;width:0;padding:0;margin:0}.date-input{margin:0rem -1.25rem 0rem -.25rem}.time--inputs{position:relative;display:flex;gap:.5rem;justify-content:center;align-items:center;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}.font-bold{font-weight:700}.actions{display:flex;flex-direction:column;width:100%!important;row-gap:1rem}.grid-picker-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.grid-picker-actions button{width:100%}\n"] }]
186
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { minDate: [{
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: "16.2.12", ngImpo
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\">\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 cancel-button\" 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 apply-button\"\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\">\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 cancel-button\" 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 apply-button\"\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,12 +9,24 @@ import * as i2 from "../base/element-wrapper/element-wrapper.component";
9
9
  import * as i3 from "@angular/material/legacy-form-field";
10
10
  import * as i4 from "@angular/material/legacy-select";
11
11
  import * as i5 from "@angular/material/legacy-core";
12
- import * as i6 from "@angular/forms";
13
- import * as i7 from "ngx-mat-select-search";
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
  get value() {
16
18
  return this.val;
17
19
  }
20
+ get trigger() {
21
+ if (this.getAllSelectedChecked()) {
22
+ return this.allLabel;
23
+ }
24
+ const firstChosenValue = this.val && this.multiple ? this.getLabel(this.val[0]) : this.getLabel(this.val);
25
+ return this.multiple && this.value?.length > 1
26
+ ? `${firstChosenValue} (+${this.useSelectAllOption && this.allSelected?.selected ? this.value?.length - 2 : this.value?.length - 1}
27
+ ${this.value?.length === 2 ? this.otherLabel : this.othersLabel})`
28
+ : firstChosenValue;
29
+ }
18
30
  set value(val) {
19
31
  if (this.val !== val) {
20
32
  this.val = val;
@@ -257,7 +269,7 @@ export class EcabsSelectComponent extends ElementBaseComponent {
257
269
  useExisting: EcabsSelectComponent,
258
270
  multi: true,
259
271
  },
260
- ], 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 class=\"form-field__select\"\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n [id]=\"name\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n [disableRipple]=\"true\"\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\r\n #allSelected\r\n *ngIf=\"useSelectAllOption && showFilteredAllOption\"\r\n (click)=\"toggleAllSelection()\"\r\n [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", 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.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i4.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatLegacySelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i5.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "directive", type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] }); }
272
+ ], 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 class=\"form-field__select\"\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n [id]=\"name\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n [disableRipple]=\"true\"\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\r\n #allSelected\r\n *ngIf=\"useSelectAllOption && showFilteredAllOption\"\r\n (click)=\"toggleAllSelection()\"\r\n [value]=\"selectAllValue\"\r\n >\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.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i4.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatLegacySelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i5.MatLegacyOption, 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", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "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" }] }); }
261
273
  }
262
274
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsSelectComponent, decorators: [{
263
275
  type: Component,
@@ -267,7 +279,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
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 class=\"form-field__select\"\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n [id]=\"name\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n [disableRipple]=\"true\"\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\r\n #allSelected\r\n *ngIf=\"useSelectAllOption && showFilteredAllOption\"\r\n (click)=\"toggleAllSelection()\"\r\n [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" }]
282
+ ], template: "<app-element-wrapper [data]=\"getData()\">\r\n <mat-form-field [ngClass]=\"{ disabled: useOnlyDisabledClass }\">\r\n <mat-select\r\n class=\"form-field__select\"\r\n [(ngModel)]=\"value\"\r\n (closed)=\"onTouch()\"\r\n [id]=\"name\"\r\n appearance=\"outline\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [placeholder]=\"placeholder\"\r\n [disableRipple]=\"true\"\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\r\n #allSelected\r\n *ngIf=\"useSelectAllOption && showFilteredAllOption\"\r\n (click)=\"toggleAllSelection()\"\r\n [value]=\"selectAllValue\"\r\n >\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: "16.2.12", ngImpo
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      class=\"form-field__select\"\r\n      [(ngModel)]=\"value\"\r\n      (closed)=\"onTouch()\"\r\n      [id]=\"name\"\r\n      appearance=\"outline\"\r\n      [multiple]=\"multiple\"\r\n      [disabled]=\"disabled\"\r\n      [placeholder]=\"placeholder\"\r\n      [disableRipple]=\"true\"\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\r\n      #allSelected\r\n      *ngIf=\"useSelectAllOption && showFilteredAllOption\"\r\n      (click)=\"toggleAllSelection()\"\r\n      [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      class=\"form-field__select\"\r\n      [(ngModel)]=\"value\"\r\n      (closed)=\"onTouch()\"\r\n      [id]=\"name\"\r\n      appearance=\"outline\"\r\n      [multiple]=\"multiple\"\r\n      [disabled]=\"disabled\"\r\n      [placeholder]=\"placeholder\"\r\n      [disableRipple]=\"true\"\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\r\n        #allSelected\r\n        *ngIf=\"useSelectAllOption && showFilteredAllOption\"\r\n        (click)=\"toggleAllSelection()\"\r\n        [value]=\"selectAllValue\"\r\n      >\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,11 +1,13 @@
1
- import { NgModule } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
3
- import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
4
- import { EcabsSelectComponent } from './ecabs-select.component';
5
1
  import { NgxMatSelectSearchModule } from 'ngx-mat-select-search';
6
2
  import { MAT_LEGACY_SELECT_SCROLL_STRATEGY as MAT_SELECT_SCROLL_STRATEGY, MatLegacySelectModule as MatSelectModule, } from '@angular/material/legacy-select';
7
3
  import { Overlay } from '@angular/cdk/overlay';
4
+ import { CommonModule } from '@angular/common';
5
+ import { NgModule } from '@angular/core';
8
6
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
7
+ import { MatTooltipModule } from '@angular/material/tooltip';
8
+ import { TooltipIfTruncatedDirectiveModule } from '../base/directives/tooltip-if-truncated.directive.module';
9
+ import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
10
+ import { EcabsSelectComponent } from './ecabs-select.component';
9
11
  import { MatLegacyFormFieldModule as MatFormFieldModule } from '@angular/material/legacy-form-field';
10
12
  import * as i0 from "@angular/core";
11
13
  export class EcabsSelectModule {
@@ -13,10 +15,12 @@ export class EcabsSelectModule {
13
15
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EcabsSelectModule, declarations: [EcabsSelectComponent], imports: [CommonModule,
14
16
  ElementWrapperModule,
15
17
  MatSelectModule,
18
+ MatTooltipModule,
16
19
  FormsModule,
17
20
  NgxMatSelectSearchModule,
18
21
  MatFormFieldModule,
19
- ReactiveFormsModule], exports: [EcabsSelectComponent] }); }
22
+ ReactiveFormsModule,
23
+ TooltipIfTruncatedDirectiveModule], exports: [EcabsSelectComponent] }); }
20
24
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsSelectModule, providers: [
21
25
  {
22
26
  provide: MAT_SELECT_SCROLL_STRATEGY,
@@ -26,10 +30,12 @@ export class EcabsSelectModule {
26
30
  ], imports: [CommonModule,
27
31
  ElementWrapperModule,
28
32
  MatSelectModule,
33
+ MatTooltipModule,
29
34
  FormsModule,
30
35
  NgxMatSelectSearchModule,
31
36
  MatFormFieldModule,
32
- ReactiveFormsModule] }); }
37
+ ReactiveFormsModule,
38
+ TooltipIfTruncatedDirectiveModule] }); }
33
39
  }
34
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsSelectModule, decorators: [{
35
41
  type: NgModule,
@@ -39,10 +45,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
39
45
  CommonModule,
40
46
  ElementWrapperModule,
41
47
  MatSelectModule,
48
+ MatTooltipModule,
42
49
  FormsModule,
43
50
  NgxMatSelectSearchModule,
44
51
  MatFormFieldModule,
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: "16.2.12", ngImpo
57
65
  export function scrollFactory(overlay) {
58
66
  return () => overlay.scrollStrategies.block();
59
67
  }
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtc2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1zZWxlY3QvZWNhYnMtc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN0RixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNqRSxPQUFPLEVBQ0wsaUNBQWlDLElBQUksMEJBQTBCLEVBQy9ELHFCQUFxQixJQUFJLGVBQWUsR0FDekMsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEVBQXVCLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsd0JBQXdCLElBQUksa0JBQWtCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7QUFzQnJHLE1BQU0sT0FBTyxpQkFBaUI7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQW5CWixvQkFBb0IsYUFFbEMsWUFBWTtZQUNaLG9CQUFvQjtZQUNwQixlQUFlO1lBQ2YsV0FBVztZQUNYLHdCQUF3QjtZQUN4QixrQkFBa0I7WUFDbEIsbUJBQW1CLGFBRVYsb0JBQW9CO2dIQVNwQixpQkFBaUIsYUFSakI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsMEJBQTBCO2dCQUNuQyxVQUFVLEVBQUUsYUFBYTtnQkFDekIsSUFBSSxFQUFFLENBQUUsT0FBTyxDQUFFO2FBQ2xCO1NBQ0YsWUFmQyxZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLGVBQWU7WUFDZixXQUFXO1lBQ1gsd0JBQXdCO1lBQ3hCLGtCQUFrQjtZQUNsQixtQkFBbUI7OzRGQVdWLGlCQUFpQjtrQkFwQjdCLFFBQVE7bUJBQUU7b0JBQ1QsWUFBWSxFQUFFLENBQUUsb0JBQW9CLENBQUU7b0JBQ3RDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLG9CQUFvQjt3QkFDcEIsZUFBZTt3QkFDZixXQUFXO3dCQUNYLHdCQUF3Qjt3QkFDeEIsa0JBQWtCO3dCQUNsQixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRSxDQUFFLG9CQUFvQixDQUFFO29CQUNqQyxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLDBCQUEwQjs0QkFDbkMsVUFBVSxFQUFFLGFBQWE7NEJBQ3pCLElBQUksRUFBRSxDQUFFLE9BQU8sQ0FBRTt5QkFDbEI7cUJBQ0Y7aUJBQ0Y7O0FBRUQsTUFBTSxVQUFVLGFBQWEsQ0FBRSxPQUFnQjtJQUM3QyxPQUFPLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUNoRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRWxlbWVudFdyYXBwZXJNb2R1bGUgfSBmcm9tICcuLi9iYXNlL2VsZW1lbnQtd3JhcHBlci9lbGVtZW50LXdyYXBwZXIubW9kdWxlJztcclxuaW1wb3J0IHsgRWNhYnNTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL2VjYWJzLXNlbGVjdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBOZ3hNYXRTZWxlY3RTZWFyY2hNb2R1bGUgfSBmcm9tICduZ3gtbWF0LXNlbGVjdC1zZWFyY2gnO1xyXG5pbXBvcnQge1xyXG4gIE1BVF9MRUdBQ1lfU0VMRUNUX1NDUk9MTF9TVFJBVEVHWSBhcyBNQVRfU0VMRUNUX1NDUk9MTF9TVFJBVEVHWSxcclxuICBNYXRMZWdhY3lTZWxlY3RNb2R1bGUgYXMgTWF0U2VsZWN0TW9kdWxlLFxyXG59IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xlZ2FjeS1zZWxlY3QnO1xyXG5pbXBvcnQgeyBCbG9ja1Njcm9sbFN0cmF0ZWd5LCBPdmVybGF5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0TGVnYWN5Rm9ybUZpZWxkTW9kdWxlIGFzIE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xlZ2FjeS1mb3JtLWZpZWxkJztcclxuXHJcbkBOZ01vZHVsZSgge1xyXG4gIGRlY2xhcmF0aW9uczogWyBFY2Fic1NlbGVjdENvbXBvbmVudCBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEVsZW1lbnRXcmFwcGVyTW9kdWxlLFxyXG4gICAgTWF0U2VsZWN0TW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBOZ3hNYXRTZWxlY3RTZWFyY2hNb2R1bGUsXHJcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbIEVjYWJzU2VsZWN0Q29tcG9uZW50IF0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE1BVF9TRUxFQ1RfU0NST0xMX1NUUkFURUdZLFxyXG4gICAgICB1c2VGYWN0b3J5OiBzY3JvbGxGYWN0b3J5LFxyXG4gICAgICBkZXBzOiBbIE92ZXJsYXkgXSxcclxuICAgIH0sXHJcbiAgXSxcclxufSApXHJcbmV4cG9ydCBjbGFzcyBFY2Fic1NlbGVjdE1vZHVsZSB7IH1cclxuZXhwb3J0IGZ1bmN0aW9uIHNjcm9sbEZhY3RvcnkoIG92ZXJsYXk6IE92ZXJsYXkgKTogKCkgPT4gQmxvY2tTY3JvbGxTdHJhdGVneSB7XHJcbiAgcmV0dXJuICgpID0+IG92ZXJsYXkuc2Nyb2xsU3RyYXRlZ2llcy5ibG9jaygpO1xyXG59XHJcbiJdfQ==
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtc2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1zZWxlY3QvZWNhYnMtc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNqRSxPQUFPLEVBQ0wsaUNBQWlDLElBQUksMEJBQTBCLEVBQy9ELHFCQUFxQixJQUFJLGVBQWUsR0FDekMsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEVBQXVCLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUU3RCxPQUFPLEVBQ0wsaUNBQWlDLEVBQ2xDLE1BQU0sMERBQTBELENBQUM7QUFDbEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDdEYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLHdCQUF3QixJQUFJLGtCQUFrQixFQUFFLE1BQU0scUNBQXFDLENBQUM7O0FBd0JyRyxNQUFNLE9BQU8saUJBQWlCOytHQUFqQixpQkFBaUI7Z0hBQWpCLGlCQUFpQixpQkFyQlosb0JBQW9CLGFBRWxDLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixXQUFXO1lBQ1gsd0JBQXdCO1lBQ3hCLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsaUNBQWlDLGFBRXhCLG9CQUFvQjtnSEFTcEIsaUJBQWlCLGFBUmpCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLDBCQUEwQjtnQkFDbkMsVUFBVSxFQUFFLGFBQWE7Z0JBQ3pCLElBQUksRUFBRSxDQUFFLE9BQU8sQ0FBRTthQUNsQjtTQUNGLFlBakJDLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixXQUFXO1lBQ1gsd0JBQXdCO1lBQ3hCLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsaUNBQWlDOzs0RkFXeEIsaUJBQWlCO2tCQXRCN0IsUUFBUTttQkFBRTtvQkFDVCxZQUFZLEVBQUUsQ0FBRSxvQkFBb0IsQ0FBRTtvQkFDdEMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsV0FBVzt3QkFDWCx3QkFBd0I7d0JBQ3hCLGtCQUFrQjt3QkFDbEIsbUJBQW1CO3dCQUNuQixpQ0FBaUM7cUJBQ2xDO29CQUNELE9BQU8sRUFBRSxDQUFFLG9CQUFvQixDQUFFO29CQUNqQyxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLDBCQUEwQjs0QkFDbkMsVUFBVSxFQUFFLGFBQWE7NEJBQ3pCLElBQUksRUFBRSxDQUFFLE9BQU8sQ0FBRTt5QkFDbEI7cUJBQ0Y7aUJBQ0Y7O0FBRUQsTUFBTSxVQUFVLGFBQWEsQ0FBRSxPQUFnQjtJQUM3QyxPQUFPLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUNoRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmd4TWF0U2VsZWN0U2VhcmNoTW9kdWxlIH0gZnJvbSAnbmd4LW1hdC1zZWxlY3Qtc2VhcmNoJztcclxuaW1wb3J0IHtcclxuICBNQVRfTEVHQUNZX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1kgYXMgTUFUX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1ksXHJcbiAgTWF0TGVnYWN5U2VsZWN0TW9kdWxlIGFzIE1hdFNlbGVjdE1vZHVsZSxcclxufSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9sZWdhY3ktc2VsZWN0JztcclxuaW1wb3J0IHsgQmxvY2tTY3JvbGxTdHJhdGVneSwgT3ZlcmxheSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcclxuXHJcbmltcG9ydCB7XHJcbiAgVG9vbHRpcElmVHJ1bmNhdGVkRGlyZWN0aXZlTW9kdWxlXHJcbn0gZnJvbSAnLi4vYmFzZS9kaXJlY3RpdmVzL3Rvb2x0aXAtaWYtdHJ1bmNhdGVkLmRpcmVjdGl2ZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic1NlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtc2VsZWN0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdExlZ2FjeUZvcm1GaWVsZE1vZHVsZSBhcyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9sZWdhY3ktZm9ybS1maWVsZCc7XHJcblxyXG5ATmdNb2R1bGUoIHtcclxuICBkZWNsYXJhdGlvbnM6IFsgRWNhYnNTZWxlY3RDb21wb25lbnQgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBFbGVtZW50V3JhcHBlck1vZHVsZSxcclxuICAgIE1hdFNlbGVjdE1vZHVsZSxcclxuICAgIE1hdFRvb2x0aXBNb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIE5neE1hdFNlbGVjdFNlYXJjaE1vZHVsZSxcclxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBUb29sdGlwSWZUcnVuY2F0ZWREaXJlY3RpdmVNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFsgRWNhYnNTZWxlY3RDb21wb25lbnQgXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTUFUX1NFTEVDVF9TQ1JPTExfU1RSQVRFR1ksXHJcbiAgICAgIHVzZUZhY3Rvcnk6IHNjcm9sbEZhY3RvcnksXHJcbiAgICAgIGRlcHM6IFsgT3ZlcmxheSBdLFxyXG4gICAgfSxcclxuICBdLFxyXG59IClcclxuZXhwb3J0IGNsYXNzIEVjYWJzU2VsZWN0TW9kdWxlIHsgfVxyXG5leHBvcnQgZnVuY3Rpb24gc2Nyb2xsRmFjdG9yeSggb3ZlcmxheTogT3ZlcmxheSApOiAoKSA9PiBCbG9ja1Njcm9sbFN0cmF0ZWd5IHtcclxuICByZXR1cm4gKCkgPT4gb3ZlcmxheS5zY3JvbGxTdHJhdGVnaWVzLmJsb2NrKCk7XHJcbn1cclxuIl19