@natec/mef-dev-ui-kit 16.2.5 → 16.3.49

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.
Files changed (79) hide show
  1. package/esm2022/lib/markup-kit/card/card/card.component.mjs +6 -6
  2. package/esm2022/lib/markup-kit/card/card-long/card-long.component.mjs +6 -6
  3. package/esm2022/lib/markup-kit/card/card-simple/card-simple.component.mjs +6 -6
  4. package/esm2022/lib/markup-kit/card/card.module.mjs +9 -9
  5. package/esm2022/lib/markup-kit/collapse/collapse/collapse.component.mjs +6 -6
  6. package/esm2022/lib/markup-kit/collapse/collapse-set/collapse-set.component.mjs +4 -4
  7. package/esm2022/lib/markup-kit/collapse/collapse.module.mjs +5 -5
  8. package/esm2022/lib/markup-kit/executors/mefdev-executor-page/mefdev-executor-page.component.mjs +4 -4
  9. package/esm2022/lib/markup-kit/executors/stage/stage.component.mjs +4 -4
  10. package/esm2022/lib/markup-kit/executors/step-executor/step-executor.component.mjs +74 -10
  11. package/esm2022/lib/markup-kit/executors/step-executor.module.mjs +10 -6
  12. package/esm2022/lib/markup-kit/modals/fill/fill.component.mjs +6 -6
  13. package/esm2022/lib/markup-kit/modals/markup-kit.module.mjs +5 -5
  14. package/esm2022/lib/markup-kit/modals/right-filter/right-filter.component.mjs +4 -4
  15. package/esm2022/lib/markup-kit/modals/slide-right/slide-right.component.mjs +5 -5
  16. package/esm2022/lib/markup-kit/modals/slide-up/slide-up.component.mjs +5 -5
  17. package/esm2022/lib/markup-kit/page-layouts/central-page/central-page.component.mjs +5 -5
  18. package/esm2022/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.mjs +4 -4
  19. package/esm2022/lib/markup-kit/page-layouts/manage-page/manage-page.component.mjs +6 -6
  20. package/esm2022/lib/markup-kit/page-layouts/page-layouts.module.mjs +5 -5
  21. package/esm2022/lib/markup-kit/page-layouts/profile/profile.component.mjs +6 -6
  22. package/esm2022/lib/markup-kit/page-layouts/table-page/table-page.component.mjs +5 -5
  23. package/esm2022/lib/markup-kit/slider/slider/slider.component.mjs +6 -6
  24. package/esm2022/lib/markup-kit/slider/slider.module.mjs +5 -5
  25. package/esm2022/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.mjs +140 -135
  26. package/esm2022/lib/markup-kit/utils/datepicker/datepicker.module.mjs +5 -5
  27. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.mjs +5 -5
  28. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.mjs +5 -5
  29. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field.module.mjs +5 -5
  30. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field.service.mjs +4 -4
  31. package/esm2022/lib/markup-kit/utils/help-block/help-block.component.mjs +6 -6
  32. package/esm2022/lib/markup-kit/utils/help-block/hepl-block.module.mjs +5 -5
  33. package/esm2022/lib/pg-components/card/card.components.mjs +11 -8
  34. package/esm2022/lib/pg-components/card/card.module.mjs +10 -10
  35. package/esm2022/lib/pg-components/progress/progress.component.mjs +4 -4
  36. package/esm2022/lib/pg-components/progress/progress.config.mjs +4 -4
  37. package/esm2022/lib/pg-components/progress/progress.module.mjs +5 -5
  38. package/esm2022/lib/pg-components/select/option.component.mjs +4 -4
  39. package/esm2022/lib/pg-components/select/option.pipe.mjs +4 -4
  40. package/esm2022/lib/pg-components/select/select.component.mjs +5 -5
  41. package/esm2022/lib/pg-components/select/select.module.mjs +5 -5
  42. package/esm2022/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.mjs +4 -4
  43. package/esm2022/lib/pg-components/spec-flow-test/spec-flow-test.module.mjs +5 -5
  44. package/esm2022/lib/pg-components/switch/switch.component.mjs +5 -5
  45. package/esm2022/lib/pg-components/switch/switch.module.mjs +5 -5
  46. package/esm2022/lib/pg-components/tabs/tab-body.component.mjs +4 -4
  47. package/esm2022/lib/pg-components/tabs/tab-label.directive.mjs +4 -4
  48. package/esm2022/lib/pg-components/tabs/tab.component.mjs +4 -4
  49. package/esm2022/lib/pg-components/tabs/tabs-ink-bar.directive.mjs +4 -4
  50. package/esm2022/lib/pg-components/tabs/tabs-nav.component.mjs +4 -4
  51. package/esm2022/lib/pg-components/tabs/tabs.module.mjs +5 -5
  52. package/esm2022/lib/pg-components/tabs/tabset.component.mjs +5 -5
  53. package/fesm2022/natec-mef-dev-ui-kit.mjs +418 -345
  54. package/fesm2022/natec-mef-dev-ui-kit.mjs.map +1 -1
  55. package/lib/markup-kit/card/card/card.component.d.ts +1 -1
  56. package/lib/markup-kit/card/card-long/card-long.component.d.ts +1 -1
  57. package/lib/markup-kit/card/card-simple/card-simple.component.d.ts +1 -1
  58. package/lib/markup-kit/card/card.module.d.ts +1 -1
  59. package/lib/markup-kit/collapse/collapse/collapse.component.d.ts +1 -1
  60. package/lib/markup-kit/executors/step-executor/step-executor.component.d.ts +45 -3
  61. package/lib/markup-kit/executors/step-executor.module.d.ts +4 -3
  62. package/lib/markup-kit/modals/fill/fill.component.d.ts +1 -1
  63. package/lib/markup-kit/modals/slide-right/slide-right.component.d.ts +1 -1
  64. package/lib/markup-kit/modals/slide-up/slide-up.component.d.ts +1 -1
  65. package/lib/markup-kit/page-layouts/central-page/central-page.component.d.ts +1 -1
  66. package/lib/markup-kit/page-layouts/manage-page/manage-page.component.d.ts +1 -1
  67. package/lib/markup-kit/page-layouts/profile/profile.component.d.ts +1 -1
  68. package/lib/markup-kit/page-layouts/table-page/table-page.component.d.ts +1 -1
  69. package/lib/markup-kit/slider/slider/slider.component.d.ts +1 -1
  70. package/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.d.ts +104 -104
  71. package/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.d.ts +1 -1
  72. package/lib/markup-kit/utils/help-block/help-block.component.d.ts +1 -1
  73. package/lib/pg-components/card/card.components.d.ts +5 -5
  74. package/lib/pg-components/card/card.module.d.ts +5 -5
  75. package/lib/pg-components/select/select.component.d.ts +1 -1
  76. package/lib/pg-components/switch/switch.component.d.ts +1 -1
  77. package/lib/pg-components/tabs/tabset.component.d.ts +1 -1
  78. package/package.json +1 -1
  79. package/src/lib/styles/designe-colors.scss +16 -1
@@ -1,81 +1,91 @@
1
- import { Component, HostListener, Input, Output, EventEmitter } from '@angular/core';
1
+ import { Component, HostListener, Input, Output, EventEmitter, } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
4
  import * as i2 from "@angular/forms";
5
5
  import * as i3 from "../../../../pg-components/select/option.component";
6
6
  import * as i4 from "../../../../pg-components/select/select.component";
7
7
  /**
8
- * Datepicker Component for selecting dates.
9
- *
10
- * This component allows users to pick a date from a calendar interface.
11
- * It supports various configuration options such as language, date format, and date range.
12
- *
13
- * @example
14
- * <mefdev-datepicker
15
- * [lang]="'uk'"
16
- * [dateFormat]="'dd/MM/yyyy'"
17
- * [range]="{startYear: 1900, toYear: 300}"
18
- * [disabled]="false"
19
- * (dateChanged)="onDateChanged($event)"
20
- * [topOffset]="'20'"
21
- * [leftOffset]="'10'">
22
- * </mefdev-datepicker>
23
- *
24
- * <example-url>https://mef.dev/ui_kit_demo/view/utils/datepicker</example-url>
25
- */
8
+ * Datepicker Component for selecting dates.
9
+ *
10
+ * This component allows users to pick a date from a calendar interface.
11
+ * It supports various configuration options such as language, date format, and date range.
12
+ *
13
+ * @example
14
+ * <mefdev-datepicker
15
+ * [labelContentText]="'Select your date'"
16
+ * [lang]="'uk'"
17
+ * [dateFormat]="'dd/MM/yyyy'"
18
+ * [range]="{startYear: 1900, toYear: 300}"
19
+ * [disabled]="false"
20
+ * (dateChanged)="onDateChanged($event)"
21
+ * [topOffset]="'20'"
22
+ * [leftOffset]="'10'">
23
+ * </mefdev-datepicker>
24
+ *
25
+ * <example-url>https://mef.dev/ui_kit_demo/view/utils/datepicker</example-url>
26
+ */
26
27
  export class DatepickerComponent {
27
28
  datePipe;
28
29
  elementRef;
30
+ /**
31
+ * A flag that checks whether a valid date has been entered and whether the entered date exists.
32
+ * If the two previous conditions are not true, the datepicker will be highlighted in red
33
+ */
34
+ isUserDateValid = true;
29
35
  /**
30
36
  * Flag to determine if the calendar is open or closed.
31
37
  * Default value: false (closed).
32
- */
38
+ */
33
39
  isCalendarOpen = false;
34
- /**
35
- * Flag to determine if the component is in editing mode.
36
- * Default value: false (not in editing mode).
37
- */
38
- isEditing = false;
39
40
  /**
40
41
  * The currently selected date.
41
42
  * Default value: Today's date.
42
- */
43
+ */
43
44
  selectedDate = new Date();
44
45
  /**
45
- * The formatted date for display in the input.
46
- * Default value: Formatted representation of the selected date.
47
- */
46
+ * The formatted date for display in the input.
47
+ * Default value: Formatted representation of the selected date.
48
+ */
48
49
  formattedDate;
49
50
  /**
50
- * Track the edited date separately when in editing mode.
51
- * Default value: An empty string.
52
- */
51
+ * Track the edited date separately when in editing mode.
52
+ * Default value: An empty string.
53
+ */
53
54
  editedDate = '';
54
55
  /**
55
56
  * Flag to determine if the month dropdown is open or closed.
56
57
  * Default value: true (open).
57
- */
58
+ */
58
59
  isMonthDropdownOpen = true;
59
60
  /**
60
61
  * Flag to determine if the year dropdown is open or closed.
61
62
  * Default value: true (open).
62
- */
63
+ */
63
64
  isYearDropdownOpen = true;
64
65
  /**
65
66
  * The selected month (0-11).
66
67
  * Default value: The month of the selected date.
67
- */
68
+ */
68
69
  selectedDateMonth = this.selectedDate.getMonth();
69
70
  /**
70
71
  * The selected year.
71
72
  * Default value: The year of the selected date.
72
- */
73
+ */
73
74
  selectedDateYear = this.selectedDate.getFullYear();
74
75
  /**
75
- * An array of years for the year dropdown.
76
- * Default value: An array of years within the specified range.
77
- */
76
+ * An array of years for the year dropdown.
77
+ * Default value: An array of years within the specified range.
78
+ */
78
79
  years;
80
+ /**
81
+ * Label text for the datepicker.
82
+ * Default value: 'en' (English).
83
+ * @example
84
+ * <mefdev-datepicker
85
+ * [labelContentText] = "'Chose your date'">
86
+ * </mefdev-datepicker>
87
+ */
88
+ labelContentText;
79
89
  /**
80
90
  * The language/locale for the datepicker.
81
91
  * Default value: 'en' (English).
@@ -83,7 +93,7 @@ export class DatepickerComponent {
83
93
  * <mefdev-datepicker
84
94
  * [lang] = "'uk'">
85
95
  * </mefdev-datepicker>
86
- */
96
+ */
87
97
  lang = 'en';
88
98
  /**
89
99
  * The date format for displaying the selected date.
@@ -92,7 +102,7 @@ export class DatepickerComponent {
92
102
  * <mefdev-datepicker
93
103
  * [dateFormat]="'dd/MM/yyyy'">
94
104
  * </mefdev-datepicker>
95
- */
105
+ */
96
106
  dateFormat = 'EEE MMM dd yyyy';
97
107
  /**
98
108
  * The range of years available in the year dropdown.
@@ -101,7 +111,7 @@ export class DatepickerComponent {
101
111
  * <mefdev-datepicker
102
112
  * [range]="{startYear: 1900, toYear: 300}">
103
113
  * </mefdev-datepicker>
104
- */
114
+ */
105
115
  yearsRange = { startYear: 1900, toYear: 300 };
106
116
  /**
107
117
  * Whether the datepicker is disabled or not.
@@ -110,7 +120,7 @@ export class DatepickerComponent {
110
120
  * <mefdev-datepicker
111
121
  * [disabled]="false">
112
122
  * </mefdev-datepicker>
113
- */
123
+ */
114
124
  disabled = false;
115
125
  /**
116
126
  * The top offset for positioning the datepicker.
@@ -119,7 +129,7 @@ export class DatepickerComponent {
119
129
  * <mefdev-datepicker
120
130
  * [topOffset]="'20'">
121
131
  * </mefdev-datepicker>
122
- */
132
+ */
123
133
  topOffset = '20';
124
134
  /**
125
135
  * The left offset for positioning the datepicker.
@@ -128,7 +138,7 @@ export class DatepickerComponent {
128
138
  * <mefdev-datepicker
129
139
  * [leftOffset]="'10'">
130
140
  * </mefdev-datepicker>
131
- */
141
+ */
132
142
  leftOffset = '10'; //Default value
133
143
  /**
134
144
  * Event emitted when the selected date in the datepicker changes.
@@ -137,19 +147,19 @@ export class DatepickerComponent {
137
147
  * <mefdev-datepicker
138
148
  * (dateChanged)="onDateChanged($event)">
139
149
  * </mefdev-datepicker>
140
- */
150
+ */
141
151
  dateChanged = new EventEmitter();
142
152
  /**
143
153
  * Regular expression to validate user input for date in the format "dd/MM/yyyy".
144
154
  * - The day (dd) should be between 01 and 31.
145
155
  * - The month (MM) should be between 01 and 12.
146
156
  * - The year (yyyy) should be a 4-digit number.
147
- */
157
+ */
148
158
  dateRegExp = /^(0[1-9]|[12][0-9]|3[01])\/(0[1-9]|1[0-2])\/\d{4}$/;
149
159
  /**
150
160
  * The string entered by the user for date input.
151
161
  * This variable stores the user's input as they type in the date field.
152
- */
162
+ */
153
163
  userInput = '';
154
164
  /**
155
165
  * Host listener for document click events to handle calendar interaction.
@@ -157,30 +167,26 @@ export class DatepickerComponent {
157
167
  * - If the click occurred within the calendar, no action is taken.
158
168
  * - If the click occurred within the input element and the component is not in editing mode,
159
169
  * it opens the calendar.
160
- * - If the click occurred outside the calendar and input, it closes the calendar.
161
170
  * @param event The MouseEvent object representing the click event.
162
- */
171
+ */
163
172
  onClick(event) {
164
173
  const targetElement = event.target;
174
+ const datepickerContainer = this.elementRef.nativeElement.querySelector('.datepicker-container');
165
175
  const calendar = this.elementRef.nativeElement.querySelector('.calendar');
166
176
  const monthDropdown = this.elementRef.nativeElement.querySelector('.monthDropdown');
167
177
  const yearDropdown = this.elementRef.nativeElement.querySelector('.yearDropdown');
168
178
  const inputElement = this.elementRef.nativeElement.querySelector('input');
169
- if (monthDropdown.contains(targetElement) && yearDropdown.contains(targetElement)) {
170
- this.toggleMonthDropdown(event);
171
- this.toggleYearDropdown(event);
172
- }
173
- if (calendar && calendar.contains(targetElement)) {
174
- return;
175
- }
176
- if (inputElement && inputElement.contains(targetElement) && !this.isEditing) {
177
- // Клік відбувся на елементі input, відкриваємо календар
178
- this.isCalendarOpen = true;
179
- }
180
- else {
181
- // Клік відбувся поза календарем та input, закриваємо календар
182
- this.isCalendarOpen = false;
183
- this.isEditing = false;
179
+ if (datepickerContainer && datepickerContainer.contains(calendar)) {
180
+ if (calendar && calendar.contains(targetElement))
181
+ return;
182
+ if (this.isMonthDropdownOpen && !calendar.contains(targetElement))
183
+ return;
184
+ if (this.isYearDropdownOpen && !calendar.contains(targetElement))
185
+ return;
186
+ if ((monthDropdown && monthDropdown.contains(targetElement)) && (yearDropdown && yearDropdown.contains(targetElement))) {
187
+ this.toggleMonthDropdown(event);
188
+ this.toggleYearDropdown(event);
189
+ }
184
190
  }
185
191
  }
186
192
  /**
@@ -188,7 +194,7 @@ export class DatepickerComponent {
188
194
  * @param datePipe A service for formatting and parsing dates.
189
195
  * @param elementRef A reference to the element on which this component is attached.
190
196
  * It is used to access DOM elements.
191
- */
197
+ */
192
198
  constructor(datePipe, elementRef) {
193
199
  this.datePipe = datePipe;
194
200
  this.elementRef = elementRef;
@@ -197,28 +203,28 @@ export class DatepickerComponent {
197
203
  /**
198
204
  * Lifecycle hook called after the component is initialized.
199
205
  * It initializes the years for the year select dropdown.
200
- */
206
+ */
201
207
  ngOnInit() {
202
208
  this.initializeYears();
203
209
  }
204
210
  /**
205
211
  * Lifecycle hook called whenever the input properties of the component change.
206
212
  * It updates the input value.
207
- */
213
+ */
208
214
  ngOnChanges() {
209
215
  this.updateInputValue();
210
216
  }
211
217
  /**
212
218
  * An array of month names based on the selected language.
213
219
  * It provides localized month names for display in the datepicker.
214
- */
220
+ */
215
221
  get months() {
216
222
  return this.getMonthList(this.lang);
217
223
  }
218
224
  /**
219
225
  * An array of weekday names based on the selected language.
220
226
  * It provides localized weekday names for display in the datepicker.
221
- */
227
+ */
222
228
  get weekdays() {
223
229
  return this.getWeekdayList(this.lang);
224
230
  }
@@ -231,16 +237,14 @@ export class DatepickerComponent {
231
237
  * // After calling initializeYears(), 'years' might contain [1900, 1901, ..., 300]
232
238
  * this.initializeYears();
233
239
  * ```
234
- */
240
+ */
235
241
  initializeYears() {
236
242
  this.years = Array.from({ length: this.yearsRange.toYear }, (_, index) => index + this.yearsRange.startYear);
237
243
  }
238
244
  /**
239
245
  * Toggle the editing mode for the date input. When enabled, the user can edit the date directly in the input field.
240
- * This method sets the 'isEditing' flag to true and stores the current formatted date for editing.
241
- */
246
+ */
242
247
  toggleEdit() {
243
- this.isEditing = !this.isEditing;
244
248
  this.editedDate = this.formatSelectedDate(); // Store the current formatted date for editing
245
249
  this.isCalendarOpen = false;
246
250
  }
@@ -253,7 +257,7 @@ export class DatepickerComponent {
253
257
  * // Get a list of month names in the default language and long format
254
258
  * const months = this.getMonthList(this.lang);
255
259
  * ```
256
- */
260
+ */
257
261
  getMonthList(locales, format = "long") {
258
262
  const year = new Date().getFullYear();
259
263
  const monthList = [...Array(12).keys()];
@@ -270,7 +274,7 @@ export class DatepickerComponent {
270
274
  * // Get a list of weekday names in the default language and short format
271
275
  * const weekdays = this.getWeekdayList();
272
276
  * ```
273
- */
277
+ */
274
278
  getWeekdayList(locales, format = "short") {
275
279
  const weekdays = [...Array(7).keys()];
276
280
  const mondayIndex = weekdays.indexOf(0);
@@ -282,22 +286,6 @@ export class DatepickerComponent {
282
286
  };
283
287
  return weekdays.map(getWeekdayName);
284
288
  }
285
- /**
286
- * Toggle the visibility of the calendar component. When called, this method changes the 'isCalendarOpen' flag
287
- * to show or hide the calendar interface.
288
- * ```
289
- * // Toggle the visibility of the calendar
290
- * this.toggleCalendar();
291
- * ```
292
- */
293
- toggleCalendar() {
294
- if (this.isEditing) {
295
- this.isCalendarOpen = false;
296
- }
297
- else {
298
- this.isCalendarOpen = !this.isCalendarOpen;
299
- }
300
- }
301
289
  /**
302
290
  * Save the edited date input by the user, provided it matches the specified date format.
303
291
  * This method checks if the entered date is in a valid format, disables the editing mode, and applies
@@ -306,25 +294,24 @@ export class DatepickerComponent {
306
294
  * // Save the edited date and update the selected date
307
295
  * this.saveEditedDate();
308
296
  * ```
309
- */
297
+ */
310
298
  saveEditedDate() {
311
299
  if (this.isDateValid(this.editedDate)) {
312
- this.isEditing = false;
313
300
  const [day, month, year] = this.editedDate.split('/');
314
301
  this.selectedDate = new Date(+year, +month - 1, +day);
315
302
  this.formatDate();
316
303
  }
317
304
  }
318
305
  /**
319
- * Handle user input in the editable input field for date editing. This method captures the input value
320
- * and stores it in the 'editedDate' variable. If the input matches the valid date format, it updates
321
- * 'selectedDateMonth' and 'selectedDateYear' accordingly.
322
- * @param event - The input event containing the user's input.
323
- * ```
324
- * // Handle user input in the editable input field
325
- * this.onDateInput(event);
326
- * ```
327
- */
306
+ * Handle user input in the editable input field for date editing. This method captures the input value
307
+ * and stores it in the 'editedDate' variable. If the input matches the valid date format, it updates
308
+ * 'selectedDateMonth' and 'selectedDateYear' accordingly.
309
+ * @param event - The input event containing the user's input.
310
+ * ```
311
+ * // Handle user input in the editable input field
312
+ * this.onDateInput(event);
313
+ * ```
314
+ */
328
315
  onDateInput(event) {
329
316
  const inputDate = event.target.value;
330
317
  if (this.isDateValid(inputDate)) {
@@ -332,7 +319,10 @@ export class DatepickerComponent {
332
319
  const parsedDate = inputDate.split('/');
333
320
  this.selectedDateMonth = +parsedDate[1] - 1;
334
321
  this.selectedDateYear = +parsedDate[2];
322
+ this.selectedDate = new Date(+parsedDate[2], +parsedDate[1] - 1, +parsedDate[0]);
323
+ this.calculateFirstDayOfCalendar();
335
324
  }
325
+ this.isUserDateValid = this.isDateValid(inputDate);
336
326
  }
337
327
  /**
338
328
  * Toggle the visibility of the month dropdown in the calendar interface.
@@ -342,19 +332,19 @@ export class DatepickerComponent {
342
332
  * // Toggle the visibility of the month dropdown
343
333
  * this.toggleMonthDropdown(event);
344
334
  * ```
345
- */
335
+ */
346
336
  toggleMonthDropdown(event) {
347
337
  this.isMonthDropdownOpen = !this.isMonthDropdownOpen;
348
338
  }
349
339
  /**
350
- * Toggle the visibility of the year dropdown in the calendar interface.
351
- * This method is used to open or close the dropdown for selecting years.
352
- * @param event - The event triggering the toggle action (e.g., a click event).
353
- * ```
354
- * // Toggle the visibility of the year dropdown
355
- * this.toggleYearDropdown(event);
356
- * ```
357
- */
340
+ * Toggle the visibility of the year dropdown in the calendar interface.
341
+ * This method is used to open or close the dropdown for selecting years.
342
+ * @param event - The event triggering the toggle action (e.g., a click event).
343
+ * ```
344
+ * // Toggle the visibility of the year dropdown
345
+ * this.toggleYearDropdown(event);
346
+ * ```
347
+ */
358
348
  toggleYearDropdown(event) {
359
349
  this.isYearDropdownOpen = !this.isYearDropdownOpen;
360
350
  }
@@ -366,10 +356,11 @@ export class DatepickerComponent {
366
356
  * // Handle the change of the selected month
367
357
  * this.onMonthChange();
368
358
  * ```
369
- */
359
+ */
370
360
  onMonthChange() {
371
361
  this.updateInputValue();
372
362
  this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);
363
+ this.formatDate();
373
364
  this.calculateFirstDayOfCalendar();
374
365
  }
375
366
  /**
@@ -380,7 +371,7 @@ export class DatepickerComponent {
380
371
  * // Handle the change of the selected year
381
372
  * this.onYearChange();
382
373
  * ```
383
- */
374
+ */
384
375
  onYearChange() {
385
376
  this.updateInputValue();
386
377
  this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);
@@ -392,7 +383,7 @@ export class DatepickerComponent {
392
383
  * This method sets the selected date, formats it, closes the calendar, and emits a dateChanged event.
393
384
  * It also updates the selected month and year dropdown values.
394
385
  * @param date - The date to be selected in the calendar.
395
- */
386
+ */
396
387
  selectDate(date) {
397
388
  this.selectedDate = date;
398
389
  this.formatDate();
@@ -408,7 +399,7 @@ export class DatepickerComponent {
408
399
  * // Format the selected date
409
400
  * this.formatDate();
410
401
  * ```
411
- */
402
+ */
412
403
  formatDate() {
413
404
  this.formattedDate = this.datePipe.transform(this.selectedDate, this.dateFormat) || '';
414
405
  }
@@ -420,7 +411,7 @@ export class DatepickerComponent {
420
411
  * // Format the selected date with language
421
412
  * const formatted = this.formatSelectedDate();
422
413
  * ```
423
- */
414
+ */
424
415
  formatSelectedDate() {
425
416
  return this.datePipe.transform(this.selectedDate, this.dateFormat, this.lang) || '';
426
417
  }
@@ -432,9 +423,9 @@ export class DatepickerComponent {
432
423
  * // Update the input value
433
424
  * this.updateInputValue();
434
425
  * ```
435
- */
426
+ */
436
427
  updateInputValue() {
437
- this.formattedDate = this.isEditing ? this.editedDate : this.formatSelectedDate();
428
+ this.formattedDate = this.isCalendarOpen ? this.editedDate : this.formatSelectedDate();
438
429
  }
439
430
  /**
440
431
  * Get an array of arrays representing the days of the current month.
@@ -444,7 +435,7 @@ export class DatepickerComponent {
444
435
  * // Get an array of arrays representing the days of the current month
445
436
  * const calendar = this.calendarDays;
446
437
  * ```
447
- */
438
+ */
448
439
  get calendarDays() {
449
440
  return this.calculateFirstDayOfCalendar();
450
441
  }
@@ -458,7 +449,7 @@ export class DatepickerComponent {
458
449
  * // Get the previous month's date to display in empty cells
459
450
  * const previousMonthDate = this.getPreviousMonthDate(new Date(2023, 8, 1));
460
451
  * ```
461
- */
452
+ */
462
453
  getPreviousMonthDate(date) {
463
454
  if (!date) {
464
455
  return '';
@@ -478,7 +469,7 @@ export class DatepickerComponent {
478
469
  * // Navigate to the previous month
479
470
  * this.getPreviousMonth();
480
471
  * ```
481
- */
472
+ */
482
473
  getPreviousMonth() {
483
474
  const currentMonth = this.selectedDate.getMonth();
484
475
  this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth - 1, 1);
@@ -492,7 +483,7 @@ export class DatepickerComponent {
492
483
  * // Navigate to the next month
493
484
  * this.getNextMonth();
494
485
  * ```
495
- */
486
+ */
496
487
  getNextMonth() {
497
488
  const currentMonth = this.selectedDate.getMonth();
498
489
  this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth + 1, 1);
@@ -504,7 +495,7 @@ export class DatepickerComponent {
504
495
  * @param year - The year for which you want to determine the number of days.
505
496
  * @param month - The month (0-based index) for which you want to determine the number of days.
506
497
  * @returns The number of days in the specified month of the given year.
507
- */
498
+ */
508
499
  daysInMonth(year, month) {
509
500
  return new Date(year, month + 1, 0).getDate();
510
501
  }
@@ -513,7 +504,7 @@ export class DatepickerComponent {
513
504
  * This method generates a matrix of day data objects representing the days in the calendar.
514
505
  * Each day data object contains the date and whether it belongs to the current month.
515
506
  * @returns A matrix of day data objects for the calendar display.
516
- */
507
+ */
517
508
  calculateFirstDayOfCalendar() {
518
509
  const year = this.selectedDate.getFullYear();
519
510
  const month = this.selectedDate.getMonth();
@@ -545,21 +536,33 @@ export class DatepickerComponent {
545
536
  * // Check if a date is selected
546
537
  * const isSelected = this.isDateSelected(someDate);
547
538
  * ```
548
- */
539
+ */
549
540
  isDateSelected(date) {
550
541
  return date.toDateString() === this.selectedDate.toDateString();
551
542
  }
552
543
  /**
553
544
  * Check if a date string is valid based on the specified date format.
545
+ * It also checks whether the specified number, month is correct and whether the specified one exists among calendar years
554
546
  * @param inputDate - The date string to validate.
555
547
  * @returns `true` if the input date string is valid, otherwise `false`.
556
548
  * ```
557
549
  * // Check if a date string is valid
558
550
  * const isValidDate = this.isDateValid('05/25/2023');
559
551
  * ```
560
- */
552
+ */
561
553
  isDateValid(inputDate) {
562
- return this.dateRegExp.test(inputDate);
554
+ if (!this.dateRegExp.test(inputDate)) {
555
+ return false;
556
+ }
557
+ const parts = inputDate.split('/');
558
+ const day = parseInt(parts[0], 10);
559
+ const month = parseInt(parts[1], 10);
560
+ const year = parseInt(parts[2], 10);
561
+ if (year > this.years[this.years.length - 1] || year < this.years[0]) {
562
+ return false;
563
+ }
564
+ const daysInMonth = new Date(year, month, 0).getDate();
565
+ return day <= daysInMonth;
563
566
  }
564
567
  /**
565
568
  * Check if a given date is today's date.
@@ -569,18 +572,20 @@ export class DatepickerComponent {
569
572
  * // Check if a date is today's date
570
573
  * const isToday = this.isDateToday(someDate);
571
574
  * ```
572
- */
575
+ */
573
576
  isDateToday(date) {
574
577
  const today = new Date();
575
578
  return date.toDateString() === today.toDateString();
576
579
  }
577
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: DatepickerComponent, deps: [{ token: i1.DatePipe }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
578
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: DatepickerComponent, selector: "mefdev-datepicker", inputs: { lang: "lang", dateFormat: "dateFormat", yearsRange: ["range", "yearsRange"], disabled: "disabled", topOffset: "topOffset", leftOffset: "leftOffset" }, outputs: { dateChanged: "dateChanged" }, host: { listeners: { "document:click": "onClick($event)" } }, usesOnChanges: true, ngImport: i0, template: "<div class=\"datepicker-container\"\r\n[class.disabled]=\"disabled\"\r\n>\r\n\r\n <!-- Input, save & edit buttons -->\r\n <div class=\"input-container\">\r\n\r\n <div *ngIf=\"!isEditing\">\r\n\r\n <input\r\n type=\"text\"\r\n (click)=\"toggleCalendar()\"\r\n [value]=\"formattedDate\"\r\n [readOnly]=\"true\"\r\n [disabled]=\"isEditing\"\r\n >\r\n </div>\r\n <!-- Edit -->\r\n <i class=\"fa fa-pencil-square-o edit-button\" aria-hidden=\"true\" (click)=\"toggleEdit()\"></i> \r\n\r\n <div *ngIf=\"isEditing\">\r\n <input\r\n type=\"text\"\r\n [value]=\"editedDate\"\r\n (input)=\"onDateInput($event)\"\r\n class=\"border-3\"\r\n (click)=\"toggleCalendar()\"\r\n >\r\n <i class=\"fa fa-floppy-o edit-button\" (click)=\"saveEditedDate()\" aria-hidden=\"true\"></i>\r\n </div> \r\n </div>\r\n\r\n<!-- Calendar(Dropdowns, dates) -->\r\n <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer \r\n [style.top]=\"topOffset\"\r\n [style.left]=\"leftOffset\">\r\n <div class=\"calendar-header\">\r\n <div class=\"monthButtonContainer\">\r\n <!-- Month dropdown -->\r\n <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n <mefdev-select \r\n class=\"monthDropdown\"\r\n [(ngModel)]=\"selectedDateMonth\" \r\n (ngModelChange)=\"onMonthChange()\"\r\n [PlaceHolder]=\"'month'\"\r\n >\r\n <mefdev-option \r\n *ngFor=\"let month of months; let i = index\" \r\n [Value]=\"i\"\r\n [Label] = \"month\" \r\n \r\n >{{ month }}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #monthLabel>\r\n <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n </ng-template>\r\n\r\n <!-- Year dropdown -->\r\n <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n <mefdev-select \r\n class=\"yearDropdown\" \r\n [(ngModel)]=\"selectedDateYear\" \r\n (ngModelChange)=\"onYearChange()\"\r\n [PlaceHolder]=\"'year'\"\r\n >\r\n <mefdev-option \r\n *ngFor=\"let year of years\" \r\n [Label] = \"year\" \r\n [Value]=\"year\" \r\n >{{year}}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #yearLabel>\r\n <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n </ng-template>\r\n </div>\r\n <!-- Calendar exit button -->\r\n <div>\r\n <i class=\"fa fa-times toggleCalendarButton\" (click)=\"toggleCalendar()\" aria-hidden=\"true\"></i>\r\n </div>\r\n </div>\r\n \r\n <div class=\"calendar-body\">\r\n <table>\r\n <tr>\r\n <th class=\"align-items-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n </tr>\r\n <tr *ngFor=\"let week of calendarDays\">\r\n <td *ngFor=\"let dayData of week\" \r\n (click)=\"selectDate(dayData.date)\"\r\n [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n <span class=\"date\" \r\n [class.prev-month]=\"!dayData.isCurrentMonth\"\r\n >\r\n {{ dayData.date.getDate() }}\r\n </span>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n", styles: [".color-Dark-Gray-1{color:#373737!important}.color-Dark-Gray-2{color:#4d4d4d!important}.color-Red{color:#cf0106!important}.color-Green{color:#28b446!important}.color-Light-Gray-1{color:#929292!important}.color-Light-Gray-2{color:#eaeaea!important}.color-Light-Gray-3{color:#f3f3f3!important}.color-White{color:#fff!important}.color-Link{color:#0185cf!important}.b-color-Dark-Gray-1{background-color:#373737!important}.b-color-Dark-Gray-2{background-color:#4d4d4d!important}.b-color-Red{background-color:#cf0106!important}.b-color-Green{background-color:#28b446!important}.b-color-Light-Gray-1{background-color:#929292!important}.b-color-Light-Gray-2{background-color:#eaeaea!important}.b-color-Light-Gray-3{background-color:#f3f3f3!important}.b-color-White{background-color:#fff!important}.b-color-Link{background-color:#0185cf!important}.datepicker-container{position:relative;display:inline-block}.datepicker-container.disabled{pointer-events:none;opacity:.8}.input-container{position:relative;display:inline-block}.input-container input[type=text]{cursor:pointer;padding:5px;border:1px solid #929292;border-radius:4px}.input-container input[type=text]:hover{border:1px solid #4D4D4D}.input-container .edit-button{position:absolute;top:0;right:0;height:100%;margin:0;padding:5px 10px;background-color:#eaeaea;border:1px solid #929292;border-left:none;border-radius:0 4px 4px 0;cursor:pointer;display:flex;justify-content:center;align-items:center}.calendar{position:absolute;top:35px;left:10%;border:1px solid #929292;background-color:#eaeaea;border-radius:4px;z-index:1}.calendar .calendar-header{background-color:#fff;text-align:center;justify-content:space-between;display:flex;padding:5px 0}.calendar .calendar-header i.fa{display:flex;justify-content:center;align-items:center;width:30px;height:30px;font-size:20px;border-radius:50%;cursor:pointer;background-color:transparent;border:none;color:#cf0106}.calendar .calendar-header .monthButtonContainer{padding-left:10px;height:45px;min-width:140px;display:flex;align-items:center}.calendar .calendar-header .monthDropdown,.calendar .calendar-header .yearDropdown{height:45px;width:105px;cursor:pointer;display:inline-block;padding:6px 5px;border:1px solid #EAEAEA;border-radius:4px;background-color:#fff;color:#4d4d4d}.calendar .calendar-header .monthDropdown{margin:0 8px 0 0;width:130px}.calendar .calendar-header .monthDropdown:hover,.calendar .calendar-header .yearDropdown:hover{border-color:#f3f3f3}.calendar .calendar-body{padding:5px;width:260px}.calendar .calendar-body td{padding:10px;position:relative}.calendar .calendar-body td.selected{position:relative;color:#fff}.calendar .calendar-body td.selected:before{content:\"\";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:20%;background-color:#cf0106;z-index:-1;width:30px;height:30px;color:#fff;border:1px solid #373737}.calendar .calendar-body td:hover{color:#fff;font-weight:700;background-color:#929292;border-radius:20%;cursor:pointer}.calendar .calendar-body .date{display:flex;justify-content:center}.calendar .calendar-body .date.prev-month{color:#f3f3f3}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MefDevOptionComponent, selector: "mefdev-option", inputs: ["Value", "Label", "Disabled"] }, { kind: "component", type: i4.MefDevSelectComponent, selector: "mefdev-select", inputs: ["Filter", "MaxMultiple", "FirstDefault", "AllowClear", "KeepUnListOptions", "Mode", "Multiple", "PlaceHolder", "NotFoundContent", "Size", "ShowSearch", "Tags", "Disabled", "Open"], outputs: ["SearchChange", "change", "OpenChange", "ScrollToBottom"] }] });
580
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerComponent, deps: [{ token: i1.DatePipe }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
581
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DatepickerComponent, selector: "mefdev-datepicker", inputs: { labelContentText: "labelContentText", lang: "lang", dateFormat: "dateFormat", yearsRange: ["range", "yearsRange"], disabled: "disabled", topOffset: "topOffset", leftOffset: "leftOffset" }, outputs: { dateChanged: "dateChanged" }, host: { listeners: { "document:click": "onClick($event)" } }, usesOnChanges: true, ngImport: i0, template: "<div class=\"datepicker-container\" [class.disabled]=\"disabled\">\r\n\r\n <!-- Input, save & edit buttons -->\r\n <div class=\"input-container form-group\">\r\n <label *ngIf=\"labelContentText\" class=\"form-label\"> {{ labelContentText }} </label>\r\n <input\r\n [ngClass]=\"{ 'calendarNotOpened': !isCalendarOpen }\"\r\n [ngStyle]=\"{ 'border-color': isUserDateValid ? '' : 'red' }\"\r\n type=\"text\"\r\n class=\"form-control\"\r\n (input)=\"onDateInput($event)\"\r\n (click)=\"isCalendarOpen = true\"\r\n [value]=\"formattedDate\"\r\n [readOnly]=\"!isCalendarOpen\"\r\n >\r\n </div>\r\n\r\n <!-- Calendar(Dropdowns, dates) -->\r\n <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer\r\n [style.top]=\"topOffset\"\r\n [style.left]=\"leftOffset\">\r\n <div class=\"calendar-header\">\r\n <div class=\"monthButtonContainer\">\r\n <!-- Month dropdown -->\r\n <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n <mefdev-select\r\n class=\"monthDropdown\"\r\n [(ngModel)]=\"selectedDateMonth\"\r\n (ngModelChange)=\"onMonthChange()\"\r\n [PlaceHolder]=\"'month'\"\r\n >\r\n <mefdev-option\r\n *ngFor=\"let month of months; let i = index\"\r\n [Value]=\"i\"\r\n [Label]=\"month\"\r\n style=\"z-index: 1\"\r\n >{{ month }}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #monthLabel>\r\n <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n </ng-template>\r\n\r\n <!-- Year dropdown -->\r\n <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n <mefdev-select\r\n class=\"yearDropdown\"\r\n [(ngModel)]=\"selectedDateYear\"\r\n (ngModelChange)=\"onYearChange()\"\r\n [PlaceHolder]=\"'year'\"\r\n >\r\n <mefdev-option\r\n *ngFor=\"let year of years\"\r\n [Label]=\"year\"\r\n [Value]=\"year\"\r\n >{{year}}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #yearLabel>\r\n <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n </ng-template>\r\n </div>\r\n <!-- Calendar exit button -->\r\n <div>\r\n <i class=\"fa fa-times toggleCalendarButton\" (click)=\"isCalendarOpen = false\" aria-hidden=\"true\"></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"calendar-body\">\r\n <table>\r\n <tr>\r\n <th class=\"text-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n </tr>\r\n <tr *ngFor=\"let week of calendarDays\">\r\n <td *ngFor=\"let dayData of week\"\r\n (click)=\"selectDate(dayData.date)\"\r\n [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n <span class=\"date\" [class.prev-month]=\"!dayData.isCurrentMonth\">\r\n {{ dayData.date.getDate() }}\r\n </span>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".color-black{color:#000!important}.color-Dark-Gray-1{color:#373737!important}.color-Dark-Gray-2{color:#4d4d4d!important}.color-Red{color:#cf0106!important}.color-Green{color:#28b446!important}.color-Light-Gray-1{color:#929292!important}.color-Light-Gray-2{color:#eaeaea!important}.color-Light-Gray-3{color:#f3f3f3!important}.color-White{color:#fff!important}.color-Link{color:#0185cf!important}.color-dark-link{color:#50c0ff!important}.b-color-black{background-color:#000!important}.b-color-Dark-Gray-1{background-color:#373737!important}.b-color-Dark-Gray-2{background-color:#4d4d4d!important}.b-color-Red{background-color:#cf0106!important}.b-color-Green{background-color:#28b446!important}.b-color-Light-Gray-1{background-color:#929292!important}.b-color-Light-Gray-2{background-color:#eaeaea!important}.b-color-Light-Gray-3{background-color:#f3f3f3!important}.b-color-White{background-color:#fff!important}.b-color-Link{background-color:#0185cf!important}.b-color-dark-link{background-color:#50c0ff!important}.datepicker-container{position:relative;display:inline-block}.datepicker-container.disabled{pointer-events:none;opacity:.8}.input-container{position:relative;display:inline-block}.input-container input[type=text]{padding:5px 5px 5px 15px;border:1px solid #929292}.input-container .calendarNotOpened{cursor:pointer}.calendar{position:absolute;border:1px solid #929292;background-color:#eaeaea;z-index:1}.calendar .calendar-header{background-color:#fff;text-align:center;justify-content:space-between;display:flex;padding:5px 0}.calendar .calendar-header i.fa{display:flex;justify-content:center;align-items:center;width:30px;height:30px;font-size:20px;border-radius:50%;cursor:pointer;background-color:transparent;border:none;color:#cf0106}.calendar .calendar-header .monthButtonContainer{padding-left:10px;height:45px;min-width:140px;display:flex;align-items:center}.calendar .calendar-header .monthDropdown,.calendar .calendar-header .yearDropdown{height:45px;width:105px;cursor:pointer;display:inline-block;padding:6px 5px;border:1px solid #EAEAEA;border-radius:4px;background-color:#fff;color:#4d4d4d}.calendar .calendar-header .monthDropdown{margin:0 8px 0 0;width:130px}.calendar .calendar-header .monthDropdown:hover,.calendar .calendar-header .yearDropdown:hover{border-color:#f3f3f3}.calendar .calendar-body{padding:5px}.calendar .calendar-body table{width:100%}.calendar .calendar-body td{padding:10px;position:relative}.calendar .calendar-body td.selected{position:relative;color:#fff}.calendar .calendar-body td.selected:before{content:\"\";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:20%;background-color:#cf0106;z-index:-1;width:30px;height:30px;color:#fff;border:1px solid #373737}.calendar .calendar-body td:hover{color:#fff;font-weight:700;background-color:#929292;border-radius:20%;cursor:pointer}.calendar .calendar-body .date{display:flex;justify-content:center}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MefDevOptionComponent, selector: "mefdev-option", inputs: ["Value", "Label", "Disabled"] }, { kind: "component", type: i4.MefDevSelectComponent, selector: "mefdev-select", inputs: ["Filter", "MaxMultiple", "FirstDefault", "AllowClear", "KeepUnListOptions", "Mode", "Multiple", "PlaceHolder", "NotFoundContent", "Size", "ShowSearch", "Tags", "Disabled", "Open"], outputs: ["SearchChange", "change", "OpenChange", "ScrollToBottom"] }] });
579
582
  }
580
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: DatepickerComponent, decorators: [{
583
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerComponent, decorators: [{
581
584
  type: Component,
582
- args: [{ selector: 'mefdev-datepicker', template: "<div class=\"datepicker-container\"\r\n[class.disabled]=\"disabled\"\r\n>\r\n\r\n <!-- Input, save & edit buttons -->\r\n <div class=\"input-container\">\r\n\r\n <div *ngIf=\"!isEditing\">\r\n\r\n <input\r\n type=\"text\"\r\n (click)=\"toggleCalendar()\"\r\n [value]=\"formattedDate\"\r\n [readOnly]=\"true\"\r\n [disabled]=\"isEditing\"\r\n >\r\n </div>\r\n <!-- Edit -->\r\n <i class=\"fa fa-pencil-square-o edit-button\" aria-hidden=\"true\" (click)=\"toggleEdit()\"></i> \r\n\r\n <div *ngIf=\"isEditing\">\r\n <input\r\n type=\"text\"\r\n [value]=\"editedDate\"\r\n (input)=\"onDateInput($event)\"\r\n class=\"border-3\"\r\n (click)=\"toggleCalendar()\"\r\n >\r\n <i class=\"fa fa-floppy-o edit-button\" (click)=\"saveEditedDate()\" aria-hidden=\"true\"></i>\r\n </div> \r\n </div>\r\n\r\n<!-- Calendar(Dropdowns, dates) -->\r\n <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer \r\n [style.top]=\"topOffset\"\r\n [style.left]=\"leftOffset\">\r\n <div class=\"calendar-header\">\r\n <div class=\"monthButtonContainer\">\r\n <!-- Month dropdown -->\r\n <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n <mefdev-select \r\n class=\"monthDropdown\"\r\n [(ngModel)]=\"selectedDateMonth\" \r\n (ngModelChange)=\"onMonthChange()\"\r\n [PlaceHolder]=\"'month'\"\r\n >\r\n <mefdev-option \r\n *ngFor=\"let month of months; let i = index\" \r\n [Value]=\"i\"\r\n [Label] = \"month\" \r\n \r\n >{{ month }}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #monthLabel>\r\n <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n </ng-template>\r\n\r\n <!-- Year dropdown -->\r\n <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n <mefdev-select \r\n class=\"yearDropdown\" \r\n [(ngModel)]=\"selectedDateYear\" \r\n (ngModelChange)=\"onYearChange()\"\r\n [PlaceHolder]=\"'year'\"\r\n >\r\n <mefdev-option \r\n *ngFor=\"let year of years\" \r\n [Label] = \"year\" \r\n [Value]=\"year\" \r\n >{{year}}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #yearLabel>\r\n <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n </ng-template>\r\n </div>\r\n <!-- Calendar exit button -->\r\n <div>\r\n <i class=\"fa fa-times toggleCalendarButton\" (click)=\"toggleCalendar()\" aria-hidden=\"true\"></i>\r\n </div>\r\n </div>\r\n \r\n <div class=\"calendar-body\">\r\n <table>\r\n <tr>\r\n <th class=\"align-items-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n </tr>\r\n <tr *ngFor=\"let week of calendarDays\">\r\n <td *ngFor=\"let dayData of week\" \r\n (click)=\"selectDate(dayData.date)\"\r\n [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n <span class=\"date\" \r\n [class.prev-month]=\"!dayData.isCurrentMonth\"\r\n >\r\n {{ dayData.date.getDate() }}\r\n </span>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n", styles: [".color-Dark-Gray-1{color:#373737!important}.color-Dark-Gray-2{color:#4d4d4d!important}.color-Red{color:#cf0106!important}.color-Green{color:#28b446!important}.color-Light-Gray-1{color:#929292!important}.color-Light-Gray-2{color:#eaeaea!important}.color-Light-Gray-3{color:#f3f3f3!important}.color-White{color:#fff!important}.color-Link{color:#0185cf!important}.b-color-Dark-Gray-1{background-color:#373737!important}.b-color-Dark-Gray-2{background-color:#4d4d4d!important}.b-color-Red{background-color:#cf0106!important}.b-color-Green{background-color:#28b446!important}.b-color-Light-Gray-1{background-color:#929292!important}.b-color-Light-Gray-2{background-color:#eaeaea!important}.b-color-Light-Gray-3{background-color:#f3f3f3!important}.b-color-White{background-color:#fff!important}.b-color-Link{background-color:#0185cf!important}.datepicker-container{position:relative;display:inline-block}.datepicker-container.disabled{pointer-events:none;opacity:.8}.input-container{position:relative;display:inline-block}.input-container input[type=text]{cursor:pointer;padding:5px;border:1px solid #929292;border-radius:4px}.input-container input[type=text]:hover{border:1px solid #4D4D4D}.input-container .edit-button{position:absolute;top:0;right:0;height:100%;margin:0;padding:5px 10px;background-color:#eaeaea;border:1px solid #929292;border-left:none;border-radius:0 4px 4px 0;cursor:pointer;display:flex;justify-content:center;align-items:center}.calendar{position:absolute;top:35px;left:10%;border:1px solid #929292;background-color:#eaeaea;border-radius:4px;z-index:1}.calendar .calendar-header{background-color:#fff;text-align:center;justify-content:space-between;display:flex;padding:5px 0}.calendar .calendar-header i.fa{display:flex;justify-content:center;align-items:center;width:30px;height:30px;font-size:20px;border-radius:50%;cursor:pointer;background-color:transparent;border:none;color:#cf0106}.calendar .calendar-header .monthButtonContainer{padding-left:10px;height:45px;min-width:140px;display:flex;align-items:center}.calendar .calendar-header .monthDropdown,.calendar .calendar-header .yearDropdown{height:45px;width:105px;cursor:pointer;display:inline-block;padding:6px 5px;border:1px solid #EAEAEA;border-radius:4px;background-color:#fff;color:#4d4d4d}.calendar .calendar-header .monthDropdown{margin:0 8px 0 0;width:130px}.calendar .calendar-header .monthDropdown:hover,.calendar .calendar-header .yearDropdown:hover{border-color:#f3f3f3}.calendar .calendar-body{padding:5px;width:260px}.calendar .calendar-body td{padding:10px;position:relative}.calendar .calendar-body td.selected{position:relative;color:#fff}.calendar .calendar-body td.selected:before{content:\"\";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:20%;background-color:#cf0106;z-index:-1;width:30px;height:30px;color:#fff;border:1px solid #373737}.calendar .calendar-body td:hover{color:#fff;font-weight:700;background-color:#929292;border-radius:20%;cursor:pointer}.calendar .calendar-body .date{display:flex;justify-content:center}.calendar .calendar-body .date.prev-month{color:#f3f3f3}\n"] }]
583
- }], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i0.ElementRef }]; }, propDecorators: { lang: [{
585
+ args: [{ selector: 'mefdev-datepicker', template: "<div class=\"datepicker-container\" [class.disabled]=\"disabled\">\r\n\r\n <!-- Input, save & edit buttons -->\r\n <div class=\"input-container form-group\">\r\n <label *ngIf=\"labelContentText\" class=\"form-label\"> {{ labelContentText }} </label>\r\n <input\r\n [ngClass]=\"{ 'calendarNotOpened': !isCalendarOpen }\"\r\n [ngStyle]=\"{ 'border-color': isUserDateValid ? '' : 'red' }\"\r\n type=\"text\"\r\n class=\"form-control\"\r\n (input)=\"onDateInput($event)\"\r\n (click)=\"isCalendarOpen = true\"\r\n [value]=\"formattedDate\"\r\n [readOnly]=\"!isCalendarOpen\"\r\n >\r\n </div>\r\n\r\n <!-- Calendar(Dropdowns, dates) -->\r\n <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer\r\n [style.top]=\"topOffset\"\r\n [style.left]=\"leftOffset\">\r\n <div class=\"calendar-header\">\r\n <div class=\"monthButtonContainer\">\r\n <!-- Month dropdown -->\r\n <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n <mefdev-select\r\n class=\"monthDropdown\"\r\n [(ngModel)]=\"selectedDateMonth\"\r\n (ngModelChange)=\"onMonthChange()\"\r\n [PlaceHolder]=\"'month'\"\r\n >\r\n <mefdev-option\r\n *ngFor=\"let month of months; let i = index\"\r\n [Value]=\"i\"\r\n [Label]=\"month\"\r\n style=\"z-index: 1\"\r\n >{{ month }}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #monthLabel>\r\n <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n </ng-template>\r\n\r\n <!-- Year dropdown -->\r\n <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n <mefdev-select\r\n class=\"yearDropdown\"\r\n [(ngModel)]=\"selectedDateYear\"\r\n (ngModelChange)=\"onYearChange()\"\r\n [PlaceHolder]=\"'year'\"\r\n >\r\n <mefdev-option\r\n *ngFor=\"let year of years\"\r\n [Label]=\"year\"\r\n [Value]=\"year\"\r\n >{{year}}</mefdev-option>\r\n </mefdev-select>\r\n </ng-container>\r\n <ng-template #yearLabel>\r\n <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n </ng-template>\r\n </div>\r\n <!-- Calendar exit button -->\r\n <div>\r\n <i class=\"fa fa-times toggleCalendarButton\" (click)=\"isCalendarOpen = false\" aria-hidden=\"true\"></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"calendar-body\">\r\n <table>\r\n <tr>\r\n <th class=\"text-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n </tr>\r\n <tr *ngFor=\"let week of calendarDays\">\r\n <td *ngFor=\"let dayData of week\"\r\n (click)=\"selectDate(dayData.date)\"\r\n [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n <span class=\"date\" [class.prev-month]=\"!dayData.isCurrentMonth\">\r\n {{ dayData.date.getDate() }}\r\n </span>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".color-black{color:#000!important}.color-Dark-Gray-1{color:#373737!important}.color-Dark-Gray-2{color:#4d4d4d!important}.color-Red{color:#cf0106!important}.color-Green{color:#28b446!important}.color-Light-Gray-1{color:#929292!important}.color-Light-Gray-2{color:#eaeaea!important}.color-Light-Gray-3{color:#f3f3f3!important}.color-White{color:#fff!important}.color-Link{color:#0185cf!important}.color-dark-link{color:#50c0ff!important}.b-color-black{background-color:#000!important}.b-color-Dark-Gray-1{background-color:#373737!important}.b-color-Dark-Gray-2{background-color:#4d4d4d!important}.b-color-Red{background-color:#cf0106!important}.b-color-Green{background-color:#28b446!important}.b-color-Light-Gray-1{background-color:#929292!important}.b-color-Light-Gray-2{background-color:#eaeaea!important}.b-color-Light-Gray-3{background-color:#f3f3f3!important}.b-color-White{background-color:#fff!important}.b-color-Link{background-color:#0185cf!important}.b-color-dark-link{background-color:#50c0ff!important}.datepicker-container{position:relative;display:inline-block}.datepicker-container.disabled{pointer-events:none;opacity:.8}.input-container{position:relative;display:inline-block}.input-container input[type=text]{padding:5px 5px 5px 15px;border:1px solid #929292}.input-container .calendarNotOpened{cursor:pointer}.calendar{position:absolute;border:1px solid #929292;background-color:#eaeaea;z-index:1}.calendar .calendar-header{background-color:#fff;text-align:center;justify-content:space-between;display:flex;padding:5px 0}.calendar .calendar-header i.fa{display:flex;justify-content:center;align-items:center;width:30px;height:30px;font-size:20px;border-radius:50%;cursor:pointer;background-color:transparent;border:none;color:#cf0106}.calendar .calendar-header .monthButtonContainer{padding-left:10px;height:45px;min-width:140px;display:flex;align-items:center}.calendar .calendar-header .monthDropdown,.calendar .calendar-header .yearDropdown{height:45px;width:105px;cursor:pointer;display:inline-block;padding:6px 5px;border:1px solid #EAEAEA;border-radius:4px;background-color:#fff;color:#4d4d4d}.calendar .calendar-header .monthDropdown{margin:0 8px 0 0;width:130px}.calendar .calendar-header .monthDropdown:hover,.calendar .calendar-header .yearDropdown:hover{border-color:#f3f3f3}.calendar .calendar-body{padding:5px}.calendar .calendar-body table{width:100%}.calendar .calendar-body td{padding:10px;position:relative}.calendar .calendar-body td.selected{position:relative;color:#fff}.calendar .calendar-body td.selected:before{content:\"\";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:20%;background-color:#cf0106;z-index:-1;width:30px;height:30px;color:#fff;border:1px solid #373737}.calendar .calendar-body td:hover{color:#fff;font-weight:700;background-color:#929292;border-radius:20%;cursor:pointer}.calendar .calendar-body .date{display:flex;justify-content:center}\n"] }]
586
+ }], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i0.ElementRef }]; }, propDecorators: { labelContentText: [{
587
+ type: Input
588
+ }], lang: [{
584
589
  type: Input
585
590
  }], dateFormat: [{
586
591
  type: Input
@@ -599,4 +604,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
599
604
  type: HostListener,
600
605
  args: ['document:click', ['$event']]
601
606
  }] } });
602
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.ts","../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, ElementRef, HostListener, OnDestroy, Input, OnChanges, OnInit, Output, EventEmitter } from '@angular/core';\r\nimport { DatePipe } from '@angular/common';\r\n\r\n\r\n/**\r\n  * Datepicker Component for selecting dates.\r\n  *\r\n  * This component allows users to pick a date from a calendar interface.\r\n  * It supports various configuration options such as language, date format, and date range.\r\n  *\r\n  * @example\r\n  * <mefdev-datepicker\r\n  *   [lang]=\"'uk'\"\r\n  *   [dateFormat]=\"'dd/MM/yyyy'\"\r\n  *   [range]=\"{startYear: 1900, toYear: 300}\"\r\n  *   [disabled]=\"false\"\r\n  *   (dateChanged)=\"onDateChanged($event)\"\r\n  *   [topOffset]=\"'20'\"\r\n  *   [leftOffset]=\"'10'\">\r\n  * </mefdev-datepicker>\r\n  *\r\n  * <example-url>https://mef.dev/ui_kit_demo/view/utils/datepicker</example-url>\r\n*/\r\n\r\n@Component({\r\n  selector: 'mefdev-datepicker',\r\n  templateUrl: './datepicker.component.html',\r\n  styleUrls: ['./datepicker.component.scss']\r\n})\r\n\r\nexport class DatepickerComponent implements  OnChanges, OnInit {\r\n\r\n/**\r\n * Flag to determine if the calendar is open or closed.\r\n * Default value: false (closed).\r\n*/\r\nisCalendarOpen: boolean = false; \r\n\r\n/**\r\n * Flag to determine if the component is in editing mode.\r\n * Default value: false (not in editing mode).\r\n*/\r\nisEditing: boolean = false;  \r\n\r\n/**\r\n * The currently selected date.\r\n * Default value: Today's date.\r\n*/\r\nselectedDate: Date = new Date(); \r\n\r\n /**\r\n * The formatted date for display in the input.\r\n * Default value: Formatted representation of the selected date.\r\n*/\r\nformattedDate: any ; \r\n\r\n /**\r\n * Track the edited date separately when in editing mode.\r\n * Default value: An empty string.\r\n*/\r\neditedDate: string = ''; \r\n\r\n/**\r\n * Flag to determine if the month dropdown is open or closed.\r\n * Default value: true (open).\r\n*/\r\nisMonthDropdownOpen: boolean = true; \r\n\r\n/**\r\n * Flag to determine if the year dropdown is open or closed.\r\n * Default value: true (open).\r\n*/\r\nisYearDropdownOpen: boolean = true; \r\n\r\n/**\r\n * The selected month (0-11).\r\n * Default value: The month of the selected date.\r\n*/\r\nselectedDateMonth: number = this.selectedDate.getMonth(); \r\n\r\n/**\r\n * The selected year.\r\n * Default value: The year of the selected date.\r\n*/\r\nselectedDateYear: number = this.selectedDate.getFullYear(); \r\n\r\n /**\r\n * An array of years for the year dropdown.\r\n * Default value: An array of years within the specified range.\r\n*/\r\nyears: number[] \r\n\r\n/**\r\n * The language/locale for the datepicker.\r\n * Default value: 'en' (English).\r\n * @example\r\n * <mefdev-datepicker\r\n *   [lang] = \"'uk'\">\r\n * </mefdev-datepicker>\r\n*/\r\n@Input() lang: string = 'en'; \r\n\r\n/**\r\n * The date format for displaying the selected date.\r\n * Default value: 'EEE MMM dd yyyy'.\r\n * @example\r\n * <mefdev-datepicker\r\n *   [dateFormat]=\"'dd/MM/yyyy'\">\r\n * </mefdev-datepicker>\r\n*/\r\n@Input() dateFormat: string = 'EEE MMM dd yyyy'; \r\n\r\n/**\r\n * The range of years available in the year dropdown.\r\n * Default value: { startYear: 1900, toYear: 300 }.\r\n * @example\r\n * <mefdev-datepicker\r\n *   [range]=\"{startYear: 1900, toYear: 300}\">\r\n * </mefdev-datepicker>\r\n*/\r\n@Input('range') yearsRange:{startYear:number, toYear:number} = {startYear:1900, toYear:300}; \r\n\r\n/**\r\n * Whether the datepicker is disabled or not.\r\n * Default value: false (enabled).\r\n * @example\r\n * <mefdev-datepicker\r\n *   [disabled]=\"false\">\r\n * </mefdev-datepicker>\r\n*/\r\n@Input() disabled: boolean = false; \r\n\r\n/**\r\n * The top offset for positioning the datepicker.\r\n * Default value: '20'.\r\n * @example\r\n * <mefdev-datepicker\r\n *   [topOffset]=\"'20'\">\r\n * </mefdev-datepicker>\r\n*/\r\n@Input() topOffset: string = '20';\r\n\r\n/**\r\n * The left offset for positioning the datepicker.\r\n * Default value: '10'.\r\n * @example\r\n * <mefdev-datepicker\r\n *   [leftOffset]=\"'10'\">\r\n * </mefdev-datepicker>\r\n*/\r\n@Input() leftOffset: string = '10'; //Default value\r\n\r\n/**\r\n * Event emitted when the selected date in the datepicker changes.\r\n * It emits a `Date` object representing the selected date.\r\n * @example\r\n * <mefdev-datepicker\r\n *   (dateChanged)=\"onDateChanged($event)\">\r\n * </mefdev-datepicker>\r\n*/\r\n@Output() dateChanged: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n/**\r\n * Regular expression to validate user input for date in the format \"dd/MM/yyyy\".\r\n * - The day (dd) should be between 01 and 31.\r\n * - The month (MM) should be between 01 and 12.\r\n * - The year (yyyy) should be a 4-digit number.\r\n*/\r\n  private dateRegExp: RegExp = /^(0[1-9]|[12][0-9]|3[01])\\/(0[1-9]|1[0-2])\\/\\d{4}$/;\r\n\r\n/**\r\n * The string entered by the user for date input.\r\n * This variable stores the user's input as they type in the date field.\r\n*/\r\n  userInput: string = '';\r\n  \r\n/**\r\n * Host listener for document click events to handle calendar interaction.\r\n * This function checks if a click event occurred within the calendar or input elements.\r\n * - If the click occurred within the calendar, no action is taken.\r\n * - If the click occurred within the input element and the component is not in editing mode,\r\n *   it opens the calendar.\r\n * - If the click occurred outside the calendar and input, it closes the calendar.\r\n * @param event The MouseEvent object representing the click event.\r\n*/\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent) {\r\n    const targetElement = event.target as HTMLElement;\r\n    const calendar = this.elementRef.nativeElement.querySelector('.calendar');\r\n    const monthDropdown = this.elementRef.nativeElement.querySelector('.monthDropdown');\r\n    const yearDropdown = this.elementRef.nativeElement.querySelector('.yearDropdown');\r\n    const inputElement = this.elementRef.nativeElement.querySelector('input');\r\n    if(monthDropdown.contains(targetElement) && yearDropdown.contains(targetElement) ){\r\n      this.toggleMonthDropdown(event)\r\n      this.toggleYearDropdown(event)\r\n    }\r\n    if (calendar && calendar.contains(targetElement)) {\r\n      return;\r\n    }\r\n    if (inputElement && inputElement.contains(targetElement) && !this.isEditing) {\r\n      // Клік відбувся на елементі input, відкриваємо календар\r\n      this.isCalendarOpen = true;\r\n    }\r\n    else {\r\n        // Клік відбувся поза календарем та input, закриваємо календар\r\n        this.isCalendarOpen = false;\r\n        this.isEditing = false;\r\n      }\r\n  }\r\n\r\n/**\r\n * Constructor for the DatepickerComponent class.\r\n * @param datePipe A service for formatting and parsing dates.\r\n * @param elementRef A reference to the element on which this component is attached.\r\n * It is used to access DOM elements.\r\n*/\r\n  constructor(private datePipe: DatePipe, private elementRef: ElementRef) {\r\n    this.updateInputValue()\r\n  }\r\n  \r\n/**\r\n * Lifecycle hook called after the component is initialized.\r\n * It initializes the years for the year select dropdown.\r\n*/\r\n  ngOnInit(){\r\n    this.initializeYears();\r\n  }\r\n/**\r\n * Lifecycle hook called whenever the input properties of the component change.\r\n * It updates the input value.\r\n*/\r\n  ngOnChanges() {\r\n    this.updateInputValue();\r\n  }\r\n\r\n/**\r\n * An array of month names based on the selected language.\r\n * It provides localized month names for display in the datepicker.\r\n*/\r\n  private get months(){\r\n    return this.getMonthList(this.lang);\r\n  }  \r\n\r\n/**\r\n * An array of weekday names based on the selected language.\r\n * It provides localized weekday names for display in the datepicker.\r\n*/\r\n  private get weekdays() {\r\n    return this.getWeekdayList(this.lang);\r\n  }\r\n\r\n/**\r\n * Initialize the list of years to be displayed in the year dropdown.\r\n * This method populates the 'years' array with a range of years based on the provided 'yearsRange' configuration.\r\n * @example\r\n * ```\r\n * // Assuming 'yearsRange' is { startYear: 1900, toYear: 300 }\r\n * // After calling initializeYears(), 'years' might contain [1900, 1901, ..., 300]\r\n * this.initializeYears();\r\n * ```\r\n*/\r\n  private initializeYears() {\r\n    this.years = Array.from({ length: this.yearsRange.toYear }, (_, index) => index + this.yearsRange.startYear);\r\n  }\r\n\r\n/**\r\n * Toggle the editing mode for the date input. When enabled, the user can edit the date directly in the input field.\r\n * This method sets the 'isEditing' flag to true and stores the current formatted date for editing.\r\n*/\r\n  toggleEdit() {\r\n    this.isEditing = !this.isEditing;\r\n    this.editedDate = this.formatSelectedDate(); // Store the current formatted date for editing\r\n    this.isCalendarOpen = false;\r\n  }\r\n\r\n/**\r\n * Get a list of month names in the specified language and format.\r\n * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n * @param format - The format for month names, either \"long\" (default) or \"short\".\r\n * @returns An array of month names based on the provided format and locale.\r\n * ```\r\n * // Get a list of month names in the default language and long format\r\n * const months = this.getMonthList(this.lang);\r\n * ```\r\n*/\r\n  private getMonthList(  locales?: string | string[],  format: \"long\" | \"short\" = \"long\"): string[] {  \r\n    const year = new Date().getFullYear();\r\n    const monthList = [...Array(12).keys()];\r\n    const formatter = new Intl.DateTimeFormat(locales, {    month: format  });\r\n    const getMonthName = (monthIndex: number) => formatter.format(new Date(year, monthIndex));\r\n     return monthList.map(getMonthName);\r\n  }\r\n  \r\n/**\r\n * Get a list of weekday names in the specified language and format.\r\n * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n * @param format - The format for weekday names, either \"short\" (default) or \"long\".\r\n * @returns An array of weekday names based on the provided format and locale.\r\n * ```\r\n * // Get a list of weekday names in the default language and short format\r\n * const weekdays = this.getWeekdayList();\r\n * ```\r\n*/\r\n  private getWeekdayList(locales?: string | string[], format: \"short\" | \"long\" = \"short\"): string[] {\r\n      const weekdays = [...Array(7).keys()];\r\n      const mondayIndex = weekdays.indexOf(0);\r\n      weekdays.splice(mondayIndex, 1); \r\n      weekdays.push(0); \r\n      const formatter = new Intl.DateTimeFormat(locales, { weekday: format });    \r\n      const getWeekdayName = (weekdayIndex: number) => {\r\n        return formatter.format(new Date(2023, 9, weekdayIndex + 1)); \r\n      };\r\n      return weekdays.map(getWeekdayName);\r\n  }\r\n    \r\n    \r\n/**\r\n * Toggle the visibility of the calendar component. When called, this method changes the 'isCalendarOpen' flag\r\n * to show or hide the calendar interface.\r\n * ```\r\n * // Toggle the visibility of the calendar\r\n * this.toggleCalendar();\r\n * ```\r\n*/\r\n  private toggleCalendar() {\r\n    if(this.isEditing){\r\n      this.isCalendarOpen = false;\r\n    }else{\r\n      this.isCalendarOpen = !this.isCalendarOpen\r\n    }\r\n  }\r\n\r\n/**\r\n * Save the edited date input by the user, provided it matches the specified date format.\r\n * This method checks if the entered date is in a valid format, disables the editing mode, and applies\r\n * the edited date to the 'selectedDate'. It then reformats the selected date and closes the calendar.\r\n * ```\r\n * // Save the edited date and update the selected date\r\n * this.saveEditedDate();\r\n * ```\r\n*/\r\n  private saveEditedDate() {\r\n    if (this.isDateValid(this.editedDate)) {\r\n      this.isEditing = false; \r\n      const [day, month, year] = this.editedDate.split('/');\r\n      this.selectedDate = new Date(+year, +month - 1, +day);\r\n      this.formatDate(); \r\n    } \r\n  }\r\n\r\n/**\r\n  * Handle user input in the editable input field for date editing. This method captures the input value\r\n  * and stores it in the 'editedDate' variable. If the input matches the valid date format, it updates\r\n  * 'selectedDateMonth' and 'selectedDateYear' accordingly.\r\n  * @param event - The input event containing the user's input.\r\n  * ```\r\n  * // Handle user input in the editable input field\r\n  * this.onDateInput(event);\r\n  * ```\r\n*/\r\n  private onDateInput(event: any) {\r\n    const inputDate: string = event.target.value;\r\n    if (this.isDateValid(inputDate)) {\r\n      this.editedDate = inputDate;\r\n      const parsedDate = inputDate.split('/');\r\n      this.selectedDateMonth = +parsedDate[1] - 1;\r\n      this.selectedDateYear = +parsedDate[2];\r\n    }\r\n  }\r\n\r\n/**\r\n * Toggle the visibility of the month dropdown in the calendar interface.\r\n * This method is used to open or close the dropdown for selecting months.\r\n * @param event - The event triggering the toggle action (e.g., a click event).\r\n * ```\r\n * // Toggle the visibility of the month dropdown\r\n * this.toggleMonthDropdown(event);\r\n * ```\r\n*/\r\n  private toggleMonthDropdown(event: Event) {\r\n    this.isMonthDropdownOpen = !this.isMonthDropdownOpen;\r\n  }\r\n\r\n/**\r\n  * Toggle the visibility of the year dropdown in the calendar interface.\r\n  * This method is used to open or close the dropdown for selecting years.\r\n  * @param event - The event triggering the toggle action (e.g., a click event).\r\n  * ```\r\n  * // Toggle the visibility of the year dropdown\r\n  * this.toggleYearDropdown(event);\r\n  * ```\r\n*/\r\n  private toggleYearDropdown(event: Event) {\r\n    this.isYearDropdownOpen = !this.isYearDropdownOpen;\r\n  }\r\n\r\n/**\r\n * Handle the change of the selected month in the calendar interface.\r\n * This method updates the input value, sets the selected date to the first day of the chosen month,\r\n * and recalculates the calendar display accordingly.\r\n * ```\r\n * // Handle the change of the selected month\r\n * this.onMonthChange();\r\n * ```\r\n*/\r\n  private onMonthChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n/**\r\n * Handle the change of the selected year in the calendar interface.\r\n * This method updates the input value, sets the selected date to the first day of the chosen year,\r\n * reformats the selected date, and recalculates the calendar display.\r\n * ```\r\n * // Handle the change of the selected year\r\n * this.onYearChange();\r\n * ```\r\n*/\r\n  private onYearChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n/**\r\n * Select a date in the calendar interface and perform necessary updates.\r\n * This method sets the selected date, formats it, closes the calendar, and emits a dateChanged event.\r\n * It also updates the selected month and year dropdown values.\r\n * @param date - The date to be selected in the calendar.\r\n*/\r\n  selectDate(date: Date) {\r\n  this.selectedDate = date;\r\n  this.formatDate();\r\n  this.isCalendarOpen = false;\r\n  this.dateChanged.next(this.selectedDate);\r\n  this.selectedDateMonth = this.selectedDate.getMonth();\r\n  this.selectedDateYear = this.selectedDate.getFullYear();\r\n  }\r\n\r\n/**\r\n * Format the selected date based on the chosen date format and language.\r\n * This method uses the Angular DatePipe to format the selected date and updates the formattedDate variable.\r\n * ```\r\n * // Format the selected date\r\n * this.formatDate();\r\n * ```\r\n*/\r\n  private formatDate() {\r\n    this.formattedDate = this.datePipe.transform(this.selectedDate, this.dateFormat) || '';\r\n  }\r\n\r\n/**\r\n * Format the selected date based on the chosen date format, language, and locale.\r\n * This method uses the Angular DatePipe to format the selected date with the specified language and updates the formatted date as a string.\r\n * @returns A formatted date string.\r\n * ```\r\n * // Format the selected date with language\r\n * const formatted = this.formatSelectedDate();\r\n * ```\r\n*/\r\n  private formatSelectedDate(): string {\r\n    return this.datePipe.transform(this.selectedDate, this.dateFormat, this.lang) || '';\r\n  }\r\n\r\n/**\r\n * Update the input value displayed in the calendar interface.\r\n * This method updates the input value to either the edited date or the formatted selected date,\r\n * depending on whether the user is in edit mode or not.\r\n * ```\r\n * // Update the input value\r\n * this.updateInputValue();\r\n * ```\r\n*/\r\n  private updateInputValue() {\r\n    this.formattedDate = this.isEditing ? this.editedDate : this.formatSelectedDate();\r\n  }\r\n\r\n/**\r\n * Get an array of arrays representing the days of the current month.\r\n * Each sub-array contains the day data for a week, and each day data object includes the date and whether it belongs to the current month.\r\n * @returns An array of arrays representing the days of the current month.\r\n * ```\r\n * // Get an array of arrays representing the days of the current month\r\n * const calendar = this.calendarDays;\r\n * ```\r\n*/\r\n  private get calendarDays() {\r\n    return this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n/**\r\n * Get the date of the previous month to display in empty cells of the current month.\r\n * This method returns the date of the previous month if the provided date is not in the current month.\r\n * If the provided date is in the current month, it returns the date's day as a string.\r\n * @param date - The date to evaluate.\r\n * @returns The date of the previous month or a day string.\r\n * ```\r\n * // Get the previous month's date to display in empty cells\r\n * const previousMonthDate = this.getPreviousMonthDate(new Date(2023, 8, 1));\r\n * ```\r\n*/\r\n  private getPreviousMonthDate(date: Date): any {\r\n    if (!date) {\r\n      return '';\r\n    }\r\n    const currentDate = new Date();\r\n    if (date.getMonth() === currentDate.getMonth() && date.getFullYear() === currentDate.getFullYear()) {\r\n      return date.getDate().toString();\r\n    } else {\r\n      return this.datePipe.transform(date, 'dd');\r\n    }\r\n  }\r\n\r\n/**\r\n * Navigate to the previous month in the calendar interface.\r\n * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n * ```\r\n * // Navigate to the previous month\r\n * this.getPreviousMonth();\r\n * ```\r\n*/\r\n  private getPreviousMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth - 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n/**\r\n * Navigate to the next month in the calendar interface.\r\n * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n * ```\r\n * // Navigate to the next month\r\n * this.getNextMonth();\r\n * ```\r\n*/\r\n  private getNextMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth + 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n/**\r\n * Get the number of days in a given month of a specific year.\r\n * @param year - The year for which you want to determine the number of days.\r\n * @param month - The month (0-based index) for which you want to determine the number of days.\r\n * @returns The number of days in the specified month of the given year.\r\n*/\r\n  private daysInMonth(year: number, month: number): number {\r\n    return new Date(year, month + 1, 0).getDate();\r\n  }\r\n\r\n/**\r\n * Calculate the structure of days in a month for the calendar display.\r\n * This method generates a matrix of day data objects representing the days in the calendar.\r\n * Each day data object contains the date and whether it belongs to the current month.\r\n * @returns A matrix of day data objects for the calendar display.\r\n*/\r\n  private calculateFirstDayOfCalendar() {\r\n    const year = this.selectedDate.getFullYear();\r\n    const month = this.selectedDate.getMonth();\r\n    const firstDayOfMonth = new Date(year, month, 1);\r\n    const firstWeekday = firstDayOfMonth.getDay();\r\n    const startDay = firstWeekday === 0 ? -5 : 2 - firstWeekday;\r\n    const calendarDays = [];\r\n    let currentDay = startDay;\r\n    for (let i = 0; i < 6; i++) {\r\n      const week = [];\r\n      for (let j = 0; j < 7; j++) {\r\n        const day = new Date(year, month, currentDay);\r\n        const dayData = {\r\n          date: day,\r\n          isCurrentMonth: currentDay >= 1 && currentDay <= this.daysInMonth(year, month),\r\n        };\r\n        week.push(dayData);\r\n        currentDay++;\r\n      }\r\n      calendarDays.push(week);\r\n    }\r\n    return calendarDays;\r\n  }\r\n  \r\n/**\r\n * Check if a given date is the currently selected date in the calendar.\r\n * @param date - The date to check.\r\n * @returns `true` if the provided date matches the selected date, otherwise `false`.\r\n * ```\r\n * // Check if a date is selected\r\n * const isSelected = this.isDateSelected(someDate);\r\n * ```\r\n*/\r\n  private isDateSelected(date: Date) {\r\n    return date.toDateString() === this.selectedDate.toDateString();\r\n  }\r\n\r\n/**\r\n * Check if a date string is valid based on the specified date format.\r\n * @param inputDate - The date string to validate.\r\n * @returns `true` if the input date string is valid, otherwise `false`.\r\n * ```\r\n * // Check if a date string is valid\r\n * const isValidDate = this.isDateValid('05/25/2023');\r\n * ```\r\n*/\r\n  private isDateValid(inputDate: string): boolean {\r\n    return this.dateRegExp.test(inputDate);\r\n  }\r\n  \r\n/**\r\n * Check if a given date is today's date.\r\n * @param date - The date to check.\r\n * @returns `true` if the provided date is today's date, otherwise `false`.\r\n * ```\r\n * // Check if a date is today's date\r\n * const isToday = this.isDateToday(someDate);\r\n * ```\r\n*/\r\n  private isDateToday(date: Date) {\r\n    const today = new Date();\r\n    return date.toDateString() === today.toDateString();\r\n  }\r\n}","<div class=\"datepicker-container\"\r\n[class.disabled]=\"disabled\"\r\n>\r\n\r\n  <!-- Input, save & edit buttons -->\r\n    <div class=\"input-container\">\r\n\r\n      <div *ngIf=\"!isEditing\">\r\n\r\n        <input\r\n        type=\"text\"\r\n        (click)=\"toggleCalendar()\"\r\n        [value]=\"formattedDate\"\r\n        [readOnly]=\"true\"\r\n        [disabled]=\"isEditing\"\r\n      >\r\n      </div>\r\n        <!-- Edit -->\r\n        <i class=\"fa fa-pencil-square-o edit-button\" aria-hidden=\"true\" (click)=\"toggleEdit()\"></i> \r\n\r\n        <div *ngIf=\"isEditing\">\r\n            <input\r\n            type=\"text\"\r\n            [value]=\"editedDate\"\r\n            (input)=\"onDateInput($event)\"\r\n            class=\"border-3\"\r\n            (click)=\"toggleCalendar()\"\r\n            >\r\n            <i class=\"fa fa-floppy-o edit-button\" (click)=\"saveEditedDate()\" aria-hidden=\"true\"></i>\r\n     </div>     \r\n    </div>\r\n\r\n<!-- Calendar(Dropdowns, dates) -->\r\n  <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer \r\n  [style.top]=\"topOffset\"\r\n  [style.left]=\"leftOffset\">\r\n    <div class=\"calendar-header\">\r\n        <div class=\"monthButtonContainer\">\r\n            <!-- Month dropdown -->\r\n            <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n              <mefdev-select    \r\n              class=\"monthDropdown\"\r\n              [(ngModel)]=\"selectedDateMonth\" \r\n              (ngModelChange)=\"onMonthChange()\"\r\n              [PlaceHolder]=\"'month'\"\r\n              >\r\n                <mefdev-option \r\n                *ngFor=\"let month of months; let i = index\" \r\n                [Value]=\"i\"\r\n                [Label] = \"month\" \r\n                \r\n                >{{ month }}</mefdev-option>\r\n              </mefdev-select>\r\n            </ng-container>\r\n            <ng-template #monthLabel>\r\n              <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n            </ng-template>\r\n\r\n            <!-- Year dropdown -->\r\n            <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n              <mefdev-select \r\n              class=\"yearDropdown\" \r\n              [(ngModel)]=\"selectedDateYear\" \r\n              (ngModelChange)=\"onYearChange()\"\r\n              [PlaceHolder]=\"'year'\"\r\n              >\r\n                  <mefdev-option \r\n                  *ngFor=\"let year of years\" \r\n                  [Label] = \"year\" \r\n                  [Value]=\"year\" \r\n                  >{{year}}</mefdev-option>\r\n              </mefdev-select>\r\n            </ng-container>\r\n            <ng-template #yearLabel>\r\n              <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n            </ng-template>\r\n           </div>\r\n           <!-- Calendar exit button -->\r\n           <div>\r\n            <i class=\"fa fa-times toggleCalendarButton\" (click)=\"toggleCalendar()\" aria-hidden=\"true\"></i>\r\n            </div>\r\n    </div>\r\n    \r\n    <div class=\"calendar-body\">\r\n      <table>\r\n        <tr>\r\n          <th class=\"align-items-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n        </tr>\r\n        <tr *ngFor=\"let week of calendarDays\">\r\n          <td *ngFor=\"let dayData of week\" \r\n              (click)=\"selectDate(dayData.date)\"\r\n              [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n            <span class=\"date\" \r\n              [class.prev-month]=\"!dayData.isCurrentMonth\"\r\n              >\r\n              {{ dayData.date.getDate() }}\r\n            </span>\r\n          </td>\r\n        </tr>\r\n      </table>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n"]}
607
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.ts","../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { DatePipe } from '@angular/common';\r\n\r\n/**\r\n * Datepicker Component for selecting dates.\r\n *\r\n * This component allows users to pick a date from a calendar interface.\r\n * It supports various configuration options such as language, date format, and date range.\r\n *\r\n * @example\r\n * <mefdev-datepicker\r\n *   [labelContentText]=\"'Select your date'\"\r\n *   [lang]=\"'uk'\"\r\n *   [dateFormat]=\"'dd/MM/yyyy'\"\r\n *   [range]=\"{startYear: 1900, toYear: 300}\"\r\n *   [disabled]=\"false\"\r\n *   (dateChanged)=\"onDateChanged($event)\"\r\n *   [topOffset]=\"'20'\"\r\n *   [leftOffset]=\"'10'\">\r\n * </mefdev-datepicker>\r\n *\r\n * <example-url>https://mef.dev/ui_kit_demo/view/utils/datepicker</example-url>\r\n */\r\n\r\n@Component({\r\n  selector: 'mefdev-datepicker',\r\n  templateUrl: './datepicker.component.html',\r\n  styleUrls: ['./datepicker.component.scss']\r\n})\r\n\r\nexport class DatepickerComponent implements  OnChanges, OnInit {\r\n\r\n  /**\r\n   * A flag that checks whether a valid date has been entered and whether the entered date exists.\r\n   * If the two previous conditions are not true, the datepicker will be highlighted in red\r\n   */\r\n  isUserDateValid: boolean = true;\r\n\r\n  /**\r\n   * Flag to determine if the calendar is open or closed.\r\n   * Default value: false (closed).\r\n   */\r\n  isCalendarOpen: boolean = false;\r\n\r\n  /**\r\n   * The currently selected date.\r\n   * Default value: Today's date.\r\n   */\r\n  selectedDate: Date = new Date();\r\n\r\n  /**\r\n   * The formatted date for display in the input.\r\n   * Default value: Formatted representation of the selected date.\r\n   */\r\n  formattedDate: any ;\r\n\r\n  /**\r\n   * Track the edited date separately when in editing mode.\r\n   * Default value: An empty string.\r\n   */\r\n  editedDate: string = '';\r\n\r\n  /**\r\n   * Flag to determine if the month dropdown is open or closed.\r\n   * Default value: true (open).\r\n   */\r\n  isMonthDropdownOpen: boolean = true;\r\n\r\n  /**\r\n   * Flag to determine if the year dropdown is open or closed.\r\n   * Default value: true (open).\r\n   */\r\n  isYearDropdownOpen: boolean = true;\r\n\r\n  /**\r\n   * The selected month (0-11).\r\n   * Default value: The month of the selected date.\r\n   */\r\n  selectedDateMonth: number = this.selectedDate.getMonth();\r\n\r\n  /**\r\n   * The selected year.\r\n   * Default value: The year of the selected date.\r\n   */\r\n  selectedDateYear: number = this.selectedDate.getFullYear();\r\n\r\n  /**\r\n   * An array of years for the year dropdown.\r\n   * Default value: An array of years within the specified range.\r\n   */\r\n  years: number[]\r\n\r\n  /**\r\n   * Label text for the datepicker.\r\n   * Default value: 'en' (English).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [labelContentText] = \"'Chose your date'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() labelContentText: string;\r\n\r\n  /**\r\n   * The language/locale for the datepicker.\r\n   * Default value: 'en' (English).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [lang] = \"'uk'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() lang: string = 'en';\r\n\r\n  /**\r\n   * The date format for displaying the selected date.\r\n   * Default value: 'EEE MMM dd yyyy'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [dateFormat]=\"'dd/MM/yyyy'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() dateFormat: string = 'EEE MMM dd yyyy';\r\n\r\n  /**\r\n   * The range of years available in the year dropdown.\r\n   * Default value: { startYear: 1900, toYear: 300 }.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [range]=\"{startYear: 1900, toYear: 300}\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input('range') yearsRange:{startYear:number, toYear:number} = {startYear:1900, toYear:300};\r\n\r\n  /**\r\n   * Whether the datepicker is disabled or not.\r\n   * Default value: false (enabled).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [disabled]=\"false\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() disabled: boolean = false;\r\n\r\n  /**\r\n   * The top offset for positioning the datepicker.\r\n   * Default value: '20'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [topOffset]=\"'20'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() topOffset: string = '20';\r\n\r\n  /**\r\n   * The left offset for positioning the datepicker.\r\n   * Default value: '10'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [leftOffset]=\"'10'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() leftOffset: string = '10'; //Default value\r\n\r\n  /**\r\n   * Event emitted when the selected date in the datepicker changes.\r\n   * It emits a `Date` object representing the selected date.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   (dateChanged)=\"onDateChanged($event)\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Output() dateChanged: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  /**\r\n   * Regular expression to validate user input for date in the format \"dd/MM/yyyy\".\r\n   * - The day (dd) should be between 01 and 31.\r\n   * - The month (MM) should be between 01 and 12.\r\n   * - The year (yyyy) should be a 4-digit number.\r\n   */\r\n  private dateRegExp: RegExp = /^(0[1-9]|[12][0-9]|3[01])\\/(0[1-9]|1[0-2])\\/\\d{4}$/;\r\n\r\n  /**\r\n   * The string entered by the user for date input.\r\n   * This variable stores the user's input as they type in the date field.\r\n   */\r\n  userInput: string = '';\r\n\r\n  /**\r\n   * Host listener for document click events to handle calendar interaction.\r\n   * This function checks if a click event occurred within the calendar or input elements.\r\n   * - If the click occurred within the calendar, no action is taken.\r\n   * - If the click occurred within the input element and the component is not in editing mode,\r\n   *   it opens the calendar.\r\n   * @param event The MouseEvent object representing the click event.\r\n   */\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent) {\r\n    const targetElement = event.target as HTMLElement;\r\n    const datepickerContainer = this.elementRef.nativeElement.querySelector('.datepicker-container');\r\n    const calendar = this.elementRef.nativeElement.querySelector('.calendar');\r\n    const monthDropdown = this.elementRef.nativeElement.querySelector('.monthDropdown');\r\n    const yearDropdown = this.elementRef.nativeElement.querySelector('.yearDropdown');\r\n    const inputElement = this.elementRef.nativeElement.querySelector('input');\r\n\r\n    if (datepickerContainer && datepickerContainer.contains(calendar)) {\r\n      if (calendar && calendar.contains(targetElement)) return;\r\n      if (this.isMonthDropdownOpen && !calendar.contains(targetElement)) return;\r\n      if (this.isYearDropdownOpen && !calendar.contains(targetElement)) return;\r\n      if ((monthDropdown && monthDropdown.contains(targetElement)) && (yearDropdown && yearDropdown.contains(targetElement))) {\r\n        this.toggleMonthDropdown(event)\r\n        this.toggleYearDropdown(event)\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Constructor for the DatepickerComponent class.\r\n   * @param datePipe A service for formatting and parsing dates.\r\n   * @param elementRef A reference to the element on which this component is attached.\r\n   * It is used to access DOM elements.\r\n   */\r\n  constructor(private datePipe: DatePipe, private elementRef: ElementRef) {\r\n    this.updateInputValue()\r\n  }\r\n\r\n  /**\r\n   * Lifecycle hook called after the component is initialized.\r\n   * It initializes the years for the year select dropdown.\r\n   */\r\n  ngOnInit(){\r\n    this.initializeYears();\r\n  }\r\n\r\n  /**\r\n   * Lifecycle hook called whenever the input properties of the component change.\r\n   * It updates the input value.\r\n   */\r\n  ngOnChanges() {\r\n    this.updateInputValue();\r\n  }\r\n\r\n  /**\r\n   * An array of month names based on the selected language.\r\n   * It provides localized month names for display in the datepicker.\r\n   */\r\n  private get months(){\r\n    return this.getMonthList(this.lang);\r\n  }\r\n\r\n  /**\r\n   * An array of weekday names based on the selected language.\r\n   * It provides localized weekday names for display in the datepicker.\r\n   */\r\n  private get weekdays() {\r\n    return this.getWeekdayList(this.lang);\r\n  }\r\n\r\n  /**\r\n   * Initialize the list of years to be displayed in the year dropdown.\r\n   * This method populates the 'years' array with a range of years based on the provided 'yearsRange' configuration.\r\n   * @example\r\n   * ```\r\n   * // Assuming 'yearsRange' is { startYear: 1900, toYear: 300 }\r\n   * // After calling initializeYears(), 'years' might contain [1900, 1901, ..., 300]\r\n   * this.initializeYears();\r\n   * ```\r\n   */\r\n  private initializeYears() {\r\n    this.years = Array.from({ length: this.yearsRange.toYear }, (_, index) => index + this.yearsRange.startYear);\r\n  }\r\n\r\n  /**\r\n   * Toggle the editing mode for the date input. When enabled, the user can edit the date directly in the input field.\r\n   */\r\n  toggleEdit() {\r\n    this.editedDate = this.formatSelectedDate(); // Store the current formatted date for editing\r\n    this.isCalendarOpen = false;\r\n  }\r\n\r\n  /**\r\n   * Get a list of month names in the specified language and format.\r\n   * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n   * @param format - The format for month names, either \"long\" (default) or \"short\".\r\n   * @returns An array of month names based on the provided format and locale.\r\n   * ```\r\n   * // Get a list of month names in the default language and long format\r\n   * const months = this.getMonthList(this.lang);\r\n   * ```\r\n   */\r\n  private getMonthList(  locales?: string | string[],  format: \"long\" | \"short\" = \"long\"): string[] {\r\n    const year = new Date().getFullYear();\r\n    const monthList = [...Array(12).keys()];\r\n    const formatter = new Intl.DateTimeFormat(locales, {    month: format  });\r\n    const getMonthName = (monthIndex: number) => formatter.format(new Date(year, monthIndex));\r\n    return monthList.map(getMonthName);\r\n  }\r\n\r\n  /**\r\n   * Get a list of weekday names in the specified language and format.\r\n   * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n   * @param format - The format for weekday names, either \"short\" (default) or \"long\".\r\n   * @returns An array of weekday names based on the provided format and locale.\r\n   * ```\r\n   * // Get a list of weekday names in the default language and short format\r\n   * const weekdays = this.getWeekdayList();\r\n   * ```\r\n   */\r\n  private getWeekdayList(locales?: string | string[], format: \"short\" | \"long\" = \"short\"): string[] {\r\n    const weekdays = [...Array(7).keys()];\r\n    const mondayIndex = weekdays.indexOf(0);\r\n    weekdays.splice(mondayIndex, 1);\r\n    weekdays.push(0);\r\n    const formatter = new Intl.DateTimeFormat(locales, { weekday: format });\r\n    const getWeekdayName = (weekdayIndex: number) => {\r\n      return formatter.format(new Date(2023, 9, weekdayIndex + 1));\r\n    };\r\n    return weekdays.map(getWeekdayName);\r\n  }\r\n\r\n  /**\r\n   * Save the edited date input by the user, provided it matches the specified date format.\r\n   * This method checks if the entered date is in a valid format, disables the editing mode, and applies\r\n   * the edited date to the 'selectedDate'. It then reformats the selected date and closes the calendar.\r\n   * ```\r\n   * // Save the edited date and update the selected date\r\n   * this.saveEditedDate();\r\n   * ```\r\n   */\r\n  private saveEditedDate() {\r\n    if (this.isDateValid(this.editedDate)) {\r\n      const [day, month, year] = this.editedDate.split('/');\r\n      this.selectedDate = new Date(+year, +month - 1, +day);\r\n      this.formatDate();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle user input in the editable input field for date editing. This method captures the input value\r\n   * and stores it in the 'editedDate' variable. If the input matches the valid date format, it updates\r\n   * 'selectedDateMonth' and 'selectedDateYear' accordingly.\r\n   * @param event - The input event containing the user's input.\r\n   * ```\r\n   * // Handle user input in the editable input field\r\n   * this.onDateInput(event);\r\n   * ```\r\n   */\r\n  public onDateInput(event: any) {\r\n    const inputDate: string = event.target.value;\r\n    if (this.isDateValid(inputDate)) {\r\n      this.editedDate = inputDate;\r\n      const parsedDate = inputDate.split('/');\r\n      this.selectedDateMonth = +parsedDate[1] - 1;\r\n      this.selectedDateYear = +parsedDate[2];\r\n      this.selectedDate = new Date(+parsedDate[2], +parsedDate[1] - 1, +parsedDate[0]);\r\n      this.calculateFirstDayOfCalendar();\r\n    }\r\n    this.isUserDateValid = this.isDateValid(inputDate);\r\n  }\r\n\r\n  /**\r\n   * Toggle the visibility of the month dropdown in the calendar interface.\r\n   * This method is used to open or close the dropdown for selecting months.\r\n   * @param event - The event triggering the toggle action (e.g., a click event).\r\n   * ```\r\n   * // Toggle the visibility of the month dropdown\r\n   * this.toggleMonthDropdown(event);\r\n   * ```\r\n   */\r\n  private toggleMonthDropdown(event: Event) {\r\n    this.isMonthDropdownOpen = !this.isMonthDropdownOpen;\r\n  }\r\n\r\n  /**\r\n   * Toggle the visibility of the year dropdown in the calendar interface.\r\n   * This method is used to open or close the dropdown for selecting years.\r\n   * @param event - The event triggering the toggle action (e.g., a click event).\r\n   * ```\r\n   * // Toggle the visibility of the year dropdown\r\n   * this.toggleYearDropdown(event);\r\n   * ```\r\n   */\r\n  private toggleYearDropdown(event: Event) {\r\n    this.isYearDropdownOpen = !this.isYearDropdownOpen;\r\n  }\r\n\r\n  /**\r\n   * Handle the change of the selected month in the calendar interface.\r\n   * This method updates the input value, sets the selected date to the first day of the chosen month,\r\n   * and recalculates the calendar display accordingly.\r\n   * ```\r\n   * // Handle the change of the selected month\r\n   * this.onMonthChange();\r\n   * ```\r\n   */\r\n  private onMonthChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Handle the change of the selected year in the calendar interface.\r\n   * This method updates the input value, sets the selected date to the first day of the chosen year,\r\n   * reformats the selected date, and recalculates the calendar display.\r\n   * ```\r\n   * // Handle the change of the selected year\r\n   * this.onYearChange();\r\n   * ```\r\n   */\r\n  private onYearChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n\r\n  /**\r\n   * Select a date in the calendar interface and perform necessary updates.\r\n   * This method sets the selected date, formats it, closes the calendar, and emits a dateChanged event.\r\n   * It also updates the selected month and year dropdown values.\r\n   * @param date - The date to be selected in the calendar.\r\n   */\r\n  selectDate(date: Date) {\r\n    this.selectedDate = date;\r\n    this.formatDate();\r\n    this.isCalendarOpen = false;\r\n    this.dateChanged.next(this.selectedDate);\r\n    this.selectedDateMonth = this.selectedDate.getMonth();\r\n    this.selectedDateYear = this.selectedDate.getFullYear();\r\n  }\r\n\r\n  /**\r\n   * Format the selected date based on the chosen date format and language.\r\n   * This method uses the Angular DatePipe to format the selected date and updates the formattedDate variable.\r\n   * ```\r\n   * // Format the selected date\r\n   * this.formatDate();\r\n   * ```\r\n   */\r\n  private formatDate() {\r\n    this.formattedDate = this.datePipe.transform(this.selectedDate, this.dateFormat) || '';\r\n  }\r\n\r\n  /**\r\n   * Format the selected date based on the chosen date format, language, and locale.\r\n   * This method uses the Angular DatePipe to format the selected date with the specified language and updates the formatted date as a string.\r\n   * @returns A formatted date string.\r\n   * ```\r\n   * // Format the selected date with language\r\n   * const formatted = this.formatSelectedDate();\r\n   * ```\r\n   */\r\n  private formatSelectedDate(): string {\r\n    return this.datePipe.transform(this.selectedDate, this.dateFormat, this.lang) || '';\r\n  }\r\n\r\n  /**\r\n   * Update the input value displayed in the calendar interface.\r\n   * This method updates the input value to either the edited date or the formatted selected date,\r\n   * depending on whether the user is in edit mode or not.\r\n   * ```\r\n   * // Update the input value\r\n   * this.updateInputValue();\r\n   * ```\r\n   */\r\n  private updateInputValue() {\r\n    this.formattedDate = this.isCalendarOpen ? this.editedDate : this.formatSelectedDate();\r\n  }\r\n\r\n  /**\r\n   * Get an array of arrays representing the days of the current month.\r\n   * Each sub-array contains the day data for a week, and each day data object includes the date and whether it belongs to the current month.\r\n   * @returns An array of arrays representing the days of the current month.\r\n   * ```\r\n   * // Get an array of arrays representing the days of the current month\r\n   * const calendar = this.calendarDays;\r\n   * ```\r\n   */\r\n  private get calendarDays() {\r\n    return this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Get the date of the previous month to display in empty cells of the current month.\r\n   * This method returns the date of the previous month if the provided date is not in the current month.\r\n   * If the provided date is in the current month, it returns the date's day as a string.\r\n   * @param date - The date to evaluate.\r\n   * @returns The date of the previous month or a day string.\r\n   * ```\r\n   * // Get the previous month's date to display in empty cells\r\n   * const previousMonthDate = this.getPreviousMonthDate(new Date(2023, 8, 1));\r\n   * ```\r\n   */\r\n  private getPreviousMonthDate(date: Date): any {\r\n    if (!date) {\r\n      return '';\r\n    }\r\n    const currentDate = new Date();\r\n    if (date.getMonth() === currentDate.getMonth() && date.getFullYear() === currentDate.getFullYear()) {\r\n      return date.getDate().toString();\r\n    } else {\r\n      return this.datePipe.transform(date, 'dd');\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Navigate to the previous month in the calendar interface.\r\n   * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n   * ```\r\n   * // Navigate to the previous month\r\n   * this.getPreviousMonth();\r\n   * ```\r\n   */\r\n  private getPreviousMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth - 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Navigate to the next month in the calendar interface.\r\n   * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n   * ```\r\n   * // Navigate to the next month\r\n   * this.getNextMonth();\r\n   * ```\r\n   */\r\n  private getNextMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth + 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n\r\n  /**\r\n   * Get the number of days in a given month of a specific year.\r\n   * @param year - The year for which you want to determine the number of days.\r\n   * @param month - The month (0-based index) for which you want to determine the number of days.\r\n   * @returns The number of days in the specified month of the given year.\r\n   */\r\n  private daysInMonth(year: number, month: number): number {\r\n    return new Date(year, month + 1, 0).getDate();\r\n  }\r\n\r\n  /**\r\n   * Calculate the structure of days in a month for the calendar display.\r\n   * This method generates a matrix of day data objects representing the days in the calendar.\r\n   * Each day data object contains the date and whether it belongs to the current month.\r\n   * @returns A matrix of day data objects for the calendar display.\r\n   */\r\n  private calculateFirstDayOfCalendar() {\r\n    const year = this.selectedDate.getFullYear();\r\n    const month = this.selectedDate.getMonth();\r\n    const firstDayOfMonth = new Date(year, month, 1);\r\n    const firstWeekday = firstDayOfMonth.getDay();\r\n    const startDay = firstWeekday === 0 ? -5 : 2 - firstWeekday;\r\n    const calendarDays = [];\r\n    let currentDay = startDay;\r\n    for (let i = 0; i < 6; i++) {\r\n      const week = [];\r\n      for (let j = 0; j < 7; j++) {\r\n        const day = new Date(year, month, currentDay);\r\n        const dayData = {\r\n          date: day,\r\n          isCurrentMonth: currentDay >= 1 && currentDay <= this.daysInMonth(year, month),\r\n        };\r\n        week.push(dayData);\r\n        currentDay++;\r\n      }\r\n      calendarDays.push(week);\r\n    }\r\n    return calendarDays;\r\n  }\r\n\r\n  /**\r\n   * Check if a given date is the currently selected date in the calendar.\r\n   * @param date - The date to check.\r\n   * @returns `true` if the provided date matches the selected date, otherwise `false`.\r\n   * ```\r\n   * // Check if a date is selected\r\n   * const isSelected = this.isDateSelected(someDate);\r\n   * ```\r\n   */\r\n  private isDateSelected(date: Date) {\r\n    return date.toDateString() === this.selectedDate.toDateString();\r\n  }\r\n\r\n  /**\r\n   * Check if a date string is valid based on the specified date format.\r\n   * It also checks whether the specified number, month is correct and whether the specified one exists among calendar years\r\n   * @param inputDate - The date string to validate.\r\n   * @returns `true` if the input date string is valid, otherwise `false`.\r\n   * ```\r\n   * // Check if a date string is valid\r\n   * const isValidDate = this.isDateValid('05/25/2023');\r\n   * ```\r\n   */\r\n  private isDateValid(inputDate: string) {\r\n    if (!this.dateRegExp.test(inputDate)) {\r\n      return false;\r\n    }\r\n\r\n    const parts = inputDate.split('/');\r\n    const day = parseInt(parts[0], 10);\r\n    const month = parseInt(parts[1], 10);\r\n    const year = parseInt(parts[2], 10);\r\n\r\n    if (year > this.years[this.years.length - 1] || year < this.years[0]) {\r\n      return false\r\n    }\r\n\r\n    const daysInMonth = new Date(year, month, 0).getDate();\r\n    return day <= daysInMonth;\r\n  }\r\n\r\n  /**\r\n   * Check if a given date is today's date.\r\n   * @param date - The date to check.\r\n   * @returns `true` if the provided date is today's date, otherwise `false`.\r\n   * ```\r\n   * // Check if a date is today's date\r\n   * const isToday = this.isDateToday(someDate);\r\n   * ```\r\n   */\r\n  private isDateToday(date: Date) {\r\n    const today = new Date();\r\n    return date.toDateString() === today.toDateString();\r\n  }\r\n}\r\n","<div class=\"datepicker-container\" [class.disabled]=\"disabled\">\r\n\r\n  <!-- Input, save & edit buttons -->\r\n    <div class=\"input-container form-group\">\r\n        <label *ngIf=\"labelContentText\" class=\"form-label\"> {{ labelContentText }} </label>\r\n        <input\r\n          [ngClass]=\"{ 'calendarNotOpened': !isCalendarOpen }\"\r\n          [ngStyle]=\"{ 'border-color': isUserDateValid ? '' : 'red' }\"\r\n          type=\"text\"\r\n          class=\"form-control\"\r\n          (input)=\"onDateInput($event)\"\r\n          (click)=\"isCalendarOpen = true\"\r\n          [value]=\"formattedDate\"\r\n          [readOnly]=\"!isCalendarOpen\"\r\n        >\r\n    </div>\r\n\r\n  <!-- Calendar(Dropdowns, dates) -->\r\n  <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer\r\n       [style.top]=\"topOffset\"\r\n       [style.left]=\"leftOffset\">\r\n    <div class=\"calendar-header\">\r\n      <div class=\"monthButtonContainer\">\r\n        <!-- Month dropdown -->\r\n        <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n          <mefdev-select\r\n            class=\"monthDropdown\"\r\n            [(ngModel)]=\"selectedDateMonth\"\r\n            (ngModelChange)=\"onMonthChange()\"\r\n            [PlaceHolder]=\"'month'\"\r\n          >\r\n            <mefdev-option\r\n              *ngFor=\"let month of months; let i = index\"\r\n              [Value]=\"i\"\r\n              [Label]=\"month\"\r\n              style=\"z-index: 1\"\r\n            >{{ month }}</mefdev-option>\r\n          </mefdev-select>\r\n        </ng-container>\r\n        <ng-template #monthLabel>\r\n          <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n        </ng-template>\r\n\r\n        <!-- Year dropdown -->\r\n        <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n          <mefdev-select\r\n            class=\"yearDropdown\"\r\n            [(ngModel)]=\"selectedDateYear\"\r\n            (ngModelChange)=\"onYearChange()\"\r\n            [PlaceHolder]=\"'year'\"\r\n          >\r\n            <mefdev-option\r\n              *ngFor=\"let year of years\"\r\n              [Label]=\"year\"\r\n              [Value]=\"year\"\r\n            >{{year}}</mefdev-option>\r\n          </mefdev-select>\r\n        </ng-container>\r\n        <ng-template #yearLabel>\r\n          <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n        </ng-template>\r\n      </div>\r\n      <!-- Calendar exit button -->\r\n      <div>\r\n        <i class=\"fa fa-times toggleCalendarButton\" (click)=\"isCalendarOpen = false\" aria-hidden=\"true\"></i>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"calendar-body\">\r\n      <table>\r\n        <tr>\r\n          <th class=\"text-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n        </tr>\r\n        <tr *ngFor=\"let week of calendarDays\">\r\n          <td *ngFor=\"let dayData of week\"\r\n              (click)=\"selectDate(dayData.date)\"\r\n              [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n            <span class=\"date\" [class.prev-month]=\"!dayData.isCurrentMonth\">\r\n              {{ dayData.date.getDate() }}\r\n            </span>\r\n          </td>\r\n        </tr>\r\n      </table>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}