@colijnit/corecomponents_v12 256.1.6 → 256.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/colijnit-corecomponents_v12.umd.js +86 -21
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/base-input-date-picker/base-input-date-picker.directive.js +2 -2
- package/esm2015/lib/components/calendar/calendar-template.component.js +59 -3
- package/esm2015/lib/components/calendar/calendar.component.js +2 -1
- package/esm2015/lib/components/calendar/calendar.module.js +4 -2
- package/esm2015/lib/components/double-calendar/double-calendar.component.js +29 -9
- package/esm2015/lib/components/input-date-picker/input-date-picker.component.js +4 -3
- package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +3 -1
- package/esm2015/lib/components/input-text/input-text.component.js +13 -3
- package/fesm2015/colijnit-corecomponents_v12.js +107 -16
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/calendar/calendar-template.component.d.ts +10 -0
- package/lib/components/calendar/style/_layout.scss +57 -4
- package/lib/components/calendar/style/_material-definition.scss +10 -10
- package/lib/components/double-calendar/double-calendar.component.d.ts +1 -0
- package/lib/components/input-text/input-text.component.d.ts +2 -0
- package/lib/style/_input.mixins.scss +1 -1
- package/package.json +1 -1
|
@@ -7,7 +7,7 @@ export class BaseInputDatePickerDirective extends BaseInputComponent {
|
|
|
7
7
|
this.rightIcon = CoreComponentsIcon.CalendarDayRegular;
|
|
8
8
|
this.locale = 'en-EN';
|
|
9
9
|
this.leftIconClick = new EventEmitter();
|
|
10
|
-
this.closeAfterDateSelection =
|
|
10
|
+
this.closeAfterDateSelection = false;
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
13
|
BaseInputDatePickerDirective.decorators = [
|
|
@@ -22,4 +22,4 @@ BaseInputDatePickerDirective.propDecorators = {
|
|
|
22
22
|
leftIconClick: [{ type: Output }],
|
|
23
23
|
closeAfterDateSelection: [{ type: Input }]
|
|
24
24
|
};
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1pbnB1dC1kYXRlLXBpY2tlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvYmFzZS1pbnB1dC1kYXRlLXBpY2tlci9iYXNlLWlucHV0LWRhdGUtcGlja2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFcEcsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFHN0UsTUFBTSxPQUFnQiw0QkFBNkIsU0FBUSxrQkFBdUI7SUFEbEY7O1FBRWtCLGNBQVMsR0FBdUIsa0JBQWtCLENBQUMsa0JBQWtCLENBQUM7UUFNL0UsV0FBTSxHQUFXLE9BQU8sQ0FBQztRQVl6QixrQkFBYSxHQUE2QixJQUFJLFlBQVksRUFBYyxDQUFDO1FBR3pFLDRCQUF1QixHQUFZLEtBQUssQ0FBQztJQUdsRCxDQUFDOzs7WUExQkEsU0FBUzs7OytCQUlQLFNBQVMsU0FBQyxrQkFBa0IsRUFBRSxFQUFDLElBQUksRUFBRSxVQUFVLEVBQUM7cUJBR2hELEtBQUs7MEJBR0wsS0FBSzt1QkFHTCxLQUFLOzJCQUdMLEtBQUs7NEJBR0wsTUFBTTtzQ0FHTixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBWaWV3Q2hpbGR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1NhZmVIdG1sfSBmcm9tIFwiQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3NlclwiO1xyXG5pbXBvcnQge0Jhc2VJbnB1dENvbXBvbmVudH0gZnJvbSBcIi4uL2Jhc2UvYmFzZS1pbnB1dC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtDb3JlQ29tcG9uZW50c0ljb259IGZyb20gXCIuLi8uLi9jb3JlL2VudW0vY29yZS1jb21wb25lbnRzLWljb24uZW51bVwiO1xyXG5cclxuQERpcmVjdGl2ZSgpXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlSW5wdXREYXRlUGlja2VyRGlyZWN0aXZlIGV4dGVuZHMgQmFzZUlucHV0Q29tcG9uZW50PGFueT4gaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIHB1YmxpYyByZWFkb25seSByaWdodEljb246IENvcmVDb21wb25lbnRzSWNvbiA9IENvcmVDb21wb25lbnRzSWNvbi5DYWxlbmRhckRheVJlZ3VsYXI7XHJcblxyXG4gIEBWaWV3Q2hpbGQoXCJwYXJlbnRGb3JPdmVybGF5XCIsIHtyZWFkOiBFbGVtZW50UmVmfSlcclxuICBwdWJsaWMgcGFyZW50Rm9yT3ZlcmxheTogRWxlbWVudFJlZjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbG9jYWxlOiBzdHJpbmcgPSAnZW4tRU4nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBwbGFjZWhvbGRlcjogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsZWZ0SWNvbjogQ29yZUNvbXBvbmVudHNJY29uO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsZWZ0SWNvbkRhdGE6IFNhZmVIdG1sO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgbGVmdEljb25DbGljazogRXZlbnRFbWl0dGVyPE1vdXNlRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxNb3VzZUV2ZW50PigpO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjbG9zZUFmdGVyRGF0ZVNlbGVjdGlvbjogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBwdWJsaWMgc2hvd0NhbGVuZGFyOiBib29sZWFuO1xyXG59XHJcbiJdfQ==
|
|
@@ -7,8 +7,13 @@ export class CalendarTemplateComponent {
|
|
|
7
7
|
this.weekNumbers = [];
|
|
8
8
|
this.locale = "nl-NL";
|
|
9
9
|
this.highlightDaysBetweenDates = false;
|
|
10
|
+
this.showButtons = true;
|
|
11
|
+
this.doubleCalendar = false;
|
|
10
12
|
this.dateSelected = new EventEmitter();
|
|
13
|
+
this.secondDateSelected = new EventEmitter();
|
|
11
14
|
this.hoveringDate = new EventEmitter();
|
|
15
|
+
this.clickedOutside = new EventEmitter();
|
|
16
|
+
this.clearDates = new EventEmitter();
|
|
12
17
|
this.showCalendarBody = true;
|
|
13
18
|
this.showMonthSelection = false;
|
|
14
19
|
this.showYearSelection = false;
|
|
@@ -23,9 +28,14 @@ export class CalendarTemplateComponent {
|
|
|
23
28
|
this.daysInMonth = [];
|
|
24
29
|
this.daysUnixTimestamps = [];
|
|
25
30
|
this.daysToHighlight = [];
|
|
31
|
+
this._initialSelectedDate = null;
|
|
26
32
|
}
|
|
27
33
|
set selectedDate(date) {
|
|
28
34
|
this._selectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;
|
|
35
|
+
// Store the initial selected date when the calendar is first opened
|
|
36
|
+
if (this._initialSelectedDate === null) {
|
|
37
|
+
this._initialSelectedDate = this._selectedDate;
|
|
38
|
+
}
|
|
29
39
|
if (this.secondSelectedDate && date && this.secondSelectedDate.getTime() < this.selectedDate.getTime() && this.temporarySelectedSecondaryDate) {
|
|
30
40
|
this.daysToHighlight = [];
|
|
31
41
|
}
|
|
@@ -162,7 +172,9 @@ export class CalendarTemplateComponent {
|
|
|
162
172
|
if (day) {
|
|
163
173
|
this.selectedDate = day;
|
|
164
174
|
this._fillDatesBetweenSelected();
|
|
165
|
-
|
|
175
|
+
if (this.doubleCalendar) {
|
|
176
|
+
this.dateSelected.emit(new Date(this.selectedDate));
|
|
177
|
+
}
|
|
166
178
|
}
|
|
167
179
|
}
|
|
168
180
|
selectMonth(month) {
|
|
@@ -191,7 +203,7 @@ export class CalendarTemplateComponent {
|
|
|
191
203
|
for (let i = 1; i <= 7; i++) {
|
|
192
204
|
const date = new Date(2018, 0, i);
|
|
193
205
|
const weekdayName = date.toLocaleString(this.locale, { weekday: 'short' });
|
|
194
|
-
this.dayNames.push(this._capitalizeFirstLetter(weekdayName));
|
|
206
|
+
this.dayNames.push(this._capitalizeFirstLetter(weekdayName.charAt(0)));
|
|
195
207
|
}
|
|
196
208
|
}
|
|
197
209
|
handleMouseOverDay(day) {
|
|
@@ -262,12 +274,46 @@ export class CalendarTemplateComponent {
|
|
|
262
274
|
const weekNumber = Math.ceil(((d.valueOf() - yearStart.valueOf()) / 86400000 + 1) / 7);
|
|
263
275
|
return weekNumber;
|
|
264
276
|
}
|
|
277
|
+
setAndClose() {
|
|
278
|
+
if (this.selectedDate) {
|
|
279
|
+
this.dateSelected.emit(this.selectedDate);
|
|
280
|
+
this.secondDateSelected.emit(this.secondSelectedDate); // Emit the selected date
|
|
281
|
+
this.closePopup(); // Trigger popup close
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
clearDate() {
|
|
285
|
+
if (this.selectedDate) {
|
|
286
|
+
this.selectedDate = null;
|
|
287
|
+
this.dateSelected.emit(null);
|
|
288
|
+
}
|
|
289
|
+
if (this.secondSelectedDate) {
|
|
290
|
+
this.secondSelectedDate = null;
|
|
291
|
+
this.secondDateSelected.emit(null);
|
|
292
|
+
}
|
|
293
|
+
this.clearDates.emit();
|
|
294
|
+
}
|
|
295
|
+
closeDate() {
|
|
296
|
+
this.selectedDate = this._initialSelectedDate;
|
|
297
|
+
this.closePopup(); // Trigger popup close without making changes
|
|
298
|
+
}
|
|
299
|
+
closePopup() {
|
|
300
|
+
this.clickedOutside.emit(); // Emit the `clickedOutside` event to notify the parent
|
|
301
|
+
}
|
|
265
302
|
}
|
|
266
303
|
CalendarTemplateComponent.decorators = [
|
|
267
304
|
{ type: Component, args: [{
|
|
268
305
|
selector: "calendar-template",
|
|
269
306
|
template: `
|
|
270
307
|
<div class="calendar">
|
|
308
|
+
<div class="selected-date-display">
|
|
309
|
+
<span *ngIf="selectedDate" class="selected-date-year">
|
|
310
|
+
{{ selectedDate.getFullYear() }}
|
|
311
|
+
</span>
|
|
312
|
+
<span *ngIf="selectedDate" class="selected-date-day">
|
|
313
|
+
{{ selectedDate | date: 'EEE d MMM' }}
|
|
314
|
+
</span>
|
|
315
|
+
<span *ngIf="!selectedDate" class="no-date-selected" [textContent]="'Selecteer datum'"></span>
|
|
316
|
+
</div>
|
|
271
317
|
<div class="calendar-header" *ngIf="monthSelection || yearSelection">
|
|
272
318
|
<co-icon class="calendar-change-month-button" [icon]="icons.ArrowPointLeft" (click)="prevMonth()"></co-icon>
|
|
273
319
|
|
|
@@ -325,6 +371,11 @@ CalendarTemplateComponent.decorators = [
|
|
|
325
371
|
</div>
|
|
326
372
|
</div>
|
|
327
373
|
</div>
|
|
374
|
+
<div class="calendar-action-buttons" *ngIf="showButtons">
|
|
375
|
+
<span class="set-and-close-button" (click)="setAndClose()">Instellen</span>
|
|
376
|
+
<span class="clear-date-button" (click)="clearDate()">Wissen</span>
|
|
377
|
+
<span class="cancel-button" (click)="closeDate()">Annuleren</span>
|
|
378
|
+
</div>
|
|
328
379
|
</div>
|
|
329
380
|
`,
|
|
330
381
|
encapsulation: ViewEncapsulation.None
|
|
@@ -334,11 +385,16 @@ CalendarTemplateComponent.propDecorators = {
|
|
|
334
385
|
showWeekNumbers: [{ type: Input }],
|
|
335
386
|
locale: [{ type: Input }],
|
|
336
387
|
highlightDaysBetweenDates: [{ type: Input }],
|
|
388
|
+
showButtons: [{ type: Input }],
|
|
389
|
+
doubleCalendar: [{ type: Input }],
|
|
337
390
|
selectedDate: [{ type: Input }],
|
|
338
391
|
secondSelectedDate: [{ type: Input }],
|
|
339
392
|
secondHoveringDate: [{ type: Input }],
|
|
340
393
|
dateSelected: [{ type: Output }],
|
|
394
|
+
secondDateSelected: [{ type: Output }],
|
|
341
395
|
hoveringDate: [{ type: Output }],
|
|
396
|
+
clickedOutside: [{ type: Output }],
|
|
397
|
+
clearDates: [{ type: Output }],
|
|
342
398
|
showClass: [{ type: HostBinding, args: ["class.calendar-template",] }]
|
|
343
399
|
};
|
|
344
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-template.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/calendar/calendar-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\n\r\n@Component({\r\n  selector: \"calendar-template\",\r\n  template: `\r\n      <div class=\"calendar\">\r\n        <div class=\"calendar-header\" *ngIf=\"monthSelection || yearSelection\">\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointLeft\" (click)=\"prevMonth()\"></co-icon>\r\n\r\n          <div class=\"calendar-header-title-wrapper\">\r\n            <span class=\"calendar-header-title\" [textContent]=\"monthSelection ? monthHeader : yearHeader\"\r\n                  (click)=\"monthSelection ? openMonthSelection() : openYearSelection()\"\r\n            ></span>\r\n          </div>\r\n\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointRight\" (click)=\"nextMonth()\"></co-icon>\r\n        </div>\r\n\r\n        <div class=\"selection-grid month\" *ngIf=\"showMonthSelection\">\r\n          <div *ngFor=\"let month of monthSelectionNames\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectMonth(month)\">\r\n            <ng-container *ngIf=\"month\">\r\n              <div class=\"month\" [textContent]=\"month\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"selection-grid year\" *ngIf=\"showYearSelection\">\r\n          <div *ngFor=\"let year of yearSelectionYears\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectYear(year)\"\r\n               [textContent]=\"year\">\r\n            <ng-container *ngIf=\"year\">\r\n              <div class=\"year\" [textContent]=\"year\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n        <div class=\"calendar-wrapper\">\r\n          <div class=\"week-wrapper\" *ngIf=\"showWeekNumbers && showCalendarBody\">\r\n            <div class=\"week-number\" [textContent]=\"'W'\"></div>\r\n            <div class=\"week-number\" *ngFor=\"let weekNumber of weekNumbers\">\r\n              {{ weekNumber }}\r\n            </div>\r\n          </div>\r\n          <div class=\"calendar-body\" *ngIf=\"showCalendarBody\">\r\n            <div class=\"day-names\">\r\n              <div class=\"weekday\" *ngFor=\"let dayName of dayNames\" [textContent]=\"dayName\"></div>\r\n            </div>\r\n            <div *ngFor=\"let day of daysInMonth\" class=\"calendar-day\"\r\n                 [class.highlighted-day]=\"daysToHighlight.includes(day)\"\r\n                 [class.selected-day]=\"selectedDate && (day && day.getTime() === selectedDate.getTime()) ||\r\n            secondSelectedDate && (day && day.getTime() === secondSelectedDate.getTime()) ||\r\n            temporarySelectedSecondaryDate && (day && day.getTime() === temporarySelectedSecondaryDate.getTime())\"\r\n                 (click)=\"selectDate(day)\"\r\n                 (mouseover)=\"handleMouseOverDay(day)\">\r\n              <!-- Day number -->\r\n              <ng-container *ngIf=\"day\">\r\n                <div class=\"day-number\" [textContent]=\"day.getDate()\"></div>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class CalendarTemplateComponent {\r\n  public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public showWeekNumbers: boolean = true;\r\n\r\n  public weekNumbers: number[] = [];\r\n  @Input()\r\n  public locale: string = \"nl-NL\";\r\n\r\n  @Input()\r\n  public highlightDaysBetweenDates: boolean = false;\r\n\r\n  @Input()\r\n  public set selectedDate(date: Date) {\r\n    this._selectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n    if (this.secondSelectedDate && date && this.secondSelectedDate.getTime() < this.selectedDate.getTime() && this.temporarySelectedSecondaryDate) {\r\n      this.daysToHighlight = [];\r\n    }\r\n  }\r\n\r\n  public get selectedDate(): Date {\r\n    return this._selectedDate;\r\n  }\r\n\r\n  @Input()\r\n  public set secondSelectedDate(date: Date) {\r\n    this._secondSelectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n    if (!this.selectedDate) {\r\n      this.daysToHighlight = [];\r\n    } else {\r\n      this._fillDatesBetweenSelected();\r\n    }\r\n  }\r\n\r\n  public get secondSelectedDate(): Date {\r\n    return this._secondSelectedDate;\r\n  }\r\n\r\n  @Input()\r\n  public set secondHoveringDate(date : Date) {\r\n    this._secondHoveringDate = date;\r\n    if (!!date) {\r\n      this.temporarySelectedSecondaryDate = null;\r\n    }\r\n    if (this.selectedDate && !this.secondSelectedDate) {\r\n      this.temporarySelectedSecondaryDate = new Date(date);\r\n    }\r\n    this.handleMouseOverDay(date);\r\n  }\r\n\r\n  public get secondHoveringDate(): Date {\r\n    return this._secondHoveringDate;\r\n  }\r\n\r\n  @Output()\r\n  public dateSelected: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public hoveringDate: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  public showCalendarBody: boolean = true;\r\n  public showMonthSelection: boolean = false;\r\n  public showYearSelection: boolean = false;\r\n  public showSelectedMonth: string;\r\n\r\n  public workingDay: Date;\r\n  public workingYear: number;\r\n  public workingMonth: number;\r\n\r\n  public monthHeader: string = '';\r\n  public yearHeader: string = '';\r\n\r\n  public monthSelection: boolean = true;\r\n  public yearSelection: boolean = false;\r\n\r\n  public dayNames = [];\r\n  public monthNames = [];\r\n  public monthSelectionNames: string[] = [];\r\n  public yearSelectionYears: number[] = [];\r\n  public daysInMonth: Date[] = [];\r\n\r\n  public daysUnixTimestamps: number[] = [];\r\n  public daysToHighlight: Date[] = [];\r\n  public temporarySelectedSecondaryDate: Date;\r\n\r\n  private _secondHoveringDate: Date;\r\n  private _secondSelectedDate: Date;\r\n  private _selectedDate: Date;\r\n\r\n  @HostBinding(\"class.calendar-template\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this._setInitialValues();\r\n    this.generateMonthNames();\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n  }\r\n\r\n  public prevMonth(): void {\r\n    if (this.workingMonth === 0) {\r\n      this.workingMonth = 11;\r\n      this.workingYear--;\r\n    } else {\r\n      this.workingMonth--;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  public nextMonth(): void {\r\n    if (this.workingMonth === 11) {\r\n      this.workingMonth = 0;\r\n      this.workingYear++;\r\n    } else {\r\n      this.workingMonth++;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  public prevYear(): void {\r\n    this.workingYear--;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public nextYear(): void {\r\n    this.workingYear++;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateCalendar(): void {\r\n    this._setMonthDaysForDate(this.workingMonth);\r\n\r\n    // Update the displayed month\r\n    const month = this.monthNames[this.workingMonth];\r\n    const year = this.workingYear;\r\n\r\n    // Update headerText\r\n    this.monthHeader = `${month} ${year}`;\r\n    this.yearHeader = `${year}`;\r\n\r\n    this.generateYearSelectionYears();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  private _setInitialValues(): void {\r\n    this.workingDay = this.selectedDate ? this.selectedDate : new Date();\r\n    this.workingYear = this.workingDay.getFullYear();\r\n    this.workingMonth = this.workingDay.getMonth();\r\n  }\r\n\r\n  private _setMonthDaysForDate(monthNumber: number): void {\r\n    this.daysInMonth = [];\r\n\r\n    const firstDayOfMonth = new Date(this.workingYear, monthNumber, 0).getDay();\r\n    const lastDayOfMonth = new Date(this.workingYear, monthNumber + 1, 0).getDate();\r\n\r\n    // Add null values to the beginning of the array to align the first day with the correct day of the week\r\n    for (let i = 0; i < firstDayOfMonth; i++) {\r\n      this.daysInMonth.push(null);\r\n    }\r\n\r\n    // Add the days of the current month to the array\r\n    for (let i = 1; i <= lastDayOfMonth; i++) {\r\n      const date = new Date(this.workingYear, this.workingMonth, i);\r\n      this.daysInMonth.push(date);\r\n    }\r\n\r\n    // Add null values to the end of the array to fill out the grid\r\n    // const remainingCells = 42 - this.daysInMonth.length;\r\n    // for (let i = 0; i < remainingCells; i++) {\r\n    //   this.daysInMonth.push(null);\r\n    // }\r\n\r\n    this.daysUnixTimestamps = this.daysInMonth.map(day => { return day ? day.getTime() : undefined });\r\n  }\r\n\r\n  public generateYearSelectionYears(): void {\r\n    const pastYears = 5;\r\n    const futureYears = 3;\r\n    const years = [];\r\n\r\n    for (let i = pastYears; i >= 1; i--) {\r\n\r\n      years.push(this.workingYear - i);\r\n    }\r\n\r\n    years.push(this.workingYear);\r\n\r\n    for (let i = 1; i <= futureYears; i++) {\r\n      years.push(this.workingYear + i);\r\n    }\r\n\r\n    this.yearSelectionYears = years.reverse();\r\n  }\r\n\r\n  public openMonthSelection(): void {\r\n    this.showCalendarBody = false;\r\n    this.monthSelection = false;\r\n    this.yearSelection = true;\r\n    this.showMonthSelection = true;\r\n  }\r\n\r\n  public openYearSelection(): void {\r\n    this.showMonthSelection = false;\r\n    this.showYearSelection = true;\r\n  }\r\n\r\n  public selectDate(day: Date): void {\r\n    if(day) {\r\n      this.selectedDate = day;\r\n      this._fillDatesBetweenSelected();\r\n      this.dateSelected.emit(new Date(this.selectedDate));\r\n    }\r\n  }\r\n\r\n  public selectMonth(month: string): void {\r\n    this.showSelectedMonth = month;\r\n    this.workingMonth = this.monthSelectionNames.indexOf(month);\r\n    this.showMonthSelection = false;\r\n    this.yearSelection = false;\r\n    this.monthSelection = true;\r\n    this.showCalendarBody = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public selectYear(year: number): void {\r\n    this.workingYear = year;\r\n    this.showYearSelection = false;\r\n    this.showMonthSelection = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateMonthNames(): void {\r\n    for (let i = 0; i < 12; i++) {\r\n      const date = new Date(2000, i, 1);\r\n      const monthNameShort = date.toLocaleString(this.locale, {month: 'short'});\r\n      const monthNameFull = date.toLocaleString(this.locale, {month: 'long'});\r\n      this.monthSelectionNames.push(this._capitalizeFirstLetter(monthNameShort));\r\n      this.monthNames.push(this._capitalizeFirstLetter(monthNameFull));\r\n    }\r\n\r\n    for (let i = 1; i <= 7; i++) {\r\n      const date = new Date(2018, 0, i);\r\n      const weekdayName = date.toLocaleString(this.locale, { weekday: 'short' });\r\n      this.dayNames.push(this._capitalizeFirstLetter(weekdayName));\r\n    }\r\n  }\r\n\r\n  public handleMouseOverDay(day: Date): void {\r\n    if (this.highlightDaysBetweenDates && day && (this.selectedDate || this.secondSelectedDate) && !(this.selectedDate && this.secondSelectedDate) && !(this.selectedDate && !this.temporarySelectedSecondaryDate && !this.secondSelectedDate)) {\r\n      this.daysToHighlight = [];\r\n      if (this.daysUnixTimestamps.includes(day.getTime())) {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n          if (this.selectedDate) {\r\n            if (dayInMonth &&\r\n              // day in the month is after selected date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.selectedDate.getTime() && dayInMonth.getTime() < day.getTime()) ||\r\n              // second date is after selected date and day in the month is before hovering day and day in month is after selected date\r\n              (this._secondHoveringDate && this._secondHoveringDate.getTime() > this.selectedDate.getTime() && day && dayInMonth && dayInMonth.getTime() < day.getTime() && dayInMonth.getTime() > this.selectedDate.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          } else {\r\n            if (dayInMonth &&\r\n              // day in the month is after second date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.secondSelectedDate.getTime() && dayInMonth.getTime() < day.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          }\r\n        }));\r\n      } else {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((day) => {\r\n          if (day > this.selectedDate) {\r\n            return day;\r\n          }\r\n        }));\r\n      }\r\n    }\r\n    this.hoveringDate.next(day);\r\n  }\r\n\r\n  private _fillDatesBetweenSelected(): void {\r\n    if (this.selectedDate && this.secondSelectedDate) {\r\n      this.daysToHighlight = [];\r\n      this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n        if (dayInMonth && (dayInMonth > this.selectedDate && dayInMonth < this.secondSelectedDate) || (dayInMonth > this.secondSelectedDate && dayInMonth < this.selectedDate)) {\r\n          return dayInMonth;\r\n        }\r\n      }));\r\n    }\r\n  }\r\n\r\n  private _capitalizeFirstLetter(value: string): string {\r\n    return value.charAt(0).toUpperCase() + value.slice(1);\r\n  }\r\n  private calculateWeekNumbers(): void {\r\n    this.weekNumbers = [];\r\n    let weekNumber: number | null = null;\r\n    for (let i = 0; i < this.daysInMonth.length; i++) {\r\n      const day = this.daysInMonth[i];\r\n      if (day) {\r\n          // Start of a new week or first day of the month, calculate and set weekNumber\r\n          weekNumber = this.getISOWeek(day);\r\n          // Check if the weekNumber is not already in the array\r\n          if (!this.weekNumbers.includes(weekNumber)) {\r\n            this.weekNumbers.push(weekNumber);\r\n          }\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  public getISOWeek(date: Date): number {\r\n      const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n      d.setUTCDate(d.getUTCDate() + 4 - (d.getUTCDay() || 7));\r\n      const yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1));\r\n      const weekNumber = Math.ceil(((d.valueOf() - yearStart.valueOf()) / 86400000 + 1) / 7);\r\n      return weekNumber;\r\n  }\r\n}\r\n"]}
|
|
400
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-template.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/calendar/calendar-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\n\r\n@Component({\r\n  selector: \"calendar-template\",\r\n  template: `\r\n      <div class=\"calendar\">\r\n        <div class=\"selected-date-display\">\r\n            <span *ngIf=\"selectedDate\" class=\"selected-date-year\">\r\n                {{ selectedDate.getFullYear() }}\r\n            </span>\r\n            <span *ngIf=\"selectedDate\" class=\"selected-date-day\">\r\n              {{ selectedDate | date: 'EEE d MMM' }}\r\n            </span>\r\n            <span *ngIf=\"!selectedDate\" class=\"no-date-selected\" [textContent]=\"'Selecteer datum'\"></span>\r\n        </div>\r\n        <div class=\"calendar-header\" *ngIf=\"monthSelection || yearSelection\">\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointLeft\" (click)=\"prevMonth()\"></co-icon>\r\n\r\n          <div class=\"calendar-header-title-wrapper\">\r\n            <span class=\"calendar-header-title\" [textContent]=\"monthSelection ? monthHeader : yearHeader\"\r\n                  (click)=\"monthSelection ? openMonthSelection() : openYearSelection()\"\r\n            ></span>\r\n          </div>\r\n\r\n          <co-icon class=\"calendar-change-month-button\" [icon]=\"icons.ArrowPointRight\" (click)=\"nextMonth()\"></co-icon>\r\n        </div>\r\n\r\n        <div class=\"selection-grid month\" *ngIf=\"showMonthSelection\">\r\n          <div *ngFor=\"let month of monthSelectionNames\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectMonth(month)\">\r\n            <ng-container *ngIf=\"month\">\r\n              <div class=\"month\" [textContent]=\"month\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"selection-grid year\" *ngIf=\"showYearSelection\">\r\n          <div *ngFor=\"let year of yearSelectionYears\"\r\n               class=\"calendar-month-or-year\"\r\n               (click)=\"selectYear(year)\"\r\n               [textContent]=\"year\">\r\n            <ng-container *ngIf=\"year\">\r\n              <div class=\"year\" [textContent]=\"year\"></div>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n        <div class=\"calendar-wrapper\">\r\n          <div class=\"week-wrapper\" *ngIf=\"showWeekNumbers && showCalendarBody\">\r\n            <div class=\"week-number\" [textContent]=\"'W'\"></div>\r\n            <div class=\"week-number\" *ngFor=\"let weekNumber of weekNumbers\">\r\n              {{ weekNumber }}\r\n            </div>\r\n          </div>\r\n          <div class=\"calendar-body\" *ngIf=\"showCalendarBody\">\r\n            <div class=\"day-names\">\r\n              <div class=\"weekday\" *ngFor=\"let dayName of dayNames\" [textContent]=\"dayName\"></div>\r\n            </div>\r\n            <div *ngFor=\"let day of daysInMonth\" class=\"calendar-day\"\r\n                 [class.highlighted-day]=\"daysToHighlight.includes(day)\"\r\n                 [class.selected-day]=\"selectedDate && (day && day.getTime() === selectedDate.getTime()) ||\r\n            secondSelectedDate && (day && day.getTime() === secondSelectedDate.getTime()) ||\r\n            temporarySelectedSecondaryDate && (day && day.getTime() === temporarySelectedSecondaryDate.getTime())\"\r\n                 (click)=\"selectDate(day)\"\r\n                 (mouseover)=\"handleMouseOverDay(day)\">\r\n              <!-- Day number -->\r\n              <ng-container *ngIf=\"day\">\r\n                <div class=\"day-number\" [textContent]=\"day.getDate()\"></div>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div class=\"calendar-action-buttons\" *ngIf=\"showButtons\">\r\n          <span class=\"set-and-close-button\" (click)=\"setAndClose()\">Instellen</span>\r\n          <span class=\"clear-date-button\" (click)=\"clearDate()\">Wissen</span>\r\n          <span class=\"cancel-button\" (click)=\"closeDate()\">Annuleren</span>\r\n        </div>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class CalendarTemplateComponent {\r\n  public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public showWeekNumbers: boolean = true;\r\n\r\n  public weekNumbers: number[] = [];\r\n  @Input()\r\n  public locale: string = \"nl-NL\";\r\n\r\n  @Input()\r\n  public highlightDaysBetweenDates: boolean = false;\r\n\r\n  @Input()\r\n  public showButtons: boolean = true;\r\n\r\n  @Input()\r\n  public doubleCalendar: boolean = false;\r\n  @Input()\r\n  public set selectedDate(date: Date) {\r\n    this._selectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n\r\n    // Store the initial selected date when the calendar is first opened\r\n    if (this._initialSelectedDate === null) {\r\n      this._initialSelectedDate = this._selectedDate;\r\n    }\r\n\r\n    if (this.secondSelectedDate && date && this.secondSelectedDate.getTime() < this.selectedDate.getTime() && this.temporarySelectedSecondaryDate) {\r\n      this.daysToHighlight = [];\r\n    }\r\n  }\r\n\r\n  public get selectedDate(): Date {\r\n    return this._selectedDate;\r\n  }\r\n\r\n  @Input()\r\n  public set secondSelectedDate(date: Date) {\r\n    this._secondSelectedDate = !!date ? new Date(date.getFullYear(), date.getMonth(), date.getDate()) : date;\r\n    if (!this.selectedDate) {\r\n      this.daysToHighlight = [];\r\n    } else {\r\n      this._fillDatesBetweenSelected();\r\n    }\r\n  }\r\n\r\n  public get secondSelectedDate(): Date {\r\n    return this._secondSelectedDate;\r\n  }\r\n\r\n  @Input()\r\n  public set secondHoveringDate(date : Date) {\r\n    this._secondHoveringDate = date;\r\n    if (!!date) {\r\n      this.temporarySelectedSecondaryDate = null;\r\n    }\r\n    if (this.selectedDate && !this.secondSelectedDate) {\r\n      this.temporarySelectedSecondaryDate = new Date(date);\r\n    }\r\n    this.handleMouseOverDay(date);\r\n  }\r\n\r\n  public get secondHoveringDate(): Date {\r\n    return this._secondHoveringDate;\r\n  }\r\n\r\n  @Output()\r\n  public dateSelected: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public secondDateSelected: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public hoveringDate: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  @Output()\r\n  public clickedOutside: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public clearDates: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  public showCalendarBody: boolean = true;\r\n  public showMonthSelection: boolean = false;\r\n  public showYearSelection: boolean = false;\r\n  public showSelectedMonth: string;\r\n\r\n  public workingDay: Date;\r\n  public workingYear: number;\r\n  public workingMonth: number;\r\n\r\n  public monthHeader: string = '';\r\n  public yearHeader: string = '';\r\n\r\n  public monthSelection: boolean = true;\r\n  public yearSelection: boolean = false;\r\n\r\n  public dayNames = [];\r\n  public monthNames = [];\r\n  public monthSelectionNames: string[] = [];\r\n  public yearSelectionYears: number[] = [];\r\n  public daysInMonth: Date[] = [];\r\n\r\n  public daysUnixTimestamps: number[] = [];\r\n  public daysToHighlight: Date[] = [];\r\n  public temporarySelectedSecondaryDate: Date;\r\n\r\n  private _secondHoveringDate: Date;\r\n  private _secondSelectedDate: Date;\r\n  private _selectedDate: Date;\r\n  private _initialSelectedDate: Date | null = null;\r\n\r\n  @HostBinding(\"class.calendar-template\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this._setInitialValues();\r\n    this.generateMonthNames();\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n  }\r\n\r\n  public prevMonth(): void {\r\n    if (this.workingMonth === 0) {\r\n      this.workingMonth = 11;\r\n      this.workingYear--;\r\n    } else {\r\n      this.workingMonth--;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  public nextMonth(): void {\r\n    if (this.workingMonth === 11) {\r\n      this.workingMonth = 0;\r\n      this.workingYear++;\r\n    } else {\r\n      this.workingMonth++;\r\n    }\r\n    this.generateCalendar();\r\n    this._fillDatesBetweenSelected();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  public prevYear(): void {\r\n    this.workingYear--;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public nextYear(): void {\r\n    this.workingYear++;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateCalendar(): void {\r\n    this._setMonthDaysForDate(this.workingMonth);\r\n\r\n    // Update the displayed month\r\n    const month = this.monthNames[this.workingMonth];\r\n    const year = this.workingYear;\r\n\r\n    // Update headerText\r\n    this.monthHeader = `${month} ${year}`;\r\n    this.yearHeader = `${year}`;\r\n\r\n    this.generateYearSelectionYears();\r\n    this.calculateWeekNumbers();\r\n  }\r\n\r\n  private _setInitialValues(): void {\r\n    this.workingDay = this.selectedDate ? this.selectedDate : new Date();\r\n    this.workingYear = this.workingDay.getFullYear();\r\n    this.workingMonth = this.workingDay.getMonth();\r\n  }\r\n\r\n  private _setMonthDaysForDate(monthNumber: number): void {\r\n    this.daysInMonth = [];\r\n\r\n    const firstDayOfMonth = new Date(this.workingYear, monthNumber, 0).getDay();\r\n    const lastDayOfMonth = new Date(this.workingYear, monthNumber + 1, 0).getDate();\r\n\r\n    // Add null values to the beginning of the array to align the first day with the correct day of the week\r\n    for (let i = 0; i < firstDayOfMonth; i++) {\r\n      this.daysInMonth.push(null);\r\n    }\r\n\r\n    // Add the days of the current month to the array\r\n    for (let i = 1; i <= lastDayOfMonth; i++) {\r\n      const date = new Date(this.workingYear, this.workingMonth, i);\r\n      this.daysInMonth.push(date);\r\n    }\r\n\r\n    // Add null values to the end of the array to fill out the grid\r\n    // const remainingCells = 42 - this.daysInMonth.length;\r\n    // for (let i = 0; i < remainingCells; i++) {\r\n    //   this.daysInMonth.push(null);\r\n    // }\r\n\r\n    this.daysUnixTimestamps = this.daysInMonth.map(day => { return day ? day.getTime() : undefined });\r\n  }\r\n\r\n  public generateYearSelectionYears(): void {\r\n    const pastYears = 5;\r\n    const futureYears = 3;\r\n    const years = [];\r\n\r\n    for (let i = pastYears; i >= 1; i--) {\r\n\r\n      years.push(this.workingYear - i);\r\n    }\r\n\r\n    years.push(this.workingYear);\r\n\r\n    for (let i = 1; i <= futureYears; i++) {\r\n      years.push(this.workingYear + i);\r\n    }\r\n\r\n    this.yearSelectionYears = years.reverse();\r\n  }\r\n\r\n  public openMonthSelection(): void {\r\n    this.showCalendarBody = false;\r\n    this.monthSelection = false;\r\n    this.yearSelection = true;\r\n    this.showMonthSelection = true;\r\n  }\r\n\r\n  public openYearSelection(): void {\r\n    this.showMonthSelection = false;\r\n    this.showYearSelection = true;\r\n  }\r\n\r\n  public selectDate(day: Date): void {\r\n    if(day) {\r\n      this.selectedDate = day;\r\n      this._fillDatesBetweenSelected();\r\n      if (this.doubleCalendar) {\r\n        this.dateSelected.emit(new Date(this.selectedDate));\r\n      }\r\n    }\r\n  }\r\n\r\n  public selectMonth(month: string): void {\r\n    this.showSelectedMonth = month;\r\n    this.workingMonth = this.monthSelectionNames.indexOf(month);\r\n    this.showMonthSelection = false;\r\n    this.yearSelection = false;\r\n    this.monthSelection = true;\r\n    this.showCalendarBody = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public selectYear(year: number): void {\r\n    this.workingYear = year;\r\n    this.showYearSelection = false;\r\n    this.showMonthSelection = true;\r\n    this.generateCalendar();\r\n  }\r\n\r\n  public generateMonthNames(): void {\r\n    for (let i = 0; i < 12; i++) {\r\n      const date = new Date(2000, i, 1);\r\n      const monthNameShort = date.toLocaleString(this.locale, {month: 'short'});\r\n      const monthNameFull = date.toLocaleString(this.locale, {month: 'long'});\r\n      this.monthSelectionNames.push(this._capitalizeFirstLetter(monthNameShort));\r\n      this.monthNames.push(this._capitalizeFirstLetter(monthNameFull));\r\n    }\r\n\r\n    for (let i = 1; i <= 7; i++) {\r\n      const date = new Date(2018, 0, i);\r\n      const weekdayName = date.toLocaleString(this.locale, { weekday: 'short' });\r\n      this.dayNames.push(this._capitalizeFirstLetter(weekdayName.charAt(0)));\r\n    }\r\n  }\r\n\r\n  public handleMouseOverDay(day: Date): void {\r\n    if (this.highlightDaysBetweenDates && day && (this.selectedDate || this.secondSelectedDate) && !(this.selectedDate && this.secondSelectedDate) && !(this.selectedDate && !this.temporarySelectedSecondaryDate && !this.secondSelectedDate)) {\r\n      this.daysToHighlight = [];\r\n      if (this.daysUnixTimestamps.includes(day.getTime())) {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n          if (this.selectedDate) {\r\n            if (dayInMonth &&\r\n              // day in the month is after selected date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.selectedDate.getTime() && dayInMonth.getTime() < day.getTime()) ||\r\n              // second date is after selected date and day in the month is before hovering day and day in month is after selected date\r\n              (this._secondHoveringDate && this._secondHoveringDate.getTime() > this.selectedDate.getTime() && day && dayInMonth && dayInMonth.getTime() < day.getTime() && dayInMonth.getTime() > this.selectedDate.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          } else {\r\n            if (dayInMonth &&\r\n              // day in the month is after second date and day in the month is before the hovering day\r\n              (dayInMonth.getTime() > this.secondSelectedDate.getTime() && dayInMonth.getTime() < day.getTime())) {\r\n              return dayInMonth;\r\n            }\r\n          }\r\n        }));\r\n      } else {\r\n        this.daysToHighlight.push(...this.daysInMonth.map((day) => {\r\n          if (day > this.selectedDate) {\r\n            return day;\r\n          }\r\n        }));\r\n      }\r\n    }\r\n    this.hoveringDate.next(day);\r\n  }\r\n\r\n  private _fillDatesBetweenSelected(): void {\r\n    if (this.selectedDate && this.secondSelectedDate) {\r\n      this.daysToHighlight = [];\r\n      this.daysToHighlight.push(...this.daysInMonth.map((dayInMonth: Date) => {\r\n        if (dayInMonth && (dayInMonth > this.selectedDate && dayInMonth < this.secondSelectedDate) || (dayInMonth > this.secondSelectedDate && dayInMonth < this.selectedDate)) {\r\n          return dayInMonth;\r\n        }\r\n      }));\r\n    }\r\n  }\r\n\r\n  private _capitalizeFirstLetter(value: string): string {\r\n    return value.charAt(0).toUpperCase() + value.slice(1);\r\n  }\r\n  private calculateWeekNumbers(): void {\r\n    this.weekNumbers = [];\r\n    let weekNumber: number | null = null;\r\n    for (let i = 0; i < this.daysInMonth.length; i++) {\r\n      const day = this.daysInMonth[i];\r\n      if (day) {\r\n          // Start of a new week or first day of the month, calculate and set weekNumber\r\n          weekNumber = this.getISOWeek(day);\r\n          // Check if the weekNumber is not already in the array\r\n          if (!this.weekNumbers.includes(weekNumber)) {\r\n            this.weekNumbers.push(weekNumber);\r\n          }\r\n      }\r\n    }\r\n  }\r\n  public getISOWeek(date: Date): number {\r\n      const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n      d.setUTCDate(d.getUTCDate() + 4 - (d.getUTCDay() || 7));\r\n      const yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1));\r\n      const weekNumber = Math.ceil(((d.valueOf() - yearStart.valueOf()) / 86400000 + 1) / 7);\r\n      return weekNumber;\r\n  }\r\n  public setAndClose(): void {\r\n    if (this.selectedDate) {\r\n      this.dateSelected.emit(this.selectedDate);\r\n      this.secondDateSelected.emit(this.secondSelectedDate);// Emit the selected date\r\n      this.closePopup(); // Trigger popup close\r\n    }\r\n  }\r\n\r\n  public clearDate(): void {\r\n    if (this.selectedDate) {\r\n      this.selectedDate = null;\r\n      this.dateSelected.emit(null);\r\n    }\r\n    if (this.secondSelectedDate) {\r\n      this.secondSelectedDate = null;\r\n      this.secondDateSelected.emit(null);\r\n    }\r\n    this.clearDates.emit();\r\n  }\r\n\r\n  public closeDate(): void {\r\n    this.selectedDate = this._initialSelectedDate;\r\n    this.closePopup(); // Trigger popup close without making changes\r\n  }\r\n\r\n  private closePopup(): void {\r\n    this.clickedOutside.emit(); // Emit the `clickedOutside` event to notify the parent\r\n  }\r\n\r\n\r\n}\r\n"]}
|
|
@@ -24,6 +24,7 @@ CalendarComponent.decorators = [
|
|
|
24
24
|
[secondHoveringDate]="secondHoveringDate"
|
|
25
25
|
(dateSelected)="dateSelected.next($event)"
|
|
26
26
|
(hoveringDate)="hoveringDate.next($event)"
|
|
27
|
+
(clickedOutside)="clickedOutside.next()"
|
|
27
28
|
></calendar-template>
|
|
28
29
|
</div>
|
|
29
30
|
`,
|
|
@@ -42,4 +43,4 @@ CalendarComponent.propDecorators = {
|
|
|
42
43
|
clickedOutside: [{ type: Output }],
|
|
43
44
|
showClass: [{ type: HostBinding, args: ["class.co-calendar",] }]
|
|
44
45
|
};
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhbGVuZGFyL2NhbGVuZGFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFjLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQW9CakgsTUFBTSxPQUFPLGlCQUFpQjtJQWxCOUI7UUFxQlMsV0FBTSxHQUFXLE9BQU8sQ0FBQztRQU16Qiw4QkFBeUIsR0FBWSxLQUFLLENBQUM7UUFZM0MsaUJBQVksR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUc1RCxpQkFBWSxHQUF1QixJQUFJLFlBQVksRUFBUSxDQUFDO1FBRzVELG1CQUFjLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7SUFPdkUsQ0FBQztJQUpRLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7OztZQWxERixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGFBQWE7Z0JBQ3ZCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7OztHQWFUO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7cUJBR0UsS0FBSzsrQkFHTCxLQUFLO3dDQUdMLEtBQUs7MkJBR0wsS0FBSztpQ0FHTCxLQUFLO2lDQUdMLEtBQUs7MkJBR0wsTUFBTTsyQkFHTixNQUFNOzZCQUdOLE1BQU07d0JBR04sV0FBVyxTQUFDLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIEhvc3RCaW5kaW5nLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImNvLWNhbGVuZGFyXCIsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxkaXYgY2xhc3M9XCJkYXRlLXBpY2tlci1jb250YWluZXJcIiBbb3ZlcmxheV09XCJwYXJlbnRGb3JPdmVybGF5XCIgKGNsaWNrT3V0c2lkZSk9XCJjbGlja2VkT3V0c2lkZS5uZXh0KClcIj5cclxuICAgICAgPGNhbGVuZGFyLXRlbXBsYXRlXHJcbiAgICAgICAgW2xvY2FsZV09XCJsb2NhbGVcIlxyXG4gICAgICAgIFtoaWdobGlnaHREYXlzQmV0d2VlbkRhdGVzXT1cImhpZ2hsaWdodERheXNCZXR3ZWVuRGF0ZXNcIlxyXG4gICAgICAgIFtzZWxlY3RlZERhdGVdPVwic2VsZWN0ZWREYXRlXCJcclxuICAgICAgICBbc2Vjb25kU2VsZWN0ZWREYXRlXT1cInNlY29uZFNlbGVjdGVkRGF0ZVwiXHJcbiAgICAgICAgW3NlY29uZEhvdmVyaW5nRGF0ZV09XCJzZWNvbmRIb3ZlcmluZ0RhdGVcIlxyXG4gICAgICAgIChkYXRlU2VsZWN0ZWQpPVwiZGF0ZVNlbGVjdGVkLm5leHQoJGV2ZW50KVwiXHJcbiAgICAgICAgKGhvdmVyaW5nRGF0ZSk9XCJob3ZlcmluZ0RhdGUubmV4dCgkZXZlbnQpXCJcclxuICAgICAgICAoY2xpY2tlZE91dHNpZGUpPVwiY2xpY2tlZE91dHNpZGUubmV4dCgpXCJcclxuICAgICAgPjwvY2FsZW5kYXItdGVtcGxhdGU+XHJcbiAgICA8L2Rpdj5cclxuICBgLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIENhbGVuZGFyQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbG9jYWxlOiBzdHJpbmcgPSBcIm5sLU5MXCI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHBhcmVudEZvck92ZXJsYXk6IEVsZW1lbnRSZWY7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGhpZ2hsaWdodERheXNCZXR3ZWVuRGF0ZXM6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2VsZWN0ZWREYXRlOiBEYXRlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZWNvbmRTZWxlY3RlZERhdGU6IERhdGU7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNlY29uZEhvdmVyaW5nRGF0ZTogRGF0ZTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIGRhdGVTZWxlY3RlZDogRXZlbnRFbWl0dGVyPERhdGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxEYXRlPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgaG92ZXJpbmdEYXRlOiBFdmVudEVtaXR0ZXI8RGF0ZT4gPSBuZXcgRXZlbnRFbWl0dGVyPERhdGU+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBjbGlja2VkT3V0c2lkZTogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby1jYWxlbmRhclwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3MoKSB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -5,6 +5,7 @@ import { IconModule } from "../icon/icon.module";
|
|
|
5
5
|
import { OverlayModule } from "../../directives/overlay/overlay.module";
|
|
6
6
|
import { ClickoutsideModule } from "../../directives/clickoutside/clickoutside.module";
|
|
7
7
|
import { CalendarTemplateComponent } from "./calendar-template.component";
|
|
8
|
+
import { CoreComponentsTranslationModule } from "../../translation/core-components-translation.module";
|
|
8
9
|
export class CalendarModule {
|
|
9
10
|
}
|
|
10
11
|
CalendarModule.decorators = [
|
|
@@ -13,7 +14,8 @@ CalendarModule.decorators = [
|
|
|
13
14
|
CommonModule,
|
|
14
15
|
IconModule,
|
|
15
16
|
OverlayModule,
|
|
16
|
-
ClickoutsideModule
|
|
17
|
+
ClickoutsideModule,
|
|
18
|
+
CoreComponentsTranslationModule
|
|
17
19
|
],
|
|
18
20
|
declarations: [
|
|
19
21
|
CalendarComponent,
|
|
@@ -25,4 +27,4 @@ CalendarModule.decorators = [
|
|
|
25
27
|
]
|
|
26
28
|
},] }
|
|
27
29
|
];
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhbGVuZGFyL2NhbGVuZGFyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDL0MsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQ3RFLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQ3JGLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ3hFLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLHNEQUFzRCxDQUFDO0FBbUJyRyxNQUFNLE9BQU8sY0FBYzs7O1lBakIxQixRQUFRLFNBQUM7Z0JBQ04sT0FBTyxFQUFFO29CQUNMLFlBQVk7b0JBQ1osVUFBVTtvQkFDVixhQUFhO29CQUNiLGtCQUFrQjtvQkFDbEIsK0JBQStCO2lCQUNsQztnQkFDSCxZQUFZLEVBQUU7b0JBQ1osaUJBQWlCO29CQUNqQix5QkFBeUI7aUJBQzFCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxpQkFBaUI7b0JBQ2pCLHlCQUF5QjtpQkFDMUI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7Q2FsZW5kYXJDb21wb25lbnR9IGZyb20gXCIuL2NhbGVuZGFyLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0ljb25Nb2R1bGV9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7T3ZlcmxheU1vZHVsZX0gZnJvbSBcIi4uLy4uL2RpcmVjdGl2ZXMvb3ZlcmxheS9vdmVybGF5Lm1vZHVsZVwiO1xyXG5pbXBvcnQge0NsaWNrb3V0c2lkZU1vZHVsZX0gZnJvbSBcIi4uLy4uL2RpcmVjdGl2ZXMvY2xpY2tvdXRzaWRlL2NsaWNrb3V0c2lkZS5tb2R1bGVcIjtcclxuaW1wb3J0IHtDYWxlbmRhclRlbXBsYXRlQ29tcG9uZW50fSBmcm9tIFwiLi9jYWxlbmRhci10ZW1wbGF0ZS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtDb3JlQ29tcG9uZW50c1RyYW5zbGF0aW9uTW9kdWxlfSBmcm9tIFwiLi4vLi4vdHJhbnNsYXRpb24vY29yZS1jb21wb25lbnRzLXRyYW5zbGF0aW9uLm1vZHVsZVwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgSWNvbk1vZHVsZSxcclxuICAgICAgICBPdmVybGF5TW9kdWxlLFxyXG4gICAgICAgIENsaWNrb3V0c2lkZU1vZHVsZSxcclxuICAgICAgICBDb3JlQ29tcG9uZW50c1RyYW5zbGF0aW9uTW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgQ2FsZW5kYXJDb21wb25lbnQsXHJcbiAgICBDYWxlbmRhclRlbXBsYXRlQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBDYWxlbmRhckNvbXBvbmVudCxcclxuICAgIENhbGVuZGFyVGVtcGxhdGVDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYWxlbmRhck1vZHVsZSB7XHJcbn1cclxuIl19
|
|
@@ -3,7 +3,7 @@ import { BaseInputDatePickerDirective } from "../base-input-date-picker/base-inp
|
|
|
3
3
|
export class DoubleCalendarComponent extends BaseInputDatePickerDirective {
|
|
4
4
|
constructor() {
|
|
5
5
|
super(...arguments);
|
|
6
|
-
this.selectedDates = [
|
|
6
|
+
this.selectedDates = [null, null]; // Initialize with valid array elements
|
|
7
7
|
this.datesSelected = new EventEmitter();
|
|
8
8
|
this.secondDateSelected = new EventEmitter();
|
|
9
9
|
this.clickedOutside = new EventEmitter();
|
|
@@ -12,26 +12,32 @@ export class DoubleCalendarComponent extends BaseInputDatePickerDirective {
|
|
|
12
12
|
return true;
|
|
13
13
|
}
|
|
14
14
|
ngOnInit() {
|
|
15
|
+
// Ensure `selectedDates` always has two elements
|
|
16
|
+
this.selectedDates = this.selectedDates || [null, null];
|
|
15
17
|
this.selectedFirstDate = this.selectedDates[0];
|
|
16
18
|
this.selectedSecondDate = this.selectedDates[1];
|
|
17
19
|
}
|
|
18
20
|
handleFirstDateSelected(date) {
|
|
19
21
|
this.selectedFirstDate = date;
|
|
20
22
|
this.selectedDates[0] = date;
|
|
21
|
-
if (this.selectedSecondDate && this.selectedFirstDate
|
|
22
|
-
this.selectedSecondDate
|
|
23
|
+
if (this.selectedSecondDate && this.selectedFirstDate) {
|
|
24
|
+
if (this.selectedFirstDate.getTime() > this.selectedSecondDate.getTime()) {
|
|
25
|
+
this.selectedSecondDate = null;
|
|
26
|
+
}
|
|
23
27
|
}
|
|
24
28
|
this.outputRangeIfValid();
|
|
25
29
|
}
|
|
26
30
|
handleSecondDateSelected(date) {
|
|
27
31
|
this.selectedSecondDate = date;
|
|
28
32
|
this.selectedDates[1] = date;
|
|
29
|
-
if (this.selectedFirstDate && this.selectedSecondDate
|
|
30
|
-
this.selectedFirstDate
|
|
31
|
-
|
|
32
|
-
|
|
33
|
+
if (this.selectedFirstDate && this.selectedSecondDate) {
|
|
34
|
+
if (this.selectedSecondDate.getTime() < this.selectedFirstDate.getTime()) {
|
|
35
|
+
this.selectedFirstDate = null;
|
|
36
|
+
this.selectedSecondDate = null;
|
|
37
|
+
this.secondHoveringDate = null;
|
|
38
|
+
}
|
|
33
39
|
}
|
|
34
|
-
if (this.selectedSecondDate && this.
|
|
40
|
+
if (this.selectedSecondDate && this.selectedFirstDate) {
|
|
35
41
|
this.outputRangeIfValid();
|
|
36
42
|
this.secondDateSelected.next();
|
|
37
43
|
}
|
|
@@ -44,6 +50,13 @@ export class DoubleCalendarComponent extends BaseInputDatePickerDirective {
|
|
|
44
50
|
handleSecondHoveringDate(day) {
|
|
45
51
|
this.secondHoveringDate = day;
|
|
46
52
|
}
|
|
53
|
+
clearAllDates() {
|
|
54
|
+
this.selectedFirstDate = null;
|
|
55
|
+
this.selectedSecondDate = null;
|
|
56
|
+
this.selectedDates = [null, null];
|
|
57
|
+
// Emit updated state to parent
|
|
58
|
+
this.datesSelected.emit(this.selectedDates);
|
|
59
|
+
}
|
|
47
60
|
}
|
|
48
61
|
DoubleCalendarComponent.decorators = [
|
|
49
62
|
{ type: Component, args: [{
|
|
@@ -56,6 +69,9 @@ DoubleCalendarComponent.decorators = [
|
|
|
56
69
|
[secondHoveringDate]="secondHoveringDate"
|
|
57
70
|
[highlightDaysBetweenDates]="true"
|
|
58
71
|
(dateSelected)="handleFirstDateSelected($event)"
|
|
72
|
+
[showButtons]="false"
|
|
73
|
+
(clearDates)="clearAllDates()"
|
|
74
|
+
[doubleCalendar]="true"
|
|
59
75
|
></calendar-template>
|
|
60
76
|
<calendar-template
|
|
61
77
|
[selectedDate]="selectedSecondDate"
|
|
@@ -63,6 +79,10 @@ DoubleCalendarComponent.decorators = [
|
|
|
63
79
|
[highlightDaysBetweenDates]="true"
|
|
64
80
|
(hoveringDate)="handleSecondHoveringDate($event)"
|
|
65
81
|
(dateSelected)="handleSecondDateSelected($event)"
|
|
82
|
+
(clickedOutside)="clickedOutside.next()"
|
|
83
|
+
[showButtons]="true"
|
|
84
|
+
[doubleCalendar]="true"
|
|
85
|
+
(clearDates)="clearAllDates()"
|
|
66
86
|
></calendar-template>
|
|
67
87
|
</div>
|
|
68
88
|
`,
|
|
@@ -77,4 +97,4 @@ DoubleCalendarComponent.propDecorators = {
|
|
|
77
97
|
clickedOutside: [{ type: Output }],
|
|
78
98
|
showClass: [{ type: HostBinding, args: ["class.co-double-calendar",] }]
|
|
79
99
|
};
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"double-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/double-calendar/double-calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\n\r\n@Component({\r\n  selector: \"co-double-calendar\",\r\n  template: `\r\n    <div class=\"dual-calendar-wrapper\" [overlay]=\"parentForOverlay\" (clickOutside)=\"clickedOutside.next()\">\r\n      <calendar-template\r\n        [selectedDate]=\"selectedFirstDate\"\r\n        [secondSelectedDate]=\"selectedSecondDate\"\r\n        [secondHoveringDate]=\"secondHoveringDate\"\r\n        [highlightDaysBetweenDates]=\"true\"\r\n        (dateSelected)=\"handleFirstDateSelected($event)\"\r\n        [showButtons]=\"false\"\r\n        (clearDates)=\"clearAllDates()\"\r\n        [doubleCalendar]=\"true\"\r\n      ></calendar-template>\r\n      <calendar-template\r\n        [selectedDate]=\"selectedSecondDate\"\r\n        [secondSelectedDate]=\"selectedFirstDate\"\r\n        [highlightDaysBetweenDates]=\"true\"\r\n        (hoveringDate)=\"handleSecondHoveringDate($event)\"\r\n        (dateSelected)=\"handleSecondDateSelected($event)\"\r\n        (clickedOutside)=\"clickedOutside.next()\"\r\n        [showButtons]=\"true\"\r\n        [doubleCalendar]=\"true\"\r\n        (clearDates)=\"clearAllDates()\"\r\n      ></calendar-template>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DoubleCalendarComponent extends BaseInputDatePickerDirective implements OnInit {\r\n\r\n  @Input()\r\n  public selectedDates: Date[] = [null, null]; // Initialize with valid array elements\r\n\r\n  @Input()\r\n  public parentForOverlay: ElementRef;\r\n\r\n  @Output()\r\n  public datesSelected: EventEmitter<Date[]> = new EventEmitter<Date[]>();\r\n\r\n  @Output()\r\n  public secondDateSelected: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public clickedOutside: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  public selectedFirstDate: Date;\r\n  public selectedSecondDate: Date;\r\n  public secondHoveringDate: Date;\r\n\r\n  @HostBinding(\"class.co-double-calendar\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    // Ensure `selectedDates` always has two elements\r\n    this.selectedDates = this.selectedDates || [null, null];\r\n    this.selectedFirstDate = this.selectedDates[0];\r\n    this.selectedSecondDate = this.selectedDates[1];\r\n  }\r\n\r\n  public handleFirstDateSelected(date: Date): void {\r\n    this.selectedFirstDate = date;\r\n    this.selectedDates[0] = date;\r\n\r\n    if (this.selectedSecondDate && this.selectedFirstDate) {\r\n      if (this.selectedFirstDate.getTime() > this.selectedSecondDate.getTime()) {\r\n        this.selectedSecondDate = null;\r\n      }\r\n    }\r\n\r\n    this.outputRangeIfValid();\r\n  }\r\n\r\n\r\n  public handleSecondDateSelected(date: Date): void {\r\n    this.selectedSecondDate = date;\r\n    this.selectedDates[1] = date;\r\n\r\n    if (this.selectedFirstDate && this.selectedSecondDate) {\r\n      if (this.selectedSecondDate.getTime() < this.selectedFirstDate.getTime()) {\r\n        this.selectedFirstDate = null;\r\n        this.selectedSecondDate = null;\r\n        this.secondHoveringDate = null;\r\n      }\r\n    }\r\n\r\n    if (this.selectedSecondDate && this.selectedFirstDate) {\r\n      this.outputRangeIfValid();\r\n      this.secondDateSelected.next();\r\n    }\r\n  }\r\n\r\n\r\n  public outputRangeIfValid(): void {\r\n    if (this.selectedDates[0] instanceof Date && this.selectedDates[1] instanceof Date) {\r\n      this.datesSelected.next(this.selectedDates);\r\n    }\r\n  }\r\n\r\n  public handleSecondHoveringDate(day: Date): void {\r\n    this.secondHoveringDate = day;\r\n  }\r\n  public clearAllDates(): void {\r\n    this.selectedFirstDate = null;\r\n    this.selectedSecondDate = null;\r\n    this.selectedDates = [null, null];\r\n\r\n    // Emit updated state to parent\r\n    this.datesSelected.emit(this.selectedDates);\r\n  }\r\n}\r\n\r\n"]}
|
|
@@ -9,7 +9,7 @@ export class InputDatePickerComponent extends BaseInputDatePickerDirective {
|
|
|
9
9
|
}
|
|
10
10
|
handleDateSelected(date) {
|
|
11
11
|
this.setModel(date);
|
|
12
|
-
if (this.closeAfterDateSelection) {
|
|
12
|
+
if (this.closeAfterDateSelection || !date) {
|
|
13
13
|
this.toggleCalendar(false);
|
|
14
14
|
}
|
|
15
15
|
}
|
|
@@ -24,7 +24,7 @@ export class InputDatePickerComponent extends BaseInputDatePickerDirective {
|
|
|
24
24
|
selectedDate: this.model
|
|
25
25
|
}, {
|
|
26
26
|
dateSelected: (event) => this.handleDateSelected(event),
|
|
27
|
-
clickedOutside: () => this.toggleCalendar(false)
|
|
27
|
+
clickedOutside: () => this.toggleCalendar(false) // Close when clicked outside
|
|
28
28
|
});
|
|
29
29
|
}
|
|
30
30
|
else {
|
|
@@ -72,6 +72,7 @@ InputDatePickerComponent.decorators = [
|
|
|
72
72
|
(rightIconClick)="toggleCalendar(true)"
|
|
73
73
|
(blur)="handleDateChange(modelAsString)"
|
|
74
74
|
(clearIconClick)="handleClearIconClicked()"
|
|
75
|
+
[emptyPlace]="true"
|
|
75
76
|
></co-input-text>
|
|
76
77
|
`,
|
|
77
78
|
providers: [
|
|
@@ -88,4 +89,4 @@ InputDatePickerComponent.decorators = [
|
|
|
88
89
|
InputDatePickerComponent.propDecorators = {
|
|
89
90
|
showClass: [{ type: HostBinding, args: ['class.co-input-date',] }]
|
|
90
91
|
};
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-date-picker/input-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentRef,\r\n  forwardRef,\r\n  HostBinding,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\nimport {CalendarComponent} from \"../calendar/calendar.component\";\r\n\r\n@Component({\r\n    selector: 'co-input-date',\r\n    template: `\r\n      <co-input-text (clickOutside)=\"toggleCalendar(false)\" overlayParent #parentForOverlay=\"overlayParent\"\r\n                     [hidden]=\"hidden\"\r\n                     [readonly]=\"readonly\"\r\n                     [(model)]=\"modelAsString\"\r\n                     [rightIcon]=\"rightIcon\"\r\n                     [leftIcon]=\"leftIcon\"\r\n                     [leftIconData]=\"leftIconData\"\r\n                     [pattern]=\"'yyyy-MM-dd'\"\r\n                     [type]=\"'date'\"\r\n                     [placeholder]=\"placeholder\"\r\n                     (leftIconClick)=\"leftIconClick.emit($event)\"\r\n                     (rightIconClick)=\"toggleCalendar(true)\"\r\n                     (blur)=\"handleDateChange(modelAsString)\"\r\n                     (clearIconClick)=\"handleClearIconClicked()\"\r\n                     [emptyPlace]=\"true\"\r\n      ></co-input-text>\r\n    `,\r\n    providers: [\r\n        OverlayService, {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => InputDatePickerComponent)\r\n        }, {\r\n            provide: BaseInputDatePickerDirective,\r\n            useExisting: InputDatePickerComponent\r\n        }],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputDatePickerComponent extends BaseInputDatePickerDirective {\r\n\r\n  public modelAsString: string;\r\n\r\n  private _calendarComponentRef: ComponentRef<CalendarComponent>;\r\n\r\n    @HostBinding('class.co-input-date')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n  public handleDateSelected(date: Date): void {\r\n    this.setModel(date);\r\n    if (this.closeAfterDateSelection || !date) {\r\n      this.toggleCalendar(false);\r\n    }\r\n  }\r\n\r\n  public toggleCalendar(show: boolean): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n\r\n    this.showCalendar = show;\r\n\r\n    if (this.showCalendar) {\r\n      this._calendarComponentRef = this.overlayService.createComponent(CalendarComponent, {\r\n        parentForOverlay: this.parentForOverlay,\r\n        selectedDate: this.model\r\n      }, {\r\n        dateSelected: (event) => this.handleDateSelected(event),\r\n        clickedOutside: () => this.toggleCalendar(false) // Close when clicked outside\r\n      });\r\n    } else {\r\n      this.overlayService.removeComponent(this._calendarComponentRef);\r\n    }\r\n  }\r\n\r\n  public handleDateChange(value: string): void {\r\n    if (value) {\r\n        this.setModel(new Date(value));\r\n    }\r\n  }\r\n\r\n  protected modelSet(): void {\r\n      this.setModelAsString();\r\n  }\r\n\r\n  private setModelAsString(): void {\r\n    if (this.model) {\r\n      const year = this.model.toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model.toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model.toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.modelAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.modelAsString = null;\r\n    }\r\n  }\r\n\r\n  public handleClearIconClicked() {\r\n      this.setModel(undefined);\r\n  }\r\n}\r\n"]}
|