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 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
- v1.0.13 Fixed emitEvent behaviour of checkbox
27
- v1.0.18 — Fixed width of date time picker
28
- v1.0.75Upgrade `EcabsButtons` module to `MDC` styling.
29
- v1.0.76Upgrade `EcabsInput` module to `MDC` styling.
30
- v1.0.77 — Upgrade `MatChips` to `MDC`.
31
- v1.0.78 — Upgrade `MatSelect` to `MDC`.
32
- v1.0.79feat(CU-11266): Update `MatDialog` to `MDC`.
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, EventEmitter, Input, Output, } from '@angular/core';
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
- const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
89
- if (isValid(date) && this._pickerValue !== val) {
90
- if (this.minDate && date < this.minDate && this.applyMinDateAuto) {
91
- this.setValues(this.minDate);
92
- this._pickerValue = val;
93
- this.preventCallSetterPickerValue = true;
94
- this.value = this.minDate;
95
- this.runTimeout = true;
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 = date;
112
- this.setValues(date);
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
- const date = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);
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" }, outputs: { onblur: "onblur" }, providers: [
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
- const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
2584
- if (isValid(date) && this._pickerValue !== val) {
2585
- if (this.minDate && date < this.minDate && this.applyMinDateAuto) {
2586
- this.setValues(this.minDate);
2587
- this._pickerValue = val;
2588
- this.preventCallSetterPickerValue = true;
2589
- this.value = this.minDate;
2590
- this.runTimeout = true;
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 = date;
2607
- this.setValues(date);
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
- const date = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);
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" }, outputs: { onblur: "onblur" }, providers: [
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 {