ecabs-components 1.1.30 → 1.1.32
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 +60 -56
- package/esm2022/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.mjs +33 -37
- package/fesm2022/ecabs-components.mjs +31 -35
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.d.ts +2 -4
- package/package.json +1 -1
- package/src/assets/styles/scss/modules/_button.scss +8 -0
package/README.md
CHANGED
|
@@ -23,68 +23,72 @@ Run `ng test ecabs-components` to execute the unit tests via [Karma](https://kar
|
|
|
23
23
|
|
|
24
24
|
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
|
|
25
25
|
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
v1.0.
|
|
29
|
-
v1.0.
|
|
30
|
-
v1.0.
|
|
31
|
-
v1.0.
|
|
32
|
-
v1.0.
|
|
26
|
+
## Version History
|
|
27
|
+
|
|
28
|
+
- **v1.0.13** — Fixed emitEvent behaviour of checkbox
|
|
29
|
+
- **v1.0.18** — Fixed width of date time picker
|
|
30
|
+
- **v1.0.75** — Upgrade `EcabsButtons` module to `MDC` styling.
|
|
31
|
+
- **v1.0.76** — Upgrade `EcabsInput` module to `MDC` styling.
|
|
32
|
+
- **v1.0.77** — Upgrade `MatChips` to `MDC`.
|
|
33
|
+
- **v1.0.78** — Upgrade `MatSelect` to `MDC`.
|
|
34
|
+
- **v1.0.79** — feat(CU-11266): Update `MatDialog` to `MDC`.
|
|
33
35
|
- Fix button height issue on anchor tags marked as `mat-button`.
|
|
34
36
|
- Update default font family.
|
|
35
37
|
- Rename `NoteComponent` to `EcabsNoteComponent`.
|
|
36
38
|
- Add `expired` style for `EcabsChip`.
|
|
37
|
-
v1.0.80 — Allow custom button options for `Confirm` and `Cancel` buttons on `EcabsDialog`.
|
|
38
|
-
v1.0.81 — Fix font size of `EcabsSelect`.
|
|
39
|
-
v1.0.82 — Improve the appearance of disabled inputs.
|
|
39
|
+
- **v1.0.80** — Allow custom button options for `Confirm` and `Cancel` buttons on `EcabsDialog`.
|
|
40
|
+
- **v1.0.81** — Fix font size of `EcabsSelect`.
|
|
41
|
+
- **v1.0.82** — Improve the appearance of disabled inputs.
|
|
40
42
|
- Fix placeholder text of `EcabsSelect`.
|
|
41
|
-
v1.0.83 — Fix buttons height.
|
|
42
|
-
v1.0.84 — Emit `falsey` result when Close button is clicked on `EcabsDialogConfirm` and `EcabsDialogMessage`.
|
|
43
|
-
v1.0.85 — Improve styling for `EcabsTable` row colors.
|
|
44
|
-
v1.0.87 — Apply min/max Date logic for date picker
|
|
45
|
-
v1.0.88 — Roll back 1.0.87
|
|
46
|
-
v1.0.89 — Upgrade `MatLegacyTable` and `MatLegacyProgress` to `MDC`.
|
|
47
|
-
v1.0.90 — Upgrade `MatLegacyPaginator` to `MDC`.
|
|
43
|
+
- **v1.0.83** — Fix buttons height.
|
|
44
|
+
- **v1.0.84** — Emit `falsey` result when Close button is clicked on `EcabsDialogConfirm` and `EcabsDialogMessage`.
|
|
45
|
+
- **v1.0.85** — Improve styling for `EcabsTable` row colors.
|
|
46
|
+
- **v1.0.87** — Apply min/max Date logic for date picker
|
|
47
|
+
- **v1.0.88** — Roll back 1.0.87
|
|
48
|
+
- **v1.0.89** — Upgrade `MatLegacyTable` and `MatLegacyProgress` to `MDC`.
|
|
49
|
+
- **v1.0.90** — Upgrade `MatLegacyPaginator` to `MDC`.
|
|
48
50
|
- Add `EcabsPaginatorDirective`.
|
|
49
51
|
- Rename `AppHint` to `EcabsHint`.
|
|
50
52
|
- Apply `ngx-toaster` overrides.
|
|
51
|
-
v1.0.91 — Upgrade `MatLegacyCheckbox` and `MatSlideToggle` to `MDC`.
|
|
52
|
-
v1.0.92 — Add default buttons for Confirm and Cancel buttons on dialog.
|
|
53
|
-
v1.0.93 — Update progress colors for percentage.
|
|
54
|
-
v1.0.94 — Upgrade `MatLegacyTabs` to `MDC`.
|
|
55
|
-
v1.0.95 — Upgrade `MatLegacyTooltip` to `MDC`.
|
|
56
|
-
v1.0.96 — Add missing styles for nested columns on `Table`.
|
|
57
|
-
v1.0.97 — Correct misaligned icon and text on `EcabsNotes`.
|
|
58
|
-
v1.0.98 — Upgrade `MatLegacyAutocomplete` to `MDC`.
|
|
59
|
-
v1.0.99 — Add `mini` and `maxi` directive and validators to `EcabsInput`.
|
|
60
|
-
v1.1.0 — Upgrade `MatLegacyMenu` to `MDC`.
|
|
61
|
-
v1.1.1 — Hide `Timepicker` options on input blur.
|
|
62
|
-
v1.1.2 — Introduce new select component (`EcabsSelectV2`) to deprecate `EcabsSelect`.
|
|
63
|
-
v1.1.3 — Upgrade `MatLegacyCard` to `MDC`.
|
|
64
|
-
v1.1.4 — Fixed blur issue for input.
|
|
65
|
-
v1.1.5 — added slider
|
|
66
|
-
v1.1.6 — accumulate all directives
|
|
67
|
-
v1.1.7 — Add a message for alphanumeric-only validation.
|
|
68
|
-
v1.1.8 — Add directive show-on-truncated to directives.
|
|
69
|
-
v1.1.9 — Fixed i18n issue.
|
|
70
|
-
v1.1.10 — Added color styles for prompt title message.
|
|
71
|
-
v1.1.12 — Extend @Input properties of `EcabsSelectV2` from `@ng-select` lib.
|
|
72
|
-
v1.1.13 — Fix `overflow-y` issue on `MatCardContent`.
|
|
73
|
-
v1.1.14 — Update styles for disabled indeterminate checkboxes.
|
|
74
|
-
v1.1.15 — Cleanup `EcabsComponentsService` and provide default config via `config` property.
|
|
75
|
-
v1.1.16 — Implemented custom phone number control.
|
|
76
|
-
v1.1.17 — Fix peerDependency on `libphonenumber-js`.
|
|
77
|
-
v1.1.18 — Adjust position of `sticky` header on `MatTable`.
|
|
78
|
-
v1.1.19 — Increase delay for phone control and to config.
|
|
79
|
-
v1.1.20 — Improve the appearance for the scrollbar.
|
|
80
|
-
v1.1.21 — Improve style for hovered disabled calendar date.
|
|
81
|
-
v1.1.22 — Added statuses for mat-chips.
|
|
53
|
+
- **v1.0.91** — Upgrade `MatLegacyCheckbox` and `MatSlideToggle` to `MDC`.
|
|
54
|
+
- **v1.0.92** — Add default buttons for Confirm and Cancel buttons on dialog.
|
|
55
|
+
- **v1.0.93** — Update progress colors for percentage.
|
|
56
|
+
- **v1.0.94** — Upgrade `MatLegacyTabs` to `MDC`.
|
|
57
|
+
- **v1.0.95** — Upgrade `MatLegacyTooltip` to `MDC`.
|
|
58
|
+
- **v1.0.96** — Add missing styles for nested columns on `Table`.
|
|
59
|
+
- **v1.0.97** — Correct misaligned icon and text on `EcabsNotes`.
|
|
60
|
+
- **v1.0.98** — Upgrade `MatLegacyAutocomplete` to `MDC`.
|
|
61
|
+
- **v1.0.99** — Add `mini` and `maxi` directive and validators to `EcabsInput`.
|
|
62
|
+
- **v1.1.0** — Upgrade `MatLegacyMenu` to `MDC`.
|
|
63
|
+
- **v1.1.1** — Hide `Timepicker` options on input blur.
|
|
64
|
+
- **v1.1.2** — Introduce new select component (`EcabsSelectV2`) to deprecate `EcabsSelect`.
|
|
65
|
+
- **v1.1.3** — Upgrade `MatLegacyCard` to `MDC`.
|
|
66
|
+
- **v1.1.4** — Fixed blur issue for input.
|
|
67
|
+
- **v1.1.5** — added slider
|
|
68
|
+
- **v1.1.6** — accumulate all directives
|
|
69
|
+
- **v1.1.7** — Add a message for alphanumeric-only validation.
|
|
70
|
+
- **v1.1.8** — Add directive show-on-truncated to directives.
|
|
71
|
+
- **v1.1.9** — Fixed i18n issue.
|
|
72
|
+
- **v1.1.10** — Added color styles for prompt title message.
|
|
73
|
+
- **v1.1.12** — Extend @Input properties of `EcabsSelectV2` from `@ng-select` lib.
|
|
74
|
+
- **v1.1.13** — Fix `overflow-y` issue on `MatCardContent`.
|
|
75
|
+
- **v1.1.14** — Update styles for disabled indeterminate checkboxes.
|
|
76
|
+
- **v1.1.15** — Cleanup `EcabsComponentsService` and provide default config via `config` property.
|
|
77
|
+
- **v1.1.16** — Implemented custom phone number control.
|
|
78
|
+
- **v1.1.17** — Fix peerDependency on `libphonenumber-js`.
|
|
79
|
+
- **v1.1.18** — Adjust position of `sticky` header on `MatTable`.
|
|
80
|
+
- **v1.1.19** — Increase delay for phone control and to config.
|
|
81
|
+
- **v1.1.20** — Improve the appearance for the scrollbar.
|
|
82
|
+
- **v1.1.21** — Improve style for hovered disabled calendar date.
|
|
83
|
+
- **v1.1.22** — Added statuses for mat-chips.
|
|
82
84
|
- Added badges for menu items.
|
|
83
|
-
v1.1.23 — Update styling for map markers.
|
|
84
|
-
v1.1.24 — Fixed date range picker when reset value.
|
|
85
|
-
v1.1.25 — Fixed date range picker when choose one date only.
|
|
86
|
-
v1.1.26 — Implement dynamic titles for `EcabsDialogComponent`.
|
|
87
|
-
v1.1.27 — Added results for the dialog message.
|
|
88
|
-
v1.1.28 — Fixed issue related to the prev version.
|
|
89
|
-
v1.1.29 — Added handling manual updates data of date range picker.
|
|
90
|
-
v1.1.30 — Added blur event handling and support for special keys in `EcabsTimePickerComponent`.
|
|
85
|
+
- **v1.1.23** — Update styling for map markers.
|
|
86
|
+
- **v1.1.24** — Fixed date range picker when reset value.
|
|
87
|
+
- **v1.1.25** — Fixed date range picker when choose one date only.
|
|
88
|
+
- **v1.1.26** — Implement dynamic titles for `EcabsDialogComponent`.
|
|
89
|
+
- **v1.1.27** — Added results for the dialog message.
|
|
90
|
+
- **v1.1.28** — Fixed issue related to the prev version.
|
|
91
|
+
- **v1.1.29** — Added handling manual updates data of date range picker.
|
|
92
|
+
- **v1.1.30** — Added blur event handling and support for special keys in `EcabsTimePickerComponent`.
|
|
93
|
+
- **v1.1.31** — Prevent hover state persistence on disabled buttons.
|
|
94
|
+
- **v1.1.32** — Return falsey value when no input is available in `DateTime` selector.
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { format, isValid, parse, setHours, setMinutes, setSeconds, } from 'date-fns';
|
|
2
2
|
import { takeUntil } from 'rxjs';
|
|
3
3
|
import { DecimalPipe } from '@angular/common';
|
|
4
|
-
import { Component,
|
|
4
|
+
import { Component, forwardRef, Input, } from '@angular/core';
|
|
5
5
|
import { NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';
|
|
6
6
|
import EcabsElementBaseComponent from '../base/element-base';
|
|
7
7
|
import { UnsubscribeService } from '../base/services/unsubscribe.service';
|
|
@@ -32,7 +32,6 @@ export class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
32
32
|
cancelLabel;
|
|
33
33
|
applyLabel;
|
|
34
34
|
applyMinDateAuto = true;
|
|
35
|
-
onblur = new EventEmitter();
|
|
36
35
|
_hours = '12';
|
|
37
36
|
_minutes = '00';
|
|
38
37
|
_seconds = '00';
|
|
@@ -84,33 +83,36 @@ export class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
84
83
|
}
|
|
85
84
|
}
|
|
86
85
|
set pickerValue(val) {
|
|
87
|
-
if (val) {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
this.refreshPickerValue(this.minDate);
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
if (this.maxDate && date > this.maxDate) {
|
|
100
|
-
this.setValues(this.maxDate);
|
|
101
|
-
this._pickerValue = val;
|
|
102
|
-
this.preventCallSetterPickerValue = true;
|
|
103
|
-
this.value = this.maxDate;
|
|
104
|
-
this.runTimeout = true;
|
|
105
|
-
this.refreshPickerValue(this.maxDate);
|
|
106
|
-
return;
|
|
107
|
-
}
|
|
108
|
-
this.runTimeout = false;
|
|
86
|
+
if (!val) {
|
|
87
|
+
this.value = undefined;
|
|
88
|
+
this.setValues(undefined);
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
|
|
92
|
+
if (isValid(date) && this._pickerValue !== val) {
|
|
93
|
+
if (this.minDate && date < this.minDate && this.applyMinDateAuto) {
|
|
94
|
+
this.setValues(this.minDate);
|
|
109
95
|
this._pickerValue = val;
|
|
110
96
|
this.preventCallSetterPickerValue = true;
|
|
111
|
-
this.value =
|
|
112
|
-
this.
|
|
97
|
+
this.value = this.minDate;
|
|
98
|
+
this.runTimeout = true;
|
|
99
|
+
this.refreshPickerValue(this.minDate);
|
|
100
|
+
return;
|
|
113
101
|
}
|
|
102
|
+
if (this.maxDate && date > this.maxDate) {
|
|
103
|
+
this.setValues(this.maxDate);
|
|
104
|
+
this._pickerValue = val;
|
|
105
|
+
this.preventCallSetterPickerValue = true;
|
|
106
|
+
this.value = this.maxDate;
|
|
107
|
+
this.runTimeout = true;
|
|
108
|
+
this.refreshPickerValue(this.maxDate);
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
this.runTimeout = false;
|
|
112
|
+
this._pickerValue = val;
|
|
113
|
+
this.preventCallSetterPickerValue = true;
|
|
114
|
+
this.value = date;
|
|
115
|
+
this.setValues(date);
|
|
114
116
|
}
|
|
115
117
|
}
|
|
116
118
|
constructor(injector, decimalPipe, cd, ecabsDatePickerHeaderService, unsubscribeService) {
|
|
@@ -150,13 +152,9 @@ export class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
150
152
|
registerOnTouched(fn) {
|
|
151
153
|
this.onTouch = fn;
|
|
152
154
|
}
|
|
153
|
-
blurChange(e) {
|
|
154
|
-
this.onblur.emit(e);
|
|
155
|
-
}
|
|
156
155
|
onApply() {
|
|
157
156
|
if (this._date && this._seconds && this._minutes && this._hours) {
|
|
158
|
-
|
|
159
|
-
this.value = date;
|
|
157
|
+
this.value = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);
|
|
160
158
|
}
|
|
161
159
|
}
|
|
162
160
|
refreshPickerValue(date) {
|
|
@@ -190,10 +188,10 @@ export class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
190
188
|
}
|
|
191
189
|
}
|
|
192
190
|
static ɵ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 }, { token: i2.EcabsDatePickerHeaderService }, { token: i3.UnsubscribeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
193
|
-
static ɵ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", cancelLabel: "cancelLabel", applyLabel: "applyLabel", applyMinDateAuto: "applyMinDateAuto" },
|
|
191
|
+
static ɵ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", cancelLabel: "cancelLabel", applyLabel: "applyLabel", applyMinDateAuto: "applyMinDateAuto" }, providers: [
|
|
194
192
|
{
|
|
195
193
|
provide: NG_VALUE_ACCESSOR,
|
|
196
|
-
useExisting: EcabsDateTimePickerComponent,
|
|
194
|
+
useExisting: forwardRef(() => EcabsDateTimePickerComponent),
|
|
197
195
|
multi: true,
|
|
198
196
|
},
|
|
199
197
|
DecimalPipe,
|
|
@@ -205,7 +203,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
205
203
|
args: [{ selector: 'ecabs-date-time-picker', providers: [
|
|
206
204
|
{
|
|
207
205
|
provide: NG_VALUE_ACCESSOR,
|
|
208
|
-
useExisting: EcabsDateTimePickerComponent,
|
|
206
|
+
useExisting: forwardRef(() => EcabsDateTimePickerComponent),
|
|
209
207
|
multi: true,
|
|
210
208
|
},
|
|
211
209
|
DecimalPipe,
|
|
@@ -225,7 +223,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
225
223
|
type: Input
|
|
226
224
|
}], applyMinDateAuto: [{
|
|
227
225
|
type: Input
|
|
228
|
-
}], onblur: [{
|
|
229
|
-
type: Output
|
|
230
226
|
}] } });
|
|
231
|
-
//# 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 {\r\n  format,\r\n  isValid,\r\n  parse,\r\n  setHours,\r\n  setMinutes,\r\n  setSeconds,\r\n} from 'date-fns';\r\nimport { takeUntil } from 'rxjs';\r\n\r\nimport { DecimalPipe } from '@angular/common';\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 EcabsElementBaseComponent from '../base/element-base';\r\nimport { EcabsDatePickerTranslations } from '../base/models/ecabs-date-picker-translations.models';\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\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    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDateTimePickerComponent\r\n  extends EcabsElementBaseComponent\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() hideSeconds = true;\r\n  @Input() cancelLabel: string;\r\n  @Input() applyLabel: string;\r\n  @Input() applyMinDateAuto = true;\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  translationConfig: EcabsDatePickerTranslations;\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\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 decimalPipe: DecimalPipe,\r\n    private readonly cd: ChangeDetectorRef,\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      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  onApply(): void {\r\n    if (this._date && this._seconds && this._minutes && this._hours) {\r\n      const date = setSeconds(\r\n        setMinutes(\r\n          setHours(new Date(this._date), +this._hours),\r\n          +this._minutes,\r\n        ),\r\n        +this._seconds,\r\n      );\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\r\n    if (date && isValid(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}\r\n","<ecabs-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\" class=\"datepicker-ui\">\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              ecabsDigitsOnly\r\n              ecabsNumberBorder\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              ecabsDigitsOnly\r\n              ecabsNumberBorder\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                ecabsDigitsOnly\r\n                ecabsNumberBorder\r\n                [digitsOnly]=\"true\"\r\n                [maxValue]=\"maxValueMinutesSeconds\"\r\n              />\r\n            </ng-container>\r\n          </div>\r\n\r\n          <ecabs-date-picker-actions [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n                                     [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n                                     (apply)=\"onApply()\">\r\n          </ecabs-date-picker-actions>\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      ecabsMaskDate\r\n      [isDateTimeMask]=\"true\"\r\n      [considerSeconds]=\"!hideSeconds\"\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</ecabs-element-wrapper>\r\n"]}
|
|
227
|
+
//# 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 {format, isValid, parse, setHours, setMinutes, setSeconds,} from 'date-fns';\r\nimport {takeUntil} from 'rxjs';\r\n\r\nimport {DecimalPipe} from '@angular/common';\r\nimport {AfterViewInit, ChangeDetectorRef, Component, forwardRef, Injector, Input, OnInit,} from '@angular/core';\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl,} from '@angular/forms';\r\n\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport {EcabsDatePickerTranslations} from '../base/models/ecabs-date-picker-translations.models';\r\nimport {EcabsDatePickerHeaderService} from '../base/services/ecabs-date-picker-translations.service';\r\nimport {UnsubscribeService} from '../base/services/unsubscribe.service';\r\nimport {\r\n  EcabsDateTimePickerHeaderComponent\r\n} 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: forwardRef(() => EcabsDateTimePickerComponent),\r\n      multi: true,\r\n    },\r\n    DecimalPipe,\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDateTimePickerComponent\r\n  extends EcabsElementBaseComponent\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() hideSeconds = true;\r\n  @Input() cancelLabel: string;\r\n  @Input() applyLabel: string;\r\n  @Input() applyMinDateAuto = true;\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  translationConfig: EcabsDatePickerTranslations;\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      this.value = undefined;\r\n      this.setValues(undefined);\r\n\r\n      return;\r\n    }\r\n\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\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  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly cd: ChangeDetectorRef,\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      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\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  onApply(): void {\r\n    if (this._date && this._seconds && this._minutes && this._hours) {\r\n      this.value = setSeconds(\r\n        setMinutes(\r\n          setHours(new Date(this._date), +this._hours),\r\n          +this._minutes,\r\n        ),\r\n        +this._seconds,\r\n      );\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\r\n    if (date && isValid(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}\r\n","<ecabs-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\" class=\"datepicker-ui\">\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              ecabsDigitsOnly\r\n              ecabsNumberBorder\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              ecabsDigitsOnly\r\n              ecabsNumberBorder\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                ecabsDigitsOnly\r\n                ecabsNumberBorder\r\n                [digitsOnly]=\"true\"\r\n                [maxValue]=\"maxValueMinutesSeconds\"\r\n              />\r\n            </ng-container>\r\n          </div>\r\n\r\n          <ecabs-date-picker-actions [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n                                     [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n                                     (apply)=\"onApply()\">\r\n          </ecabs-date-picker-actions>\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      ecabsMaskDate\r\n      [isDateTimeMask]=\"true\"\r\n      [considerSeconds]=\"!hideSeconds\"\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</ecabs-element-wrapper>\r\n"]}
|
|
@@ -2527,7 +2527,6 @@ class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
2527
2527
|
cancelLabel;
|
|
2528
2528
|
applyLabel;
|
|
2529
2529
|
applyMinDateAuto = true;
|
|
2530
|
-
onblur = new EventEmitter();
|
|
2531
2530
|
_hours = '12';
|
|
2532
2531
|
_minutes = '00';
|
|
2533
2532
|
_seconds = '00';
|
|
@@ -2579,33 +2578,36 @@ class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
2579
2578
|
}
|
|
2580
2579
|
}
|
|
2581
2580
|
set pickerValue(val) {
|
|
2582
|
-
if (val) {
|
|
2583
|
-
|
|
2584
|
-
|
|
2585
|
-
|
|
2586
|
-
|
|
2587
|
-
|
|
2588
|
-
|
|
2589
|
-
|
|
2590
|
-
|
|
2591
|
-
this.refreshPickerValue(this.minDate);
|
|
2592
|
-
return;
|
|
2593
|
-
}
|
|
2594
|
-
if (this.maxDate && date > this.maxDate) {
|
|
2595
|
-
this.setValues(this.maxDate);
|
|
2596
|
-
this._pickerValue = val;
|
|
2597
|
-
this.preventCallSetterPickerValue = true;
|
|
2598
|
-
this.value = this.maxDate;
|
|
2599
|
-
this.runTimeout = true;
|
|
2600
|
-
this.refreshPickerValue(this.maxDate);
|
|
2601
|
-
return;
|
|
2602
|
-
}
|
|
2603
|
-
this.runTimeout = false;
|
|
2581
|
+
if (!val) {
|
|
2582
|
+
this.value = undefined;
|
|
2583
|
+
this.setValues(undefined);
|
|
2584
|
+
return;
|
|
2585
|
+
}
|
|
2586
|
+
const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
|
|
2587
|
+
if (isValid(date) && this._pickerValue !== val) {
|
|
2588
|
+
if (this.minDate && date < this.minDate && this.applyMinDateAuto) {
|
|
2589
|
+
this.setValues(this.minDate);
|
|
2604
2590
|
this._pickerValue = val;
|
|
2605
2591
|
this.preventCallSetterPickerValue = true;
|
|
2606
|
-
this.value =
|
|
2607
|
-
this.
|
|
2592
|
+
this.value = this.minDate;
|
|
2593
|
+
this.runTimeout = true;
|
|
2594
|
+
this.refreshPickerValue(this.minDate);
|
|
2595
|
+
return;
|
|
2608
2596
|
}
|
|
2597
|
+
if (this.maxDate && date > this.maxDate) {
|
|
2598
|
+
this.setValues(this.maxDate);
|
|
2599
|
+
this._pickerValue = val;
|
|
2600
|
+
this.preventCallSetterPickerValue = true;
|
|
2601
|
+
this.value = this.maxDate;
|
|
2602
|
+
this.runTimeout = true;
|
|
2603
|
+
this.refreshPickerValue(this.maxDate);
|
|
2604
|
+
return;
|
|
2605
|
+
}
|
|
2606
|
+
this.runTimeout = false;
|
|
2607
|
+
this._pickerValue = val;
|
|
2608
|
+
this.preventCallSetterPickerValue = true;
|
|
2609
|
+
this.value = date;
|
|
2610
|
+
this.setValues(date);
|
|
2609
2611
|
}
|
|
2610
2612
|
}
|
|
2611
2613
|
constructor(injector, decimalPipe, cd, ecabsDatePickerHeaderService, unsubscribeService) {
|
|
@@ -2645,13 +2647,9 @@ class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
2645
2647
|
registerOnTouched(fn) {
|
|
2646
2648
|
this.onTouch = fn;
|
|
2647
2649
|
}
|
|
2648
|
-
blurChange(e) {
|
|
2649
|
-
this.onblur.emit(e);
|
|
2650
|
-
}
|
|
2651
2650
|
onApply() {
|
|
2652
2651
|
if (this._date && this._seconds && this._minutes && this._hours) {
|
|
2653
|
-
|
|
2654
|
-
this.value = date;
|
|
2652
|
+
this.value = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);
|
|
2655
2653
|
}
|
|
2656
2654
|
}
|
|
2657
2655
|
refreshPickerValue(date) {
|
|
@@ -2685,10 +2683,10 @@ class EcabsDateTimePickerComponent extends EcabsElementBaseComponent {
|
|
|
2685
2683
|
}
|
|
2686
2684
|
}
|
|
2687
2685
|
static ɵ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 }, { token: EcabsDatePickerHeaderService }, { token: UnsubscribeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
2688
|
-
static ɵ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", cancelLabel: "cancelLabel", applyLabel: "applyLabel", applyMinDateAuto: "applyMinDateAuto" },
|
|
2686
|
+
static ɵ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", cancelLabel: "cancelLabel", applyLabel: "applyLabel", applyMinDateAuto: "applyMinDateAuto" }, providers: [
|
|
2689
2687
|
{
|
|
2690
2688
|
provide: NG_VALUE_ACCESSOR,
|
|
2691
|
-
useExisting: EcabsDateTimePickerComponent,
|
|
2689
|
+
useExisting: forwardRef(() => EcabsDateTimePickerComponent),
|
|
2692
2690
|
multi: true,
|
|
2693
2691
|
},
|
|
2694
2692
|
DecimalPipe,
|
|
@@ -2700,7 +2698,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
2700
2698
|
args: [{ selector: 'ecabs-date-time-picker', providers: [
|
|
2701
2699
|
{
|
|
2702
2700
|
provide: NG_VALUE_ACCESSOR,
|
|
2703
|
-
useExisting: EcabsDateTimePickerComponent,
|
|
2701
|
+
useExisting: forwardRef(() => EcabsDateTimePickerComponent),
|
|
2704
2702
|
multi: true,
|
|
2705
2703
|
},
|
|
2706
2704
|
DecimalPipe,
|
|
@@ -2720,8 +2718,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
2720
2718
|
type: Input
|
|
2721
2719
|
}], applyMinDateAuto: [{
|
|
2722
2720
|
type: Input
|
|
2723
|
-
}], onblur: [{
|
|
2724
|
-
type: Output
|
|
2725
2721
|
}] } });
|
|
2726
2722
|
|
|
2727
2723
|
class EcabsMaskDateDirectiveModule {
|