ecabs-components 1.0.87 → 1.0.89
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/README.md +3 -0
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +12 -87
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.module.mjs +3 -7
- package/esm2022/lib/ecabs-table/ecabs-table.component.mjs +5 -5
- package/esm2022/lib/ecabs-table/ecabs-table.module.mjs +3 -3
- package/fesm2022/ecabs-components.mjs +218 -295
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/ecabs-date-picker/ecabs-date-picker.component.d.ts +6 -18
- package/lib/ecabs-date-picker/ecabs-date-picker.module.d.ts +1 -2
- package/lib/ecabs-table/ecabs-table.component.d.ts +1 -1
- package/lib/ecabs-table/ecabs-table.module.d.ts +3 -3
- package/package.json +1 -1
- package/src/assets/styles/material/_theme.scss +0 -12
- package/src/assets/styles/material/overrides/_progress.scss +7 -0
- package/src/assets/styles/material/overrides/index.scss +1 -0
- package/src/assets/styles/scss/base/_normalize.scss +6 -0
package/README.md
CHANGED
|
@@ -42,3 +42,6 @@ v1.0.83 - Fix buttons height.
|
|
|
42
42
|
v1.0.84 - Emit `falsey` result when Close button is clicked on `EcabsDialogConfirm` and `EcabsDialogMessage`.
|
|
43
43
|
v1.0.85 - Improve styling for `EcabsTable` row colors.
|
|
44
44
|
v1.0.87 - Apply min/max Date logic for date picker
|
|
45
|
+
v1.0.88 - Roll back 1.0.87
|
|
46
|
+
v1.0.84 - Emit `falsey` result when Close button is clicked on `EcabsDialogConfirm` and `EcabsDialogMessage`.
|
|
47
|
+
v1.0.89 - Upgrade `MatLegacyTable` and `MatLegacyProgress` to `MDC`.
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { format, isEqual, isValid
|
|
1
|
+
import { format, isEqual, isValid } from 'date-fns';
|
|
2
2
|
import { takeUntil } from 'rxjs';
|
|
3
3
|
import Holidays from 'date-holidays';
|
|
4
4
|
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
@@ -13,14 +13,12 @@ import * as i3 from "../base/element-wrapper/element-wrapper.component";
|
|
|
13
13
|
import * as i4 from "@angular/material/icon";
|
|
14
14
|
import * as i5 from "@angular/material/datepicker";
|
|
15
15
|
import * as i6 from "@angular/forms";
|
|
16
|
-
import * as i7 from "@angular/material/
|
|
16
|
+
import * as i7 from "@angular/material/form-field";
|
|
17
17
|
import * as i8 from "../ecabs-date-picker-actions/ecabs-date-picker-actions.component";
|
|
18
|
-
import * as i9 from "../base/directives/date-mask.directive";
|
|
19
18
|
export class EcabsDatePickerComponent extends ElementBaseComponent {
|
|
20
19
|
injector;
|
|
21
20
|
ecabsDatePickerHeaderService;
|
|
22
21
|
unsubscribeService;
|
|
23
|
-
cd;
|
|
24
22
|
minDate;
|
|
25
23
|
maxDate;
|
|
26
24
|
touchUi = false;
|
|
@@ -30,65 +28,25 @@ export class EcabsDatePickerComponent extends ElementBaseComponent {
|
|
|
30
28
|
excludeWeekends;
|
|
31
29
|
specificDates;
|
|
32
30
|
holidayOptions;
|
|
33
|
-
applyMinDateAuto = true;
|
|
34
31
|
onblur = new EventEmitter();
|
|
35
32
|
val;
|
|
36
33
|
header = EcabsDatePickerHeaderComponent;
|
|
37
34
|
translationConfig;
|
|
38
|
-
_date;
|
|
39
|
-
_pickerValue;
|
|
40
|
-
preventCallSetterPickerValue = false;
|
|
41
|
-
runTimeout = false;
|
|
42
35
|
get value() {
|
|
43
36
|
return this.val;
|
|
44
37
|
}
|
|
45
|
-
get pickerValue() {
|
|
46
|
-
return this._pickerValue;
|
|
47
|
-
}
|
|
48
38
|
set value(val) {
|
|
49
39
|
if (this.val !== val && (!val || isValid(new Date(val)))) {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
this.preventCallSetterPickerValue = false;
|
|
40
|
+
this.val = val;
|
|
41
|
+
this.onChange(val);
|
|
42
|
+
this.onTouch(val);
|
|
54
43
|
}
|
|
55
44
|
}
|
|
56
|
-
|
|
57
|
-
if (val) {
|
|
58
|
-
const date = parse(val.replace('_', ''), `dd/MM/yyyy`, new Date());
|
|
59
|
-
if (isValid(date) && this._pickerValue !== val) {
|
|
60
|
-
if (this.minDate && date < this.minDate && this.applyMinDateAuto) {
|
|
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
|
-
this._pickerValue = val;
|
|
80
|
-
this.preventCallSetterPickerValue = true;
|
|
81
|
-
this.value = date;
|
|
82
|
-
this.setValues(date);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
constructor(injector, ecabsDatePickerHeaderService, unsubscribeService, cd) {
|
|
45
|
+
constructor(injector, ecabsDatePickerHeaderService, unsubscribeService) {
|
|
87
46
|
super();
|
|
88
47
|
this.injector = injector;
|
|
89
48
|
this.ecabsDatePickerHeaderService = ecabsDatePickerHeaderService;
|
|
90
49
|
this.unsubscribeService = unsubscribeService;
|
|
91
|
-
this.cd = cd;
|
|
92
50
|
}
|
|
93
51
|
ngOnInit() {
|
|
94
52
|
this.ecabsDatePickerHeaderService
|
|
@@ -100,12 +58,6 @@ export class EcabsDatePickerComponent extends ElementBaseComponent {
|
|
|
100
58
|
const ngControl = this.injector.get(NgControl, null);
|
|
101
59
|
if (ngControl) {
|
|
102
60
|
this.control = ngControl.control;
|
|
103
|
-
setTimeout(() => {
|
|
104
|
-
const controlDate = this.control.value;
|
|
105
|
-
if (controlDate) {
|
|
106
|
-
this.setValues(controlDate);
|
|
107
|
-
}
|
|
108
|
-
}, 10);
|
|
109
61
|
}
|
|
110
62
|
}
|
|
111
63
|
onChange = () => { };
|
|
@@ -150,40 +102,15 @@ export class EcabsDatePickerComponent extends ElementBaseComponent {
|
|
|
150
102
|
}
|
|
151
103
|
return result;
|
|
152
104
|
};
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
this.value = this._date;
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
refreshPickerValue(date) {
|
|
159
|
-
setTimeout(() => {
|
|
160
|
-
if (this.runTimeout) {
|
|
161
|
-
this._pickerValue = this.formatDate(date);
|
|
162
|
-
this.cd.detectChanges();
|
|
163
|
-
}
|
|
164
|
-
}, 3000);
|
|
165
|
-
}
|
|
166
|
-
setValues(date) {
|
|
167
|
-
this.onChange(date);
|
|
168
|
-
this.onTouch(date);
|
|
169
|
-
this._date = date;
|
|
170
|
-
}
|
|
171
|
-
formatDate(date) {
|
|
172
|
-
let result = '';
|
|
173
|
-
if (date && isValid(new Date(date))) {
|
|
174
|
-
result = format(new Date(date), `dd/MM/yyyy`);
|
|
175
|
-
}
|
|
176
|
-
return result;
|
|
177
|
-
}
|
|
178
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDatePickerComponent, deps: [{ token: i0.Injector }, { token: i1.EcabsDatePickerHeaderService }, { token: i2.UnsubscribeService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
179
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDatePickerComponent, selector: "ecabs-date-picker", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", cancelLabel: "cancelLabel", applyLabel: "applyLabel", excludeHolidays: "excludeHolidays", excludeWeekends: "excludeWeekends", specificDates: "specificDates", holidayOptions: "holidayOptions", applyMinDateAuto: "applyMinDateAuto" }, outputs: { onblur: "onblur" }, providers: [
|
|
105
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDatePickerComponent, deps: [{ token: i0.Injector }, { token: i1.EcabsDatePickerHeaderService }, { token: i2.UnsubscribeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
106
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDatePickerComponent, selector: "ecabs-date-picker", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", cancelLabel: "cancelLabel", applyLabel: "applyLabel", excludeHolidays: "excludeHolidays", excludeWeekends: "excludeWeekends", specificDates: "specificDates", holidayOptions: "holidayOptions" }, outputs: { onblur: "onblur" }, providers: [
|
|
180
107
|
{
|
|
181
108
|
provide: NG_VALUE_ACCESSOR,
|
|
182
109
|
useExisting: EcabsDatePickerComponent,
|
|
183
110
|
multi: true,
|
|
184
111
|
},
|
|
185
112
|
UnsubscribeService,
|
|
186
|
-
], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper
|
|
113
|
+
], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper\">\r\n <input\r\n class=\"form-field__input date-input\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"value\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"picker\"\r\n [min]=\"minDate\"\r\n [max]=\"maxDate\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <mat-datepicker-toggle\r\n matSuffix [for]=\"picker\"\r\n class=\"text-gray-500\"\r\n >\r\n <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\"\r\n >\r\n <mat-datepicker-actions>\r\n <ecabs-date-picker-actions\r\n [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n >\r\n </ecabs-date-picker-actions>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: [""], dependencies: [{ kind: "component", type: i3.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i5.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "component", type: i5.MatDatepickerActions, selector: "mat-datepicker-actions, mat-date-range-picker-actions" }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "directive", type: i7.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i8.EcabsDatePickerActionsComponent, selector: "ecabs-date-picker-actions", inputs: ["cancelLabel", "applyLabel"], outputs: ["apply"] }] });
|
|
187
114
|
}
|
|
188
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDatePickerComponent, decorators: [{
|
|
189
116
|
type: Component,
|
|
@@ -194,8 +121,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
194
121
|
multi: true,
|
|
195
122
|
},
|
|
196
123
|
UnsubscribeService,
|
|
197
|
-
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper
|
|
198
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.EcabsDatePickerHeaderService }, { type: i2.UnsubscribeService }
|
|
124
|
+
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper\">\r\n <input\r\n class=\"form-field__input date-input\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"value\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"picker\"\r\n [min]=\"minDate\"\r\n [max]=\"maxDate\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <mat-datepicker-toggle\r\n matSuffix [for]=\"picker\"\r\n class=\"text-gray-500\"\r\n >\r\n <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\"\r\n >\r\n <mat-datepicker-actions>\r\n <ecabs-date-picker-actions\r\n [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n >\r\n </ecabs-date-picker-actions>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n </div>\r\n</app-element-wrapper>\r\n" }]
|
|
125
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.EcabsDatePickerHeaderService }, { type: i2.UnsubscribeService }]; }, propDecorators: { minDate: [{
|
|
199
126
|
type: Input
|
|
200
127
|
}], maxDate: [{
|
|
201
128
|
type: Input
|
|
@@ -213,9 +140,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
213
140
|
type: Input
|
|
214
141
|
}], holidayOptions: [{
|
|
215
142
|
type: Input
|
|
216
|
-
}], applyMinDateAuto: [{
|
|
217
|
-
type: Input
|
|
218
143
|
}], onblur: [{
|
|
219
144
|
type: Output
|
|
220
145
|
}] } });
|
|
221
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { format, isEqual, isValid, parse } from 'date-fns';\r\nimport { takeUntil } from 'rxjs';\r\nimport Holidays from 'date-holidays';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} from '../base/models/ecabs-date-picker-translations.models';\r\n\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\n\r\nimport { EcabsDatePickerHeaderComponent } from './components/ecabs-date-picker-header/ecabs-date-picker-header.component';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-picker',\r\n  templateUrl: './ecabs-date-picker.component.html',\r\n  styleUrls: ['./ecabs-date-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDatePickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDatePickerComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit\r\n{\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() cancelLabel: string;\r\n  @Input() applyLabel: string;\r\n  @Input() excludeHolidays: boolean;\r\n  @Input() excludeWeekends: boolean;\r\n  @Input() specificDates: Date[];\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n  @Input() applyMinDateAuto = true;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  val: Date;\r\n  header = EcabsDatePickerHeaderComponent;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n  _date: Date;\r\n  _pickerValue: string;\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  set value(val) {\r\n    if (this.val !== val && (!val || isValid(new Date(val)))) {\r\n      if (!this.preventCallSetterPickerValue) {\r\n        this.pickerValue = this.formatDate(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(val.replace('_', ''), `dd/MM/yyyy`, new Date());\r\n\r\n      if (isValid(date) && this._pickerValue !== val) {\r\n        if (this.minDate && date < this.minDate && this.applyMinDateAuto) {\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(\r\n    private readonly injector: Injector,\r\n    private readonly ecabsDatePickerHeaderService: EcabsDatePickerHeaderService,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n    private readonly cd: ChangeDetectorRef,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.ecabsDatePickerHeaderService\r\n      .getConfig()\r\n      .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n      .subscribe((config) => (this.translationConfig = config));\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;\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  isDateNotHoliday(date: Date): boolean {\r\n    const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};\r\n\r\n    if (countryCode && timeZoneOffset) {\r\n      const holiday = new Holidays(countryCode.toUpperCase());\r\n\r\n      return !holiday.isHoliday(\r\n        `${format(date, 'yyyy-MM-dd')}T00:00:00${timeZoneOffset}`,\r\n      );\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  filterDateRange = (date: Date): boolean => {\r\n    let result = true;\r\n\r\n    if (isValid(new Date(date))) {\r\n      const day = date?.getDay();\r\n\r\n      if (this.excludeWeekends) {\r\n        result = result && day !== 0 && day !== 6;\r\n      }\r\n\r\n      if (this.excludeHolidays) {\r\n        result = result && this.isDateNotHoliday(date);\r\n      }\r\n\r\n      if (this.specificDates?.length > 0) {\r\n        const specificDates = this.specificDates;\r\n        if (specificDates && specificDates.length > 0) {\r\n          const index = specificDates.findIndex((specificDate) =>\r\n            isEqual(date, specificDate),\r\n          );\r\n          result = result && index === -1;\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  };\r\n\r\n  onApply(): void {\r\n    if (this._date) {\r\n      this.value = this._date;\r\n    }\r\n  }\r\n\r\n  private refreshPickerValue(date: Date): void {\r\n    setTimeout(() => {\r\n      if (this.runTimeout) {\r\n        this._pickerValue = this.formatDate(date);\r\n        this.cd.detectChanges();\r\n      }\r\n    }, 3000);\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  }\r\n\r\n  private formatDate(date: Date): string {\r\n    let result = '';\r\n\r\n    if (date && isValid(new Date(date))) {\r\n      result = format(new Date(date), `dd/MM/yyyy`);\r\n    }\r\n\r\n    return result;\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      [matDatepickerFilter]=\"filterDateRange\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n  <mat-datepicker #picker\r\n    [calendarHeaderComponent]=\"header\"\r\n    [touchUi]=\"touchUi\"\r\n  >\r\n    <mat-datepicker-actions>\r\n      <ecabs-date-picker-actions\r\n        [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n        [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n        (apply)=\"onApply()\"\r\n      >\r\n      </ecabs-date-picker-actions>\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      (blur)=\"onTouch()\"\r\n    />\r\n    <button mat-icon-button class=\"datepicker-ui__toggle text-gray-500\"\r\n            (click)=\"picker.open()\">\r\n      <mat-icon>calendar_today</mat-icon>\r\n    </button>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { format, isEqual, isValid } from 'date-fns';\r\nimport { takeUntil } from 'rxjs';\r\nimport Holidays from 'date-holidays';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} from '../base/models/ecabs-date-picker-translations.models';\r\n\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\n\r\nimport { EcabsDatePickerHeaderComponent } from './components/ecabs-date-picker-header/ecabs-date-picker-header.component';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-picker',\r\n  templateUrl: './ecabs-date-picker.component.html',\r\n  styleUrls: ['./ecabs-date-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDatePickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDatePickerComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit\r\n{\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() cancelLabel: string;\r\n  @Input() applyLabel: string;\r\n  @Input() excludeHolidays: boolean;\r\n  @Input() excludeWeekends: boolean;\r\n  @Input() specificDates: Date[];\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  val: string | number;\r\n  header = EcabsDatePickerHeaderComponent;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n\r\n  get value(): string | number {\r\n    return this.val;\r\n  }\r\n\r\n  set value(val: string | number) {\r\n    if (this.val !== val && (!val || isValid(new Date(val)))) {\r\n      this.val = val;\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 ecabsDatePickerHeaderService: EcabsDatePickerHeaderService,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.ecabsDatePickerHeaderService\r\n      .getConfig()\r\n      .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n      .subscribe((config) => (this.translationConfig = config));\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  }\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  isDateNotHoliday(date: Date): boolean {\r\n    const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};\r\n\r\n    if (countryCode && timeZoneOffset) {\r\n      const holiday = new Holidays(countryCode.toUpperCase());\r\n\r\n      return !holiday.isHoliday(\r\n        `${format(date, 'yyyy-MM-dd')}T00:00:00${timeZoneOffset}`,\r\n      );\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  filterDateRange = (date: Date): boolean => {\r\n    let result = true;\r\n\r\n    if (isValid(new Date(date))) {\r\n      const day = date?.getDay();\r\n\r\n      if (this.excludeWeekends) {\r\n        result = result && day !== 0 && day !== 6;\r\n      }\r\n\r\n      if (this.excludeHolidays) {\r\n        result = result && this.isDateNotHoliday(date);\r\n      }\r\n\r\n      if (this.specificDates?.length > 0) {\r\n        const specificDates = this.specificDates;\r\n        if (specificDates && specificDates.length > 0) {\r\n          const index = specificDates.findIndex((specificDate) =>\r\n            isEqual(date, specificDate),\r\n          );\r\n          result = result && index === -1;\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  };\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper\">\r\n    <input\r\n      class=\"form-field__input date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"value\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      [matDatepickerFilter]=\"filterDateRange\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker-toggle\r\n      matSuffix [for]=\"picker\"\r\n      class=\"text-gray-500\"\r\n    >\r\n      <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-datepicker #picker\r\n      [calendarHeaderComponent]=\"header\"\r\n      [touchUi]=\"touchUi\"\r\n    >\r\n      <mat-datepicker-actions>\r\n        <ecabs-date-picker-actions\r\n          [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n          [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n        >\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
@@ -10,7 +10,6 @@ import { EcabsDatePickerComponent } from './ecabs-date-picker.component';
|
|
|
10
10
|
import { EcabsDatePickerActionsModule } from '../ecabs-date-picker-actions/ecabs-date-picker-actions.module';
|
|
11
11
|
import { MatInputModule } from '@angular/material/input';
|
|
12
12
|
import { MatButtonModule } from '@angular/material/button';
|
|
13
|
-
import { MaskDateDirectiveModule } from '../base/directives/date-mask.directive.module';
|
|
14
13
|
import * as i0 from "@angular/core";
|
|
15
14
|
export class EcabsDatePickerModule {
|
|
16
15
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDatePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -23,8 +22,7 @@ export class EcabsDatePickerModule {
|
|
|
23
22
|
EcabsPickerHeaderModule,
|
|
24
23
|
MatButtonModule,
|
|
25
24
|
MatInputModule,
|
|
26
|
-
EcabsDatePickerActionsModule,
|
|
27
|
-
MaskDateDirectiveModule], exports: [EcabsDatePickerComponent, EcabsDatePickerHeaderComponent] });
|
|
25
|
+
EcabsDatePickerActionsModule], exports: [EcabsDatePickerComponent, EcabsDatePickerHeaderComponent] });
|
|
28
26
|
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDatePickerModule, imports: [CommonModule,
|
|
29
27
|
ElementWrapperModule,
|
|
30
28
|
MatIconModule,
|
|
@@ -34,8 +32,7 @@ export class EcabsDatePickerModule {
|
|
|
34
32
|
EcabsPickerHeaderModule,
|
|
35
33
|
MatButtonModule,
|
|
36
34
|
MatInputModule,
|
|
37
|
-
EcabsDatePickerActionsModule
|
|
38
|
-
MaskDateDirectiveModule] });
|
|
35
|
+
EcabsDatePickerActionsModule] });
|
|
39
36
|
}
|
|
40
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDatePickerModule, decorators: [{
|
|
41
38
|
type: NgModule,
|
|
@@ -52,9 +49,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
52
49
|
MatButtonModule,
|
|
53
50
|
MatInputModule,
|
|
54
51
|
EcabsDatePickerActionsModule,
|
|
55
|
-
MaskDateDirectiveModule,
|
|
56
52
|
],
|
|
57
53
|
exports: [EcabsDatePickerComponent, EcabsDatePickerHeaderComponent],
|
|
58
54
|
}]
|
|
59
55
|
}] });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtZGF0ZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWRhdGUtcGlja2VyL2VjYWJzLWRhdGUtcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3RGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQzVGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLDBFQUEwRSxDQUFDO0FBQzFILE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBQzdHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBa0IzRCxNQUFNLE9BQU8scUJBQXFCO3dHQUFyQixxQkFBcUI7eUdBQXJCLHFCQUFxQixpQkFmakIsd0JBQXdCLEVBQUUsOEJBQThCLGFBRXJFLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLHVCQUF1QjtZQUN2QixlQUFlO1lBQ2YsY0FBYztZQUNkLDRCQUE0QixhQUVwQix3QkFBd0IsRUFBRSw4QkFBOEI7eUdBRXZELHFCQUFxQixZQWI5QixZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIsV0FBVztZQUNYLG1CQUFtQjtZQUNuQix1QkFBdUI7WUFDdkIsZUFBZTtZQUNmLGNBQWM7WUFDZCw0QkFBNEI7OzRGQUluQixxQkFBcUI7a0JBaEJqQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHdCQUF3QixFQUFFLDhCQUE4QixDQUFDO29CQUN4RSxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixvQkFBb0I7d0JBQ3BCLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsdUJBQXVCO3dCQUN2QixlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsNEJBQTRCO3FCQUM3QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyx3QkFBd0IsRUFBRSw4QkFBOEIsQ0FBQztpQkFDcEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0RGF0ZXBpY2tlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXInO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcblxyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic1BpY2tlckhlYWRlck1vZHVsZSB9IGZyb20gJy4uL2VjYWJzLXBpY2tlci1oZWFkZXIvZWNhYnMtcGlja2VyLWhlYWRlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic0RhdGVQaWNrZXJIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZWNhYnMtZGF0ZS1waWNrZXItaGVhZGVyL2VjYWJzLWRhdGUtcGlja2VyLWhlYWRlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBFY2Fic0RhdGVQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2VjYWJzLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEVjYWJzRGF0ZVBpY2tlckFjdGlvbnNNb2R1bGUgfSBmcm9tICcuLi9lY2Ficy1kYXRlLXBpY2tlci1hY3Rpb25zL2VjYWJzLWRhdGUtcGlja2VyLWFjdGlvbnMubW9kdWxlJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0VjYWJzRGF0ZVBpY2tlckNvbXBvbmVudCwgRWNhYnNEYXRlUGlja2VySGVhZGVyQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBFbGVtZW50V3JhcHBlck1vZHVsZSxcclxuICAgIE1hdEljb25Nb2R1bGUsXHJcbiAgICBNYXREYXRlcGlja2VyTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgRWNhYnNQaWNrZXJIZWFkZXJNb2R1bGUsXHJcbiAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICBNYXRJbnB1dE1vZHVsZSxcclxuICAgIEVjYWJzRGF0ZVBpY2tlckFjdGlvbnNNb2R1bGUsXHJcbiAgXSxcclxuICBleHBvcnRzOiBbRWNhYnNEYXRlUGlja2VyQ29tcG9uZW50LCBFY2Fic0RhdGVQaWNrZXJIZWFkZXJDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNEYXRlUGlja2VyTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { Component, ContentChild, Input, } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { MatTable } from '@angular/material/table';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
|
-
import * as i2 from "@angular/material/
|
|
5
|
+
import * as i2 from "@angular/material/progress-bar";
|
|
6
6
|
import * as i3 from "../ecabs-empty-placeholder/ecabs-empty-placeholder.component";
|
|
7
7
|
export class TableComponent {
|
|
8
8
|
table;
|
|
9
9
|
header;
|
|
10
10
|
paginator;
|
|
11
|
-
bordered =
|
|
11
|
+
bordered = true;
|
|
12
12
|
loading = false;
|
|
13
13
|
isEmpty;
|
|
14
14
|
isEmptyMessage;
|
|
@@ -20,7 +20,7 @@ export class TableComponent {
|
|
|
20
20
|
}
|
|
21
21
|
}
|
|
22
22
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
23
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TableComponent, selector: "ecabs-table", inputs: { header: "header", paginator: "paginator", bordered: "bordered", loading: "loading", isEmpty: "isEmpty", isEmptyMessage: "isEmptyMessage", redirectPath: "redirectPath", srcImageEmpty: "srcImageEmpty" }, queries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true }], ngImport: i0, template: "<section class=\"table-ui table-ui--wrapper\" [ngClass]=\"{ 'table-ui__bordered': bordered, loading: loading }\">\r\n <mat-progress-bar *ngIf=\"loading\" mode=\"indeterminate\" class=\"table-ui__progress\"></mat-progress-bar>\r\n\r\n <div *ngIf=\"header\" class=\"table-ui__header\">\r\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!(isEmptyMessage && isEmpty); else noDataTemplate\">\r\n <ng-content></ng-content>\r\n\r\n <div *ngIf=\"paginator\" class=\"table-ui__paginator\">\r\n <ng-container *ngTemplateOutlet=\"paginator\"></ng-container>\r\n </div>\r\n </ng-container>\r\n\r\n <!--#For Empty state -->\r\n <ng-template #noDataTemplate>\r\n <ecabs-empty-placeholder\r\n *ngIf=\"!loading\"\r\n [redirectPath]=\"redirectPath\"\r\n [isEmptyMessage]=\"isEmptyMessage\"\r\n [srcImage]=\"srcImageEmpty\"\r\n ></ecabs-empty-placeholder>\r\n </ng-template>\r\n</section>\r\n", styles: [":host mat-progress-bar{position:absolute;width:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.
|
|
23
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TableComponent, selector: "ecabs-table", inputs: { header: "header", paginator: "paginator", bordered: "bordered", loading: "loading", isEmpty: "isEmpty", isEmptyMessage: "isEmptyMessage", redirectPath: "redirectPath", srcImageEmpty: "srcImageEmpty" }, queries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true }], ngImport: i0, template: "<section class=\"table-ui table-ui--wrapper\" [ngClass]=\"{ 'table-ui__bordered': bordered, loading: loading }\">\r\n <mat-progress-bar *ngIf=\"loading\" mode=\"indeterminate\" class=\"table-ui__progress\"></mat-progress-bar>\r\n\r\n <div *ngIf=\"header\" class=\"table-ui__header\">\r\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!(isEmptyMessage && isEmpty); else noDataTemplate\">\r\n <ng-content></ng-content>\r\n\r\n <div *ngIf=\"paginator\" class=\"table-ui__paginator\">\r\n <ng-container *ngTemplateOutlet=\"paginator\"></ng-container>\r\n </div>\r\n </ng-container>\r\n\r\n <!--#For Empty state -->\r\n <ng-template #noDataTemplate>\r\n <ecabs-empty-placeholder\r\n *ngIf=\"!loading\"\r\n [redirectPath]=\"redirectPath\"\r\n [isEmptyMessage]=\"isEmptyMessage\"\r\n [srcImage]=\"srcImageEmpty\"\r\n ></ecabs-empty-placeholder>\r\n </ng-template>\r\n</section>\r\n", styles: [":host mat-progress-bar{position:absolute;width:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i3.EcabsEmptyPlaceholderComponent, selector: "ecabs-empty-placeholder", inputs: ["isEmptyMessage", "redirectPath", "srcImage"] }] });
|
|
24
24
|
}
|
|
25
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TableComponent, decorators: [{
|
|
26
26
|
type: Component,
|
|
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
45
45
|
}], srcImageEmpty: [{
|
|
46
46
|
type: Input
|
|
47
47
|
}] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtdGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLXRhYmxlL2VjYWJzLXRhYmxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy10YWJsZS9lY2Ficy10YWJsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHlCQUF5QixDQUFDOzs7OztBQVFuRCxNQUFNLE9BQU8sY0FBYztJQUV6QixLQUFLLENBQWdCO0lBR3JCLE1BQU0sQ0FBbUI7SUFHekIsU0FBUyxDQUFtQjtJQUc1QixRQUFRLEdBQUcsSUFBSSxDQUFDO0lBR2hCLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFHaEIsT0FBTyxDQUFVO0lBRWpCLGNBQWMsQ0FBUztJQUd2QixZQUFZLENBQTBCO0lBR3RDLGFBQWEsQ0FBUztJQUV0QixxQkFBcUI7UUFDbkIsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2QsSUFBSSxDQUFDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQUUsTUFBTSxDQUFDO1NBQzdDO0lBQ0gsQ0FBQzt3R0EvQlUsY0FBYzs0RkFBZCxjQUFjLDBTQUNYLFFBQVEsZ0RDaEJ4QixxOUJBeUJBOzs0RkRWYSxjQUFjO2tCQUwxQixTQUFTOytCQUNFLGFBQWE7OEJBTXZCLEtBQUs7c0JBREosWUFBWTt1QkFBQyxRQUFRO2dCQUl0QixNQUFNO3NCQURMLEtBQUs7Z0JBSU4sU0FBUztzQkFEUixLQUFLO2dCQUlOLFFBQVE7c0JBRFAsS0FBSztnQkFJTixPQUFPO3NCQUROLEtBQUs7Z0JBSU4sT0FBTztzQkFETixLQUFLO2dCQUdOLGNBQWM7c0JBRGIsS0FBSztnQkFJTixZQUFZO3NCQURYLEtBQUs7Z0JBSU4sYUFBYTtzQkFEWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBBZnRlckNvbnRlbnRDaGVja2VkLFxyXG4gIENvbXBvbmVudCxcclxuICBDb250ZW50Q2hpbGQsXHJcbiAgSW5wdXQsXHJcbiAgVGVtcGxhdGVSZWYsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdFRhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFibGUnO1xyXG5pbXBvcnQgeyBQbGFjZWhvbGRlclJlZGlyZWN0UGF0aCB9IGZyb20gJy4uL2VjYWJzLWVtcHR5LXBsYWNlaG9sZGVyL2VjYWJzLWVtcHR5LXBsYWNlaG9sZGVyLmNvbXBvbmVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2VjYWJzLXRhYmxlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZWNhYnMtdGFibGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2VjYWJzLXRhYmxlLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyQ29udGVudENoZWNrZWQge1xyXG4gIEBDb250ZW50Q2hpbGQoTWF0VGFibGUpXHJcbiAgdGFibGU6IE1hdFRhYmxlPGFueT47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgaGVhZGVyOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHBhZ2luYXRvcjogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgQElucHV0KClcclxuICBib3JkZXJlZCA9IHRydWU7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgbG9hZGluZyA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIGlzRW1wdHk6IGJvb2xlYW47XHJcbiAgQElucHV0KClcclxuICBpc0VtcHR5TWVzc2FnZTogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHJlZGlyZWN0UGF0aDogUGxhY2Vob2xkZXJSZWRpcmVjdFBhdGg7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgc3JjSW1hZ2VFbXB0eTogc3RyaW5nO1xyXG5cclxuICBuZ0FmdGVyQ29udGVudENoZWNrZWQoKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy50YWJsZSkge1xyXG4gICAgICB0aGlzLmlzRW1wdHkgPSAhdGhpcy50YWJsZVsnX2RhdGEnXT8ubGVuZ3RoO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCI8c2VjdGlvbiBjbGFzcz1cInRhYmxlLXVpIHRhYmxlLXVpLS13cmFwcGVyXCIgW25nQ2xhc3NdPVwieyAndGFibGUtdWlfX2JvcmRlcmVkJzogYm9yZGVyZWQsIGxvYWRpbmc6IGxvYWRpbmcgfVwiPlxyXG4gIDxtYXQtcHJvZ3Jlc3MtYmFyICpuZ0lmPVwibG9hZGluZ1wiIG1vZGU9XCJpbmRldGVybWluYXRlXCIgY2xhc3M9XCJ0YWJsZS11aV9fcHJvZ3Jlc3NcIj48L21hdC1wcm9ncmVzcy1iYXI+XHJcblxyXG4gIDxkaXYgKm5nSWY9XCJoZWFkZXJcIiBjbGFzcz1cInRhYmxlLXVpX19oZWFkZXJcIj5cclxuICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJoZWFkZXJcIj48L25nLWNvbnRhaW5lcj5cclxuICA8L2Rpdj5cclxuXHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiEoaXNFbXB0eU1lc3NhZ2UgJiYgaXNFbXB0eSk7IGVsc2Ugbm9EYXRhVGVtcGxhdGVcIj5cclxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuXHJcbiAgICA8ZGl2ICpuZ0lmPVwicGFnaW5hdG9yXCIgY2xhc3M9XCJ0YWJsZS11aV9fcGFnaW5hdG9yXCI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJwYWdpbmF0b3JcIj48L25nLWNvbnRhaW5lcj5cclxuICAgIDwvZGl2PlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG5cclxuICA8IS0tI0ZvciBFbXB0eSBzdGF0ZSAtLT5cclxuICA8bmctdGVtcGxhdGUgI25vRGF0YVRlbXBsYXRlPlxyXG4gICAgPGVjYWJzLWVtcHR5LXBsYWNlaG9sZGVyXHJcbiAgICAgICpuZ0lmPVwiIWxvYWRpbmdcIlxyXG4gICAgICBbcmVkaXJlY3RQYXRoXT1cInJlZGlyZWN0UGF0aFwiXHJcbiAgICAgIFtpc0VtcHR5TWVzc2FnZV09XCJpc0VtcHR5TWVzc2FnZVwiXHJcbiAgICAgIFtzcmNJbWFnZV09XCJzcmNJbWFnZUVtcHR5XCJcclxuICAgID48L2VjYWJzLWVtcHR5LXBsYWNlaG9sZGVyPlxyXG4gIDwvbmctdGVtcGxhdGU+XHJcbjwvc2VjdGlvbj5cclxuIl19
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { TableComponent } from './ecabs-table.component';
|
|
4
|
-
import {
|
|
4
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
5
5
|
import { RouterModule } from '@angular/router';
|
|
6
6
|
import { EcabsEmptyPlaceholderModule } from '../ecabs-empty-placeholder/ecabs-empty-placeholder.module';
|
|
7
|
-
import {
|
|
7
|
+
import { MatTableModule } from '@angular/material/table';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export class EcabsTableModule {
|
|
10
10
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
30
30
|
exports: [TableComponent, MatTableModule, EcabsEmptyPlaceholderModule],
|
|
31
31
|
}]
|
|
32
32
|
}] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtdGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLXRhYmxlL2VjYWJzLXRhYmxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3hHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFZekQsTUFBTSxPQUFPLGdCQUFnQjt3R0FBaEIsZ0JBQWdCO3lHQUFoQixnQkFBZ0IsaUJBVFosY0FBYyxhQUUzQixZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLFlBQVk7WUFDWiwyQkFBMkIsYUFFbkIsY0FBYyxFQUFFLGNBQWMsRUFBRSwyQkFBMkI7eUdBRTFELGdCQUFnQixZQVB6QixZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLFlBQVk7WUFDWiwyQkFBMkIsRUFFSCxjQUFjLEVBQUUsMkJBQTJCOzs0RkFFMUQsZ0JBQWdCO2tCQVY1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixZQUFZO3dCQUNaLDJCQUEyQjtxQkFDNUI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsY0FBYyxFQUFFLGNBQWMsRUFBRSwyQkFBMkIsQ0FBQztpQkFDdkUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtdGFibGUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1iYXInO1xyXG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBFY2Fic0VtcHR5UGxhY2Vob2xkZXJNb2R1bGUgfSBmcm9tICcuLi9lY2Ficy1lbXB0eS1wbGFjZWhvbGRlci9lY2Ficy1lbXB0eS1wbGFjZWhvbGRlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBNYXRUYWJsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYmxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbVGFibGVDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIE1hdFByb2dyZXNzQmFyTW9kdWxlLFxyXG4gICAgUm91dGVyTW9kdWxlLFxyXG4gICAgRWNhYnNFbXB0eVBsYWNlaG9sZGVyTW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1RhYmxlQ29tcG9uZW50LCBNYXRUYWJsZU1vZHVsZSwgRWNhYnNFbXB0eVBsYWNlaG9sZGVyTW9kdWxlXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEVjYWJzVGFibGVNb2R1bGUge31cclxuIl19
|