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 +102 -99
- package/esm2022/lib/base/models/sidebar.models.mjs +1 -1
- package/esm2022/lib/ecabs-date-range-picker-v2/ecabs-date-range-picker-v2.component.mjs +57 -46
- package/esm2022/lib/ecabs-time-range-input-v2/ecabs-time-range-input-v2.component.mjs +33 -23
- package/fesm2022/ecabs-components.mjs +82 -59
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/base/models/sidebar.models.d.ts +9 -4
- package/lib/ecabs-date-range-picker-v2/ecabs-date-range-picker-v2.component.d.ts +6 -7
- package/lib/ecabs-time-range-input-v2/ecabs-time-range-input-v2.component.d.ts +2 -1
- package/package.json +1 -1
- package/src/assets/styles/tailwind/index.scss +1 -1
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.
|
|
29
|
-
- **v1.
|
|
30
|
-
-
|
|
31
|
-
- **v1.
|
|
32
|
-
- **v1.
|
|
33
|
-
- **v1.
|
|
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.
|
|
40
|
-
- **v1.0.
|
|
41
|
-
- **v1.0.
|
|
42
|
-
|
|
43
|
-
- **v1.0.
|
|
44
|
-
- **v1.0.
|
|
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,
|
|
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/
|
|
13
|
-
import * as i3 from "
|
|
14
|
-
import * as i4 from "@angular/
|
|
15
|
-
import * as i5 from "
|
|
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
|
-
|
|
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
|
|
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
|
|
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,
|
|
97
|
+
constructor(injector, ecabsDatePickerHeaderService, destroyRef) {
|
|
85
98
|
super();
|
|
86
99
|
this.injector = injector;
|
|
87
100
|
this.ecabsDatePickerHeaderService = ecabsDatePickerHeaderService;
|
|
88
|
-
this.
|
|
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(
|
|
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(
|
|
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
|
-
|
|
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:
|
|
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
|
-
|
|
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:
|
|
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"]}
|