ecabs-components 1.1.66 → 1.1.68

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
@@ -25,107 +25,110 @@ To get more help on the Angular CLI use `ng help` or go check out the [Angular C
25
25
 
26
26
  ## Version History
27
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`.
28
+ - **v1.1.68** — Add `isVisible` callback for `SidebarMenuItem` to support dynamic visibility based on context.
29
+ - **v1.1.67** — Add support for optional "to" (end date) for `EcabsDateRangePickerV2Component`.
30
+ - Add allow cross-midnight time ranges for `EcabsTimeRangeInputV2Component`.
31
+ - **v1.1.66** — Suppress emission of an empty query on refocusing after selection of option from `EcabsChipAutocomplete`.
32
+ - **v1.1.65** — `EcabsInputRange`: Remove padding and background styling.
33
+ - **v1.1.64** — Refactor `EcabsChipAutocomplete` logic, improve component styles/disabled states, and update button styles.
34
+ - **v1.1.63** — Add `EcabsSegmentComponent`.
35
+ - Update `EcabsSelectV2` to be more robust when handling multiple selections.
36
+ - **v1.1.62** — Add `EcabsTimeRangeInputV2Component`.,
37
+ - **v1.1.61** — Added support for 12-hour time input for `maskito` library.
38
+ - **Affected components**: `EcabsDateTimePicker`, `EcabsTimepicker`, `EcabsDateTimeRangePicker`.
39
+ - **v1.1.60** — Migrate input mask library from `vanilla-text-mask` to `maskito`.
40
+ - **Affected components**: `EcabsDateTimePicker`, `EcabsTimepicker`, `EcabsDateTimeRangePicker`.
41
+ - **v1.1.59** — `EcabsCheckboxV2Component`: Implement version 2 of `EcabsCheckboxComponent`.
42
+ - **v1.1.58** — Add `EcabsInputRangeComponent` with support for minimum and maximum values.
43
+ - **v1.1.57** — Implement `EcabsChipGroup`and `EcabsAutocompleteChipGroup` components with demo.
44
+ - **v1.1.56** — Implement `EcabsDateRangePickerComponentV2`.
45
+ - **v1.1.55** — `EcabsButtonsV2Component`: Added version 2 of `EcabsButtonsComponent` with support for small, medium, and large sizes.
46
+ - **v1.1.54** — Implement `EcabsButtonToggleComponent` with support for small, medium, and large sizes.
47
+ - **v1.1.53** — Introduce new gray color palette and update references and apply styling improvements.
48
+ - **v1.1.52** — Update styling overrides for Material nav-style tabs, including active state.
49
+ - **v1.1.51** — Implement option of displaying dynamic content for `EcabsTableComponent` when empty.
50
+ - **v1.1.50** — Add `Documentation` for `EcabsTableModule`.
51
+ - **v1.1.49** — Add support for `splitButtonsWidth` in `EcabsDialogConfirmComponent` and update button styling.`.
52
+ - **v1.1.48** — Implement `EcabsPlaceAutocompleteV2Component` to support waypoints history, query change handling, and dropdown suggestions display.
53
+ - **v1.1.47** — Add `Title` and `dynamic` content support to `EcabsEmptyPlaceholderComponent`.
54
+ - **v1.1.46** — Add `ViewChild` reference for `MatRadioGroup` and update event type in `EcabsRadioButtonListComponent`.
55
+ - **v1.1.45** — Added default validation of date range
56
+ - **v1.1.44** — Fixed issue Apply button is still active when only the DateFrom is selected
57
+ - **v1.1.43** — Added disabling of Apply button for date range picker
58
+ - **v1.1.42** — Apply `width` and `height` properties directly to root `MatDialog` of `EcabsDialogConfirmComponent`.
59
+ - **v1.1.41** — Added EcabsDialogConfirmationDeletionComponent.
60
+ - **v1.1.40** — `EcabsDateTimePicker`: Added support for preserving and returning `receivedValue` when there is no change in the input.
61
+ - **v1.1.39** — Added date adapter to public api.
62
+ - **v1.1.38** — Use native `matDatepickerToggleIcon` in `EcabsDateTimePicker`.
63
+ - **v1.1.35** — Add `waypointType` input to `EcabsAutoComplete`.
64
+ - Add `nativeElement` handles to custom inputs.
65
+ - **v1.1.34** — Emit `selectionChange` event when selecting item from `EcabsSelectV2`.
66
+ - Add collapse styling for `EcabsLogo`.
67
+ - **v1.1.33** — Return falsey value when no input is available in `DateTime` selector through keyboard action deletion.
68
+ - **v1.1.32** — Return falsey value when no input is available in `DateTime` selector.
69
+ - **v1.1.31** — Prevent hover state persistence on disabled buttons.
70
+ - **v1.1.30** — Added blur event handling and support for special keys in `EcabsTimePickerComponent`.
71
+ - **v1.1.29** — Added handling manual updates data of date range picker.
72
+ - **v1.1.28** — Fixed issue related to the prev version.
73
+ - **v1.1.27** — Added results for the dialog message.
74
+ - **v1.1.26** — Implement dynamic titles for `EcabsDialogComponent`.
75
+ - **v1.1.25** — Fixed date range picker when choose one date only.
76
+ - **v1.1.24** — Fixed date range picker when reset value.
77
+ - **v1.1.23** — Update styling for map markers.
78
+ - **v1.1.22** — Added statuses for mat-chips.
79
+ - Added badges for menu items.
80
+ - **v1.1.21** — Improve style for hovered disabled calendar date.
81
+ - **v1.1.20** — Improve the appearance for the scrollbar.
82
+ - **v1.1.19** — Increase delay for phone control and to config.
83
+ - **v1.1.18** — Adjust position of `sticky` header on `MatTable`.
84
+ - **v1.1.17** — Fix peerDependency on `libphonenumber-js`.
85
+ - **v1.1.16** — Implemented custom phone number control.
86
+ - **v1.1.15** — Cleanup `EcabsComponentsService` and provide default config via `config` property.
87
+ - **v1.1.14** — Update styles for disabled indeterminate checkboxes.
88
+ - **v1.1.13** — Fix `overflow-y` issue on `MatCardContent`.
89
+ - **v1.1.12** — Extend @Input properties of `EcabsSelectV2` from `@ng-select` lib.
90
+ - **v1.1.10** — Added color styles for prompt title message.
91
+ - **v1.1.9** — Fixed i18n issue.
92
+ - **v1.1.8** — Add directive show-on-truncated to directives.
93
+ - **v1.1.7** — Add a message for alphanumeric-only validation.
94
+ - **v1.1.6** — accumulate all directives
95
+ - **v1.1.5** — added slider
96
+ - **v1.1.4** — Fixed blur issue for input.
97
+ - **v1.1.3** — Upgrade `MatLegacyCard` to `MDC`.
98
+ - **v1.1.2** — Introduce new select component (`EcabsSelectV2`) to deprecate `EcabsSelect`.
99
+ - **v1.1.1** — Hide `Timepicker` options on input blur.
100
+ - **v1.1.0** — Upgrade `MatLegacyMenu` to `MDC`.
101
+ - **v1.0.99** — Add `mini` and `maxi` directive and validators to `EcabsInput`.
102
+ - **v1.0.98** — Upgrade `MatLegacyAutocomplete` to `MDC`.
103
+ - **v1.0.97** — Correct misaligned icon and text on `EcabsNotes`.
104
+ - **v1.0.96** — Add missing styles for nested columns on `Table`.
105
+ - **v1.0.95** — Upgrade `MatLegacyTooltip` to `MDC`.
106
+ - **v1.0.94** — Upgrade `MatLegacyTabs` to `MDC`.
107
+ - **v1.0.93** — Update progress colors for percentage.
108
+ - **v1.0.92** — Add default buttons for Confirm and Cancel buttons on dialog.
109
+ - **v1.0.91** — Upgrade `MatLegacyCheckbox` and `MatSlideToggle` to `MDC`.
110
+ - **v1.0.90** — Upgrade `MatLegacyPaginator` to `MDC`.
111
+ - Add `EcabsPaginatorDirective`.
112
+ - Rename `AppHint` to `EcabsHint`.
113
+ - Apply `ngx-toaster` overrides.
114
+ - **v1.0.89** — Upgrade `MatLegacyTable` and `MatLegacyProgress` to `MDC`.
115
+ - **v1.0.88** — Roll back 1.0.87
116
+ - **v1.0.87** — Apply min/max Date logic for date picker
117
+ - **v1.0.85** — Improve styling for `EcabsTable` row colors.
118
+ - **v1.0.84** — Emit `falsey` result when Close button is clicked on `EcabsDialogConfirm` and `EcabsDialogMessage`.
119
+ - **v1.0.83** — Fix buttons height.
120
+ - **v1.0.82** — Improve the appearance of disabled inputs.
121
+ - Fix placeholder text of `EcabsSelect`.
122
+ - **v1.0.81** — Fix font size of `EcabsSelect`.
123
+ - **v1.0.80** — Allow custom button options for `Confirm` and `Cancel` buttons on `EcabsDialog`.
34
124
  - **v1.0.79** — feat(CU-11266): Update `MatDialog` to `MDC`.
35
125
  - Fix button height issue on anchor tags marked as `mat-button`.
36
126
  - Update default font family.
37
127
  - Rename `NoteComponent` to `EcabsNoteComponent`.
38
128
  - Add `expired` style for `EcabsChip`.
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.
42
- - Fix placeholder text of `EcabsSelect`.
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`.
50
- - Add `EcabsPaginatorDirective`.
51
- - Rename `AppHint` to `EcabsHint`.
52
- - Apply `ngx-toaster` overrides.
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.
84
- - Added badges for menu items.
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.
95
- - **v1.1.33** — Return falsey value when no input is available in `DateTime` selector through keyboard action deletion.
96
- - **v1.1.34** — Emit `selectionChange` event when selecting item from `EcabsSelectV2`.
97
- - Add collapse styling for `EcabsLogo`.
98
- - **v1.1.35** — Add `waypointType` input to `EcabsAutoComplete`.
99
- - Add `nativeElement` handles to custom inputs.
100
- - **v1.1.38** — Use native `matDatepickerToggleIcon` in `EcabsDateTimePicker`.
101
- - **v1.1.39** — Added date adapter to public api.
102
- - **v1.1.40** — `EcabsDateTimePicker`: Added support for preserving and returning `receivedValue` when there is no change in the input.
103
- - **v1.1.41** — Added EcabsDialogConfirmationDeletionComponent.
104
- - **v1.1.42** — Apply `width` and `height` properties directly to root `MatDialog` of `EcabsDialogConfirmComponent`.
105
- - **v1.1.43** — Added disabling of Apply button for date range picker
106
- - **v1.1.44** — Fixed issue Apply button is still active when only the DateFrom is selected
107
- - **v1.1.45** — Added default validation of date range
108
- - **v1.1.46** — Add `ViewChild` reference for `MatRadioGroup` and update event type in `EcabsRadioButtonListComponent`.
109
- - **v1.1.47** — Add `Title` and `dynamic` content support to `EcabsEmptyPlaceholderComponent`.
110
- - **v1.1.48** — Implement `EcabsPlaceAutocompleteV2Component` to support waypoints history, query change handling, and dropdown suggestions display.
111
- - **v1.1.49** — Add support for `splitButtonsWidth` in `EcabsDialogConfirmComponent` and update button styling.`.
112
- - **v1.1.50** — Add `Documentation` for `EcabsTableModule`.
113
- - **v1.1.51** — Implement option of displaying dynamic content for `EcabsTableComponent` when empty.
114
- - **v1.1.52** — Update styling overrides for Material nav-style tabs, including active state.
115
- - **v1.1.53** — Introduce new gray color palette and update references and apply styling improvements.
116
- - **v1.1.54** — Implement `EcabsButtonToggleComponent` with support for small, medium, and large sizes.
117
- - **v1.1.55** — `EcabsButtonsV2Component`: Added version 2 of `EcabsButtonsComponent` with support for small, medium, and large sizes.
118
- - **v1.1.56** — Implement `EcabsDateRangePickerComponentV2`.
119
- - **v1.1.57** — Implement `EcabsChipGroup`and `EcabsAutocompleteChipGroup` components with demo.
120
- - **v1.1.58** — Add `EcabsInputRangeComponent` with support for minimum and maximum values.
121
- - **v1.1.59** — `EcabsCheckboxV2Component`: Implement version 2 of `EcabsCheckboxComponent`.
122
- - **v1.1.60** — Migrate input mask library from `vanilla-text-mask` to `maskito`.
123
- - **Affected components**: `EcabsDateTimePicker`, `EcabsTimepicker`, `EcabsDateTimeRangePicker`.
124
- - **v1.1.61** — Added support for 12-hour time input for `maskito` library.
125
- - **Affected components**: `EcabsDateTimePicker`, `EcabsTimepicker`, `EcabsDateTimeRangePicker`.
126
- - **v1.1.62** — Add `EcabsTimeRangeInputV2Component`.,
127
- - **v1.1.63** — Add `EcabsSegmentComponent`.
128
- - Update `EcabsSelectV2` to be more robust when handling multiple selections.
129
- - **v1.1.64** — Refactor `EcabsChipAutocomplete` logic, improve component styles/disabled states, and update button styles.
130
- - **v1.1.65** — `EcabsInputRange`: Remove padding and background styling.
131
- - **v1.1.66** — Suppress emission of an empty query on refocusing after selection of option from `EcabsChipAutocomplete`.
129
+ - **v1.0.78** — Upgrade `MatSelect` to `MDC`.
130
+ - **v1.0.77** — Upgrade `MatChips` to `MDC`.
131
+ - **v1.0.76** — Upgrade `EcabsInput` module to `MDC` styling.
132
+ - **v1.0.75** Upgrade `EcabsButtons` module to `MDC` styling.
133
+ - **v1.0.18** — Fixed width of date time picker
134
+ - **v1.0.13** — Fixed emitEvent behaviour of checkbox
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci5tb2RlbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvYmFzZS9tb2RlbHMvc2lkZWJhci5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgU2lkZWJhck1lbnVJdGVtIHtcclxuICB0aXRsZTogc3RyaW5nO1xyXG4gIGljb24/OiBzdHJpbmc7XHJcbiAgdXJsPzogc3RyaW5nO1xyXG4gIGV4cGFuZD86IGJvb2xlYW47XHJcbiAgc3ViSXRlbXM/OiBTaWRlYmFyTWVudUl0ZW1bXTtcclxuICBwZXJtaXNzaW9ucz86IFBlcm1pc3Npb25WYWx1ZUVudW08c3RyaW5nPltdO1xyXG4gIGljb25SZXNvdXJjZT86IFNpZGViYXJJY29uUmVzb3VyY2U7XHJcbiAgYmFkZ2U/OiBzdHJpbmc7XHJcbn1cclxuXHJcbnR5cGUgUGVybWlzc2lvblZhbHVlRW51bTxUIGV4dGVuZHMgc3RyaW5nPiA9IHtcclxuICB2YWx1ZXM6IFJlY29yZDxULCBzdHJpbmc+O1xyXG59O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTaWRlYmFySWNvblJlc291cmNlIHtcclxuICBwYXRoOiBzdHJpbmc7XHJcbiAgbmFtZTogc3RyaW5nO1xyXG59XHJcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci5tb2RlbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvYmFzZS9tb2RlbHMvc2lkZWJhci5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgU2lkZWJhck1lbnVJdGVtPFRFbnYgPSB1bmtub3duLCBUUm9sZSA9IHVua25vd24+IHtcclxuICB0aXRsZTogc3RyaW5nO1xyXG4gIGljb24/OiBzdHJpbmc7XHJcbiAgdXJsPzogc3RyaW5nO1xyXG4gIGV4cGFuZD86IGJvb2xlYW47XHJcbiAgc3ViSXRlbXM/OiBTaWRlYmFyTWVudUl0ZW1bXTtcclxuICBwZXJtaXNzaW9ucz86IFBlcm1pc3Npb25WYWx1ZUVudW08c3RyaW5nPltdO1xyXG4gIGljb25SZXNvdXJjZT86IFNpZGViYXJJY29uUmVzb3VyY2U7XHJcbiAgYmFkZ2U/OiBzdHJpbmc7XHJcbiAgaXNWaXNpYmxlPzogKGNvbnRleHQ6IE1lbnVJdGVtVmlzaWJpbGl0eUNvbnRleHQ8VEVudiwgVFJvbGU+KSA9PiBib29sZWFuO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE1lbnVJdGVtVmlzaWJpbGl0eUNvbnRleHQ8VEVudiwgVFJvbGU+IHtcclxuICBlbnZpcm9ubWVudDogVEVudjtcclxuICByb2xlOiBUUm9sZTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTaWRlYmFySWNvblJlc291cmNlIHtcclxuICBwYXRoOiBzdHJpbmc7XHJcbiAgbmFtZTogc3RyaW5nO1xyXG59XHJcblxyXG5pbnRlcmZhY2UgUGVybWlzc2lvblZhbHVlRW51bTxUIGV4dGVuZHMgc3RyaW5nPiB7XHJcbiAgdmFsdWVzOiBSZWNvcmQ8VCwgc3RyaW5nPjtcclxufVxyXG4iXX0=
@@ -3,21 +3,19 @@ import { NG_VALUE_ACCESSOR, NgControl, Validators, } from '@angular/forms';
3
3
  import { format, isEqual, isValid } from 'date-fns';
4
4
  import Holidays from 'date-holidays';
5
5
  import { isEqual as lodashIsEqual } from 'lodash';
6
- import { takeUntil } from 'rxjs';
7
6
  import EcabsElementBaseComponent from '../base/element-base';
8
- import { UnsubscribeService } from '../base/services/unsubscribe.service';
9
7
  import { EcabsDateRangePickerHeaderComponentV2 } from './components/ecabs-date-range-picker-header/ecabs-date-range-picker-header-v2.component';
8
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
10
9
  import * as i0 from "@angular/core";
11
10
  import * as i1 from "../base/services/ecabs-date-picker-translations.service";
12
- import * as i2 from "../base/services/unsubscribe.service";
13
- import * as i3 from "../base/element-wrapper/element-wrapper.component";
14
- import * as i4 from "@angular/material/datepicker";
15
- import * as i5 from "@angular/forms";
16
- import * as i6 from "../base/directives/date-mask.directive";
11
+ import * as i2 from "../base/element-wrapper/element-wrapper.component";
12
+ import * as i3 from "@angular/material/datepicker";
13
+ import * as i4 from "@angular/forms";
14
+ import * as i5 from "../base/directives/date-mask.directive";
17
15
  export class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
18
16
  injector;
19
17
  ecabsDatePickerHeaderService;
20
- unsubscribeService;
18
+ destroyRef;
21
19
  minDate;
22
20
  maxDate;
23
21
  touchUi = false;
@@ -30,6 +28,7 @@ export class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
30
28
  excludeWeekends;
31
29
  specificDates;
32
30
  holidayOptions;
31
+ dateToOptional = false;
33
32
  onblur = new EventEmitter();
34
33
  val;
35
34
  pickerTo;
@@ -64,28 +63,42 @@ export class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
64
63
  }
65
64
  //eslint-disable-next-line
66
65
  set dateFrom(val) {
67
- if (this._dateFrom !== val && isValid(new Date(val))) {
66
+ if (this._dateFrom === val) {
67
+ return;
68
+ }
69
+ if (val && isValid(new Date(val))) {
68
70
  this._dateFrom = val;
69
71
  this.minDateTo = new Date(val);
70
- if (!this.dateTo) {
72
+ if (!this.dateTo && !this.dateToOptional) {
71
73
  this.pickerTo?.open();
72
74
  }
73
- this.onApply();
74
75
  }
76
+ else if (!val) {
77
+ this._dateFrom = val;
78
+ this.minDateTo = this.minDate;
79
+ }
80
+ this.onApply();
75
81
  }
76
82
  //eslint-disable-next-line
77
83
  set dateTo(val) {
78
- if (this._dateTo !== val && isValid(new Date(val))) {
84
+ if (this._dateTo === val) {
85
+ return;
86
+ }
87
+ if (val && isValid(new Date(val))) {
79
88
  this._dateTo = val;
80
89
  this.maxDateFrom = new Date(val);
81
- this.onApply();
82
90
  }
91
+ else if (!val) {
92
+ this._dateTo = val;
93
+ this.maxDateFrom = this.maxDate;
94
+ }
95
+ this.onApply();
83
96
  }
84
- constructor(injector, ecabsDatePickerHeaderService, unsubscribeService) {
97
+ constructor(injector, ecabsDatePickerHeaderService, destroyRef) {
85
98
  super();
86
99
  this.injector = injector;
87
100
  this.ecabsDatePickerHeaderService = ecabsDatePickerHeaderService;
88
- this.unsubscribeService = unsubscribeService;
101
+ this.destroyRef = destroyRef;
89
102
  }
90
103
  ngOnChanges(changes) {
91
104
  const { minDate, maxDate } = changes;
@@ -101,7 +114,7 @@ export class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
101
114
  ngOnInit() {
102
115
  this.ecabsDatePickerHeaderService
103
116
  .getConfig()
104
- .pipe(takeUntil(this.unsubscribeService.subscription()))
117
+ .pipe(takeUntilDestroyed(this.destroyRef))
105
118
  .subscribe((config) => (this.translationConfig = config));
106
119
  if (this.holidayOptions?.countryCode) {
107
120
  this.holidayInstance = new Holidays(this.holidayOptions.countryCode.toUpperCase());
@@ -112,17 +125,15 @@ export class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
112
125
  if (ngControl) {
113
126
  this.control = ngControl.control;
114
127
  this.control.valueChanges
115
- .pipe(takeUntil(this.unsubscribeService.subscription()))
128
+ .pipe(takeUntilDestroyed(this.destroyRef))
116
129
  .subscribe(() => this.dateRangeValidator(this.control));
117
130
  setTimeout(() => {
118
131
  this.dateFrom = this.value.dateFrom;
119
132
  this.dateTo = this.value.dateTo;
133
+ this.dateRangeValidator(this.control);
120
134
  });
121
135
  }
122
136
  }
123
- ngOnDestroy() {
124
- this.unsubscribeService.destroy();
125
- }
126
137
  onChange = () => { };
127
138
  onTouch = () => { };
128
139
  writeValue(value) {
@@ -181,38 +192,37 @@ export class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
181
192
  }
182
193
  dateRangeValidator(control) {
183
194
  const required = control?.hasValidator(Validators.required);
184
- if (control.value) {
185
- const { dateFrom, dateTo } = control.value;
186
- control.setErrors(null);
187
- if (required &&
188
- (!dateFrom || dateFrom?.length === 0) &&
189
- (!dateTo || dateTo?.length === 0)) {
195
+ if (!control.value) {
196
+ if (required) {
190
197
  control.setErrors({ required: true });
191
- return;
192
- }
193
- if (!dateFrom && dateTo) {
194
- control.setErrors({ dateFromRangeRequired: true });
195
- return;
196
- }
197
- if (dateFrom && !dateTo) {
198
- control.setErrors({ dateToRangeRequired: true });
199
- return;
200
- }
201
- if (new Date(dateFrom) > new Date(dateTo)) {
202
- control.setErrors({ dateFromMoreThanDateTo: true });
203
- return;
204
198
  }
199
+ return;
200
+ }
201
+ const { dateFrom, dateTo } = control.value;
202
+ control.setErrors(null);
203
+ if (required &&
204
+ (!dateFrom || dateFrom?.length === 0) &&
205
+ (!dateTo || dateTo?.length === 0)) {
206
+ control.setErrors({ required: true });
207
+ }
208
+ else if (!dateFrom && dateTo) {
209
+ control.setErrors({ rangeFrom: true });
210
+ }
211
+ else if (dateFrom && !dateTo && !this.dateToOptional) {
212
+ control.setErrors({ rangeTo: true });
213
+ }
214
+ else if (dateFrom && dateTo && new Date(dateFrom) > new Date(dateTo)) {
215
+ control.setErrors({ rangeOrder: true });
205
216
  }
206
217
  }
207
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateRangePickerComponentV2, deps: [{ token: i0.Injector }, { token: i1.EcabsDatePickerHeaderService }, { token: i2.UnsubscribeService }], target: i0.ɵɵFactoryTarget.Component });
208
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDateRangePickerComponentV2, selector: "ecabs-date-range-picker-v2", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", cancelLabel: "cancelLabel", applyLabel: "applyLabel", startDatePlaceholder: "startDatePlaceholder", endDatePlaceholder: "endDatePlaceholder", separatorLabel: "separatorLabel", excludeHolidays: "excludeHolidays", excludeWeekends: "excludeWeekends", specificDates: "specificDates", holidayOptions: "holidayOptions" }, outputs: { onblur: "onblur" }, providers: [
218
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateRangePickerComponentV2, deps: [{ token: i0.Injector }, { token: i1.EcabsDatePickerHeaderService }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Component });
219
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDateRangePickerComponentV2, selector: "ecabs-date-range-picker-v2", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", cancelLabel: "cancelLabel", applyLabel: "applyLabel", startDatePlaceholder: "startDatePlaceholder", endDatePlaceholder: "endDatePlaceholder", separatorLabel: "separatorLabel", excludeHolidays: "excludeHolidays", excludeWeekends: "excludeWeekends", specificDates: "specificDates", holidayOptions: "holidayOptions", dateToOptional: "dateToOptional" }, outputs: { onblur: "onblur" }, providers: [
209
220
  {
210
221
  provide: NG_VALUE_ACCESSOR,
211
222
  useExisting: EcabsDateRangePickerComponentV2,
212
223
  multi: true,
213
224
  },
214
- UnsubscribeService,
215
- ], viewQueries: [{ propertyName: "pickerTo", first: true, predicate: ["pickerTo"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__range--wrapper\">\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateFrom' }}\"\r\n [(ngModel)]=\"dateFrom\"\r\n [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerFrom\"\r\n [min]=\"minDateFrom\"\r\n [max]=\"maxDateFrom\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerFrom.open()\"\r\n />\r\n <mat-datepicker #pickerFrom\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n\r\n <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateTo' }}\"\r\n [(ngModel)]=\"dateTo\"\r\n [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerTo\"\r\n [min]=\"minDateTo\"\r\n [max]=\"maxDateTo\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerTo.open()\"\r\n />\r\n <mat-datepicker #pickerTo\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n </div>\r\n</ecabs-element-wrapper>\r\n", styles: [""], dependencies: [{ kind: "component", type: i3.EcabsElementWrapperComponent, selector: "ecabs-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i4.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i4.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.EcabsMaskDateDirective, selector: "[ecabsMaskDate]", inputs: ["isDateTimeMask", "considerSeconds"] }] });
225
+ ], viewQueries: [{ propertyName: "pickerTo", first: true, predicate: ["pickerTo"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__range--wrapper\">\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateFrom' }}\"\r\n [(ngModel)]=\"dateFrom\"\r\n [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerFrom\"\r\n [min]=\"minDateFrom\"\r\n [max]=\"maxDateFrom\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerFrom.open()\"\r\n />\r\n <mat-datepicker #pickerFrom\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n\r\n <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateTo' }}\"\r\n [(ngModel)]=\"dateTo\"\r\n [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerTo\"\r\n [min]=\"minDateTo\"\r\n [max]=\"maxDateTo\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerTo.open()\"\r\n />\r\n <mat-datepicker #pickerTo\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n </div>\r\n</ecabs-element-wrapper>\r\n", styles: [""], dependencies: [{ kind: "component", type: i2.EcabsElementWrapperComponent, selector: "ecabs-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.EcabsMaskDateDirective, selector: "[ecabsMaskDate]", inputs: ["isDateTimeMask", "considerSeconds"] }] });
216
226
  }
217
227
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateRangePickerComponentV2, decorators: [{
218
228
  type: Component,
@@ -222,9 +232,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
222
232
  useExisting: EcabsDateRangePickerComponentV2,
223
233
  multi: true,
224
234
  },
225
- UnsubscribeService,
226
235
  ], template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__range--wrapper\">\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateFrom' }}\"\r\n [(ngModel)]=\"dateFrom\"\r\n [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerFrom\"\r\n [min]=\"minDateFrom\"\r\n [max]=\"maxDateFrom\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerFrom.open()\"\r\n />\r\n <mat-datepicker #pickerFrom\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n\r\n <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateTo' }}\"\r\n [(ngModel)]=\"dateTo\"\r\n [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerTo\"\r\n [min]=\"minDateTo\"\r\n [max]=\"maxDateTo\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerTo.open()\"\r\n />\r\n <mat-datepicker #pickerTo\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n </div>\r\n</ecabs-element-wrapper>\r\n" }]
227
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.EcabsDatePickerHeaderService }, { type: i2.UnsubscribeService }]; }, propDecorators: { minDate: [{
236
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.EcabsDatePickerHeaderService }, { type: i0.DestroyRef }]; }, propDecorators: { minDate: [{
228
237
  type: Input
229
238
  }], maxDate: [{
230
239
  type: Input
@@ -248,10 +257,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
248
257
  type: Input
249
258
  }], holidayOptions: [{
250
259
  type: Input
260
+ }], dateToOptional: [{
261
+ type: Input
251
262
  }], onblur: [{
252
263
  type: Output
253
264
  }], pickerTo: [{
254
265
  type: ViewChild,
255
266
  args: ['pickerTo']
256
267
  }] } });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-range-picker-v2.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker-v2/ecabs-date-range-picker-v2.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker-v2/ecabs-date-range-picker-v2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { MatDateRangePicker } from '@angular/material/datepicker';\r\nimport { format, isEqual, isValid } from 'date-fns';\r\nimport Holidays from 'date-holidays';\r\nimport { isEqual as lodashIsEqual } from 'lodash';\r\n\r\nimport { takeUntil } from 'rxjs';\r\n\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} 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 { EcabsDateRangePickerHeaderComponentV2 } from './components/ecabs-date-range-picker-header/ecabs-date-range-picker-header-v2.component';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-range-picker-v2',\r\n  templateUrl: './ecabs-date-range-picker-v2.component.html',\r\n  styleUrls: ['./ecabs-date-range-picker-v2.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateRangePickerComponentV2,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDateRangePickerComponentV2\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit, OnChanges, OnDestroy\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() startDatePlaceholder: string;\r\n  @Input() endDatePlaceholder: string;\r\n  @Input() separatorLabel = 'to';\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  val: {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  };\r\n\r\n  @ViewChild('pickerTo') pickerTo: MatDateRangePicker<any> | undefined;\r\n\r\n  header = EcabsDateRangePickerHeaderComponentV2;\r\n  _dateFrom: string;\r\n  _dateTo: string;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n  minDateFrom?: Date = undefined;\r\n  maxDateFrom?: Date = undefined;\r\n  minDateTo?: Date = undefined;\r\n  maxDateTo?: Date = undefined;\r\n\r\n  protected readonly panelClass = 'ecabs-date-range-picker-v2';\r\n\r\n  private holidayInstance: Holidays;\r\n\r\n  get value(): {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  } {\r\n    return this.val;\r\n  }\r\n\r\n  get dateFrom(): string {\r\n    return this._dateFrom;\r\n  }\r\n\r\n  get dateTo(): string {\r\n    return this._dateTo;\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set value(val: { dateFrom: string; dateTo: string }) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.dateFrom = val.dateFrom;\r\n      this.dateTo = val.dateTo;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateFrom(val: string) {\r\n    if (this._dateFrom !== val && isValid(new Date(val))) {\r\n      this._dateFrom = val;\r\n      this.minDateTo = new Date(val);\r\n\r\n      if (!this.dateTo) {\r\n        this.pickerTo?.open();\r\n      }\r\n\r\n      this.onApply();\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateTo(val: string) {\r\n    if (this._dateTo !== val && isValid(new Date(val))) {\r\n      this._dateTo = val;\r\n      this.maxDateFrom = new Date(val);\r\n      this.onApply();\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  ngOnChanges(changes: SimpleChanges): void {\r\n    const { minDate, maxDate } = changes;\r\n\r\n    if (minDate?.currentValue) {\r\n      this.minDateFrom = minDate?.currentValue;\r\n      this.minDateTo = minDate?.currentValue;\r\n    }\r\n\r\n    if (maxDate?.currentValue) {\r\n      this.maxDateFrom = maxDate?.currentValue;\r\n      this.maxDateTo = maxDate?.currentValue;\r\n    }\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    if (this.holidayOptions?.countryCode) {\r\n      this.holidayInstance = new Holidays(\r\n        this.holidayOptions.countryCode.toUpperCase(),\r\n      );\r\n    }\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      this.control.valueChanges\r\n        .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n        .subscribe(() => this.dateRangeValidator(this.control));\r\n      setTimeout(() => {\r\n        this.dateFrom = this.value.dateFrom;\r\n        this.dateTo = this.value.dateTo;\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribeService.destroy();\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): void {\r\n    this.onblur.emit(e);\r\n  }\r\n\r\n  onApply(): void {\r\n    const newValue = {\r\n      dateFrom: this.dateFrom,\r\n      dateTo: this.dateTo,\r\n    };\r\n\r\n    if (!lodashIsEqual(this.value, newValue)) {\r\n      this.val = newValue;\r\n      this.onChange(newValue);\r\n      this.onTouch(newValue);\r\n    }\r\n\r\n    this.value = {\r\n      dateFrom: this.dateFrom,\r\n      dateTo: this.dateTo,\r\n    };\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  isDateNotHoliday(date: Date): boolean {\r\n    const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};\r\n\r\n    if (countryCode && timeZoneOffset) {\r\n      return !this.holidayInstance?.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  dateRangeValidator(control: UntypedFormControl) {\r\n    const required = control?.hasValidator(Validators.required);\r\n\r\n    if (control.value) {\r\n      const { dateFrom, dateTo } = control.value;\r\n      control.setErrors(null);\r\n\r\n      if (\r\n        required &&\r\n        (!dateFrom || dateFrom?.length === 0) &&\r\n        (!dateTo || dateTo?.length === 0)\r\n      ) {\r\n        control.setErrors({ required: true });\r\n\r\n        return;\r\n      }\r\n\r\n      if (!dateFrom && dateTo) {\r\n        control.setErrors({ dateFromRangeRequired: true });\r\n\r\n        return;\r\n      }\r\n\r\n      if (dateFrom && !dateTo) {\r\n        control.setErrors({ dateToRangeRequired: true });\r\n\r\n        return;\r\n      }\r\n\r\n      if (new Date(dateFrom) > new Date(dateTo)) {\r\n        control.setErrors({ dateFromMoreThanDateTo: true });\r\n\r\n        return;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__range--wrapper\">\r\n    <div class=\"form-field__range\">\r\n      <input\r\n        class=\"border-none w-full\"\r\n        id=\"{{ name + 'dateFrom' }}\"\r\n        [(ngModel)]=\"dateFrom\"\r\n        [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\"\r\n        [disabled]=\"disabled\"\r\n        [matDatepicker]=\"pickerFrom\"\r\n        [min]=\"minDateFrom\"\r\n        [max]=\"maxDateFrom\"\r\n        [matDatepickerFilter]=\"filterDateRange\"\r\n        ecabsMaskDate\r\n        (blur)=\"onTouch()\"\r\n        (click)=\"pickerFrom.open()\"\r\n      />\r\n      <mat-datepicker #pickerFrom\r\n                      [panelClass]=\"panelClass\"\r\n                      [calendarHeaderComponent]=\"header\"\r\n                      [touchUi]=\"touchUi\">\r\n      </mat-datepicker>\r\n    </div>\r\n\r\n    <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n    <div class=\"form-field__range\">\r\n      <input\r\n        class=\"border-none w-full\"\r\n        id=\"{{ name + 'dateTo' }}\"\r\n        [(ngModel)]=\"dateTo\"\r\n        [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\"\r\n        [disabled]=\"disabled\"\r\n        [matDatepicker]=\"pickerTo\"\r\n        [min]=\"minDateTo\"\r\n        [max]=\"maxDateTo\"\r\n        [matDatepickerFilter]=\"filterDateRange\"\r\n        ecabsMaskDate\r\n        (blur)=\"onTouch()\"\r\n        (click)=\"pickerTo.open()\"\r\n      />\r\n      <mat-datepicker #pickerTo\r\n                      [panelClass]=\"panelClass\"\r\n                      [calendarHeaderComponent]=\"header\"\r\n                      [touchUi]=\"touchUi\">\r\n      </mat-datepicker>\r\n    </div>\r\n  </div>\r\n</ecabs-element-wrapper>\r\n"]}
268
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-range-picker-v2.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker-v2/ecabs-date-range-picker-v2.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker-v2/ecabs-date-range-picker-v2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  DestroyRef,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { MatDateRangePicker } from '@angular/material/datepicker';\r\nimport { format, isEqual, isValid } from 'date-fns';\r\nimport Holidays from 'date-holidays';\r\nimport { isEqual as lodashIsEqual } from 'lodash';\r\n\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} from '../base/models/ecabs-date-picker-translations.models';\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { EcabsDateRangePickerHeaderComponentV2 } from './components/ecabs-date-range-picker-header/ecabs-date-range-picker-header-v2.component';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-range-picker-v2',\r\n  templateUrl: './ecabs-date-range-picker-v2.component.html',\r\n  styleUrls: ['./ecabs-date-range-picker-v2.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateRangePickerComponentV2,\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class EcabsDateRangePickerComponentV2\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit, OnChanges\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() startDatePlaceholder: string;\r\n  @Input() endDatePlaceholder: string;\r\n  @Input() separatorLabel = 'to';\r\n  @Input() excludeHolidays: boolean;\r\n  @Input() excludeWeekends: boolean;\r\n  @Input() specificDates: Date[];\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n  @Input() dateToOptional = false;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n  val: {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  };\r\n\r\n  @ViewChild('pickerTo') pickerTo: MatDateRangePicker<any> | undefined;\r\n\r\n  header = EcabsDateRangePickerHeaderComponentV2;\r\n  _dateFrom: string;\r\n  _dateTo: string;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n  minDateFrom?: Date = undefined;\r\n  maxDateFrom?: Date = undefined;\r\n  minDateTo?: Date = undefined;\r\n  maxDateTo?: Date = undefined;\r\n\r\n  protected readonly panelClass = 'ecabs-date-range-picker-v2';\r\n\r\n  private holidayInstance: Holidays;\r\n\r\n  get value(): {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  } {\r\n    return this.val;\r\n  }\r\n\r\n  get dateFrom(): string {\r\n    return this._dateFrom;\r\n  }\r\n\r\n  get dateTo(): string {\r\n    return this._dateTo;\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set value(val: { dateFrom: string; dateTo: string }) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.dateFrom = val.dateFrom;\r\n      this.dateTo = val.dateTo;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateFrom(val: string) {\r\n    if (this._dateFrom === val) {\r\n      return;\r\n    }\r\n\r\n    if (val && isValid(new Date(val))) {\r\n      this._dateFrom = val;\r\n      this.minDateTo = new Date(val);\r\n\r\n      if (!this.dateTo && !this.dateToOptional) {\r\n        this.pickerTo?.open();\r\n      }\r\n    } else if (!val) {\r\n      this._dateFrom = val;\r\n      this.minDateTo = this.minDate;\r\n    }\r\n\r\n    this.onApply();\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateTo(val: string) {\r\n    if (this._dateTo === val) {\r\n      return;\r\n    }\r\n\r\n    if (val && isValid(new Date(val))) {\r\n      this._dateTo = val;\r\n      this.maxDateFrom = new Date(val);\r\n    } else if (!val) {\r\n      this._dateTo = val;\r\n      this.maxDateFrom = this.maxDate;\r\n    }\r\n\r\n    this.onApply();\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly ecabsDatePickerHeaderService: EcabsDatePickerHeaderService,\r\n    private readonly destroyRef: DestroyRef,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { minDate, maxDate } = changes;\r\n\r\n    if (minDate?.currentValue) {\r\n      this.minDateFrom = minDate?.currentValue;\r\n      this.minDateTo = minDate?.currentValue;\r\n    }\r\n\r\n    if (maxDate?.currentValue) {\r\n      this.maxDateFrom = maxDate?.currentValue;\r\n      this.maxDateTo = maxDate?.currentValue;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.ecabsDatePickerHeaderService\r\n      .getConfig()\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe((config) => (this.translationConfig = config));\r\n\r\n    if (this.holidayOptions?.countryCode) {\r\n      this.holidayInstance = new Holidays(\r\n        this.holidayOptions.countryCode.toUpperCase(),\r\n      );\r\n    }\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      this.control.valueChanges\r\n        .pipe(takeUntilDestroyed(this.destroyRef))\r\n        .subscribe(() => this.dateRangeValidator(this.control));\r\n      setTimeout(() => {\r\n        this.dateFrom = this.value.dateFrom;\r\n        this.dateTo = this.value.dateTo;\r\n        this.dateRangeValidator(this.control);\r\n      });\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): void {\r\n    this.onblur.emit(e);\r\n  }\r\n\r\n  onApply(): void {\r\n    const newValue = {\r\n      dateFrom: this.dateFrom,\r\n      dateTo: this.dateTo,\r\n    };\r\n\r\n    if (!lodashIsEqual(this.value, newValue)) {\r\n      this.val = newValue;\r\n      this.onChange(newValue);\r\n      this.onTouch(newValue);\r\n    }\r\n\r\n    this.value = {\r\n      dateFrom: this.dateFrom,\r\n      dateTo: this.dateTo,\r\n    };\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  isDateNotHoliday(date: Date): boolean {\r\n    const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};\r\n\r\n    if (countryCode && timeZoneOffset) {\r\n      return !this.holidayInstance?.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  dateRangeValidator(control: UntypedFormControl) {\r\n    const required = control?.hasValidator(Validators.required);\r\n\r\n    if (!control.value) {\r\n      if (required) {\r\n        control.setErrors({ required: true });\r\n      }\r\n\r\n      return;\r\n    }\r\n\r\n    const { dateFrom, dateTo } = control.value;\r\n    control.setErrors(null);\r\n\r\n    if (\r\n      required &&\r\n      (!dateFrom || dateFrom?.length === 0) &&\r\n      (!dateTo || dateTo?.length === 0)\r\n    ) {\r\n      control.setErrors({ required: true });\r\n    } else if (!dateFrom && dateTo) {\r\n      control.setErrors({ rangeFrom: true });\r\n    } else if (dateFrom && !dateTo && !this.dateToOptional) {\r\n      control.setErrors({ rangeTo: true });\r\n    } else if (dateFrom && dateTo && new Date(dateFrom) > new Date(dateTo)) {\r\n      control.setErrors({ rangeOrder: true });\r\n    }\r\n  }\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__range--wrapper\">\r\n    <div class=\"form-field__range\">\r\n      <input\r\n        class=\"border-none w-full\"\r\n        id=\"{{ name + 'dateFrom' }}\"\r\n        [(ngModel)]=\"dateFrom\"\r\n        [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\"\r\n        [disabled]=\"disabled\"\r\n        [matDatepicker]=\"pickerFrom\"\r\n        [min]=\"minDateFrom\"\r\n        [max]=\"maxDateFrom\"\r\n        [matDatepickerFilter]=\"filterDateRange\"\r\n        ecabsMaskDate\r\n        (blur)=\"onTouch()\"\r\n        (click)=\"pickerFrom.open()\"\r\n      />\r\n      <mat-datepicker #pickerFrom\r\n                      [panelClass]=\"panelClass\"\r\n                      [calendarHeaderComponent]=\"header\"\r\n                      [touchUi]=\"touchUi\">\r\n      </mat-datepicker>\r\n    </div>\r\n\r\n    <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n    <div class=\"form-field__range\">\r\n      <input\r\n        class=\"border-none w-full\"\r\n        id=\"{{ name + 'dateTo' }}\"\r\n        [(ngModel)]=\"dateTo\"\r\n        [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\"\r\n        [disabled]=\"disabled\"\r\n        [matDatepicker]=\"pickerTo\"\r\n        [min]=\"minDateTo\"\r\n        [max]=\"maxDateTo\"\r\n        [matDatepickerFilter]=\"filterDateRange\"\r\n        ecabsMaskDate\r\n        (blur)=\"onTouch()\"\r\n        (click)=\"pickerTo.open()\"\r\n      />\r\n      <mat-datepicker #pickerTo\r\n                      [panelClass]=\"panelClass\"\r\n                      [calendarHeaderComponent]=\"header\"\r\n                      [touchUi]=\"touchUi\">\r\n      </mat-datepicker>\r\n    </div>\r\n  </div>\r\n</ecabs-element-wrapper>\r\n"]}