@smart-solutions-tech/smart-angular-calendar 0.0.11 → 0.0.12

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.
@@ -178,7 +178,7 @@ export class SmartCalendarComponent {
178
178
  month: today.getMonth() + 1
179
179
  };
180
180
  this.selectDate(today);
181
- this.selectWeekByDate(today);
181
+ this.selectWeekByDate(today, false);
182
182
  if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)
183
183
  this.monthChange.emit({
184
184
  newMonth: this.currentMonth,
@@ -214,7 +214,7 @@ export class SmartCalendarComponent {
214
214
  });
215
215
  this.dateChanged.emit(this.selectedDate);
216
216
  }
217
- selectWeekByDate(date) {
217
+ selectWeekByDate(date, emitChange = true) {
218
218
  // Calculate the start date of the week based on startAt
219
219
  const dayOfWeek = date.getDay(); // 0 (Sun) to 6 (Sat)
220
220
  let diffToStart;
@@ -234,16 +234,18 @@ export class SmartCalendarComponent {
234
234
  const eventEnd = event.end ? new Date(event.end) : eventStart;
235
235
  return (eventStart <= this.weekEndDate) && (eventEnd >= this.weekStartDate);
236
236
  });
237
- const oldMonth = this.currentMonth;
238
- this.currentMonth = {
239
- year: this.weekStartDate.getFullYear(),
240
- month: this.weekStartDate.getMonth() + 1
241
- };
242
- if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)
243
- this.monthChange.emit({
244
- newMonth: this.currentMonth,
245
- oldMonth
246
- });
237
+ if (emitChange) {
238
+ const oldMonth = this.currentMonth;
239
+ this.currentMonth = {
240
+ year: this.weekStartDate.getFullYear(),
241
+ month: this.weekStartDate.getMonth() + 1
242
+ };
243
+ if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)
244
+ this.monthChange.emit({
245
+ newMonth: this.currentMonth,
246
+ oldMonth
247
+ });
248
+ }
247
249
  }
248
250
  setMode(newMode) {
249
251
  this.mode = newMode;
@@ -281,4 +283,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
281
283
  type: HostListener,
282
284
  args: ['document:click', ['$event']]
283
285
  }] } });
284
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-angular-calendar/src/lib/components/smart-calendar/smart-calendar.component.ts","../../../../../../projects/smart-angular-calendar/src/lib/components/smart-calendar/smart-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { CalendarEvent } from '../../types';\n\n@Component({\n  selector: 'smart-calendar',\n  templateUrl: './smart-calendar.component.html',\n  styleUrls: ['./smart-calendar.component.scss']\n})\nexport class SmartCalendarComponent implements OnInit {\n\n  @Input() mode: 'month' | 'week' | 'day' = 'month';\n\n  @Input() startAt: 'monday' | 'sunday' = 'sunday';\n\n  @Input() currentMonth: { year: number, month: number } = {\n    year: new Date().getFullYear(),\n    month: new Date().getMonth() + 1\n  };\n\n  @Input() events: CalendarEvent[] = [];\n\n  @Output() monthChange = new EventEmitter<{\n    newMonth: { year: number, month: number },\n    oldMonth: { year: number, month: number }\n  }>();\n\n  @Output() dateChanged = new EventEmitter<Date>();\n\n  @Output() eventClick = new EventEmitter<CalendarEvent>();\n\n  @ViewChild('dateSelectorDropdown', { static: false }) dateSelectorDropdown!: ElementRef;\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent) {\n    if (!this.showDateSelector) return;\n    const dropdown = this.dateSelectorDropdown?.nativeElement;\n    const button = document.querySelector('.btn-date-selector');\n    if (dropdown && !dropdown.contains(event.target) && button && !button.contains(event.target as Node)) {\n      this.showDateSelector = false;\n    }\n  }\n\n  showDateSelector: boolean = false;\n\n  selectedDate: Date = new Date();\n  selectedDateEvents: CalendarEvent[] = [];\n\n  weekStartDate: Date = new Date();\n  weekEndDate: Date = new Date(this.weekStartDate.getTime() + 6 * 24 * 60 * 60 * 1000);\n  weekEvents: CalendarEvent[] = [];\n\n  constructor() { }\n\n  ngOnInit(): void {\n    this.selectDate(new Date());\n  }\n\n  toggleDateSelector() {\n    this.showDateSelector = !this.showDateSelector;\n  }\n\n  onMonthSelected(newMonth: { year: number, month: number }) {\n    const oldMonth = { ...this.currentMonth };\n    this.currentMonth = newMonth;\n\n    this.selectDate(new Date(this.currentMonth.year, this.currentMonth.month - 1, 1));\n\n    this.monthChange.emit({\n      newMonth: this.currentMonth,\n      oldMonth\n    });\n\n    this.showDateSelector = false;\n  }\n\n  onEventClick(event: CalendarEvent) {\n    this.eventClick.emit(event);\n  }\n\n  nextMonth() {\n    const oldMonth = { ...this.currentMonth };\n\n    if (this.currentMonth.month === 12) {\n      this.currentMonth = {\n        year: this.currentMonth.year + 1,\n        month: 1\n      };\n    } else {\n      this.currentMonth = {\n        year: this.currentMonth.year,\n        month: this.currentMonth.month + 1\n      };\n    }\n\n    this.selectDate(new Date(this.currentMonth.year, this.currentMonth.month - 1, 1));\n\n    this.monthChange.emit({\n      newMonth: this.currentMonth,\n      oldMonth\n    });\n  }\n\n  prevMonth() {\n    const oldMonth = { ...this.currentMonth };\n    if (this.currentMonth.month === 1) {\n      this.currentMonth = {\n        year: this.currentMonth.year - 1,\n        month: 12\n      };\n    } else {\n      this.currentMonth = {\n        year: this.currentMonth.year,\n        month: this.currentMonth.month - 1\n      };\n    }\n\n    this.selectDate(new Date(this.currentMonth.year, this.currentMonth.month - 1, 1));\n\n    this.monthChange.emit({\n      newMonth: this.currentMonth,\n      oldMonth\n    });\n  }\n\n  nextDay() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.selectedDate);\n    newDate.setDate(newDate.getDate() + 1);\n\n    this.selectDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  prevDay() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.selectedDate);\n    newDate.setDate(newDate.getDate() - 1);\n\n    this.selectDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  nextWeek() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.weekStartDate);\n    newDate.setDate(newDate.getDate() + 7);\n    this.selectWeekByDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  prevWeek() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.weekStartDate);\n    newDate.setDate(newDate.getDate() - 7);\n    this.selectWeekByDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  onNext() {\n    if (this.mode === 'month')\n      this.nextMonth();\n    else if (this.mode === 'week')\n      this.nextWeek();\n    else if (this.mode === 'day')\n      this.nextDay();\n  }\n\n  onPrev() {\n    if (this.mode === 'month')\n      this.prevMonth();\n    else if (this.mode === 'week')\n      this.prevWeek();\n    else if (this.mode === 'day')\n      this.prevDay();\n  }\n\n  goToToday() {\n    const today = new Date();\n    const oldMonth = { ...this.currentMonth };\n\n    this.currentMonth = {\n      year: today.getFullYear(),\n      month: today.getMonth() + 1\n    };\n\n    this.selectDate(today);\n    this.selectWeekByDate(today);\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  setSelectedDateEvents() {\n    this.selectedDateEvents = this.events.filter(event => {\n      const eventDate = new Date(event.start);\n\n      // return events that starts, ends or spans the selected date\n      return (eventDate.getDate() === this.selectedDate.getDate() &&\n        eventDate.getMonth() === this.selectedDate.getMonth() &&\n        eventDate.getFullYear() === this.selectedDate.getFullYear()) ||\n        (event.end &&\n          event.end.getDate() === this.selectedDate.getDate() &&\n          event.end.getMonth() === this.selectedDate.getMonth() &&\n          event.end.getFullYear() === this.selectedDate.getFullYear()) ||\n        (event.start < this.selectedDate && event.end && event.end > this.selectedDate);\n    });\n  }\n\n  selectDate(date: Date) {\n    this.selectedDate = date;\n\n    this.setSelectedDateEvents();\n\n    const oldMonth = this.currentMonth;\n\n    this.currentMonth = {\n      year: date.getFullYear(),\n      month: date.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n\n    this.dateChanged.emit(this.selectedDate);\n  }\n\n  selectWeekByDate(date: Date) {\n    // Calculate the start date of the week based on startAt\n    const dayOfWeek = date.getDay(); // 0 (Sun) to 6 (Sat)\n    let diffToStart: number;\n\n    if (this.startAt === 'monday') {\n      diffToStart = (dayOfWeek === 0) ? -6 : 1 - dayOfWeek; // If Sunday, go back 6 days\n    } else {\n      diffToStart = -dayOfWeek; // Sunday start\n    }\n\n    this.weekStartDate = new Date(date);\n    this.weekStartDate.setDate(date.getDate() + diffToStart);\n\n    this.weekEndDate = new Date(this.weekStartDate);\n    this.weekEndDate.setDate(this.weekStartDate.getDate() + 6);\n\n    // Filter events for the week\n    this.weekEvents = this.events.filter(event => {\n      const eventStart = new Date(event.start);\n      const eventEnd = event.end ? new Date(event.end) : eventStart;\n      return (eventStart <= this.weekEndDate) && (eventEnd >= this.weekStartDate);\n    });\n\n    const oldMonth = this.currentMonth;\n\n    this.currentMonth = {\n      year: this.weekStartDate.getFullYear(),\n      month: this.weekStartDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  setMode(newMode: typeof this.mode) {\n    this.mode = newMode;\n    if (newMode === 'day') {\n      this.setSelectedDateEvents();\n    } else if (newMode === 'week') {\n      this.selectWeekByDate(this.selectedDate);\n    }\n  }\n\n}\n","<div class=\"smart-calendar-component\">\n    <div class=\"header\">\n        <div class=\"nav-controls\">\n            <button class=\"btn-prev\" (click)=\"onPrev()\">\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path d=\"M560-240 320-480l240-240 56 56-184 184 184 184-56 56Z\" />\n                </svg>\n            </button>\n\n            <button class=\"btn-today\" (click)=\"goToToday()\">{{'today' | translate}}</button>\n\n            <button class=\"btn-next\" (click)=\"onNext()\">\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path d=\"M504-480 320-664l56-56 240 240-240 240-56-56 184-184Z\" />\n                </svg>\n            </button>\n        </div>\n\n        <div class=\"spacer\"></div>\n\n        <div class=\"date-selector-container\">\n            <button class=\"btn-date-selector\" (click)=\"toggleDateSelector()\">\n                <span *ngIf=\"mode === 'month'\">{{ currentMonth.month | translateMonth}} - {{ currentMonth.year }}</span>\n                <span *ngIf=\"mode === 'week'\">\n                    {{ weekStartDate.toDateString() }} - {{ weekEndDate.toDateString() }}\n                </span>\n                <span *ngIf=\"mode === 'day'\">{{ selectedDate.toDateString() }}</span>\n\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path d=\"M480-360 280-560h400L480-360Z\" />\n                </svg>\n            </button>\n\n            <div class=\"date-selector-dropdown\" *ngIf=\"showDateSelector\" #dateSelectorDropdown>\n                <lib-month-selector [selectedMonth]=\"currentMonth\"\n                    (monthSelected)=\"onMonthSelected($event)\"></lib-month-selector>\n            </div>\n        </div>\n\n        <div class=\"spacer\"></div>\n\n        <div class=\"view-selector\">\n            <button class=\"btn-view\" [ngClass]=\"{active: mode === 'month'}\" (click)=\"setMode('month')\">\n                <!-- month view -->\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path\n                        d=\"M200-80q-33 0-56.5-23.5T120-160v-560q0-33 23.5-56.5T200-800h40v-80h80v80h320v-80h80v80h40q33 0 56.5 23.5T840-720v560q0 33-23.5 56.5T760-80H200Zm0-80h560v-400H200v400Zm0-480h560v-80H200v80Zm0 0v-80 80Zm280 240q-17 0-28.5-11.5T440-440q0-17 11.5-28.5T480-480q17 0 28.5 11.5T520-440q0 17-11.5 28.5T480-400Zm-160 0q-17 0-28.5-11.5T280-440q0-17 11.5-28.5T320-480q17 0 28.5 11.5T360-440q0 17-11.5 28.5T320-400Zm320 0q-17 0-28.5-11.5T600-440q0-17 11.5-28.5T640-480q17 0 28.5 11.5T680-440q0 17-11.5 28.5T640-400ZM480-240q-17 0-28.5-11.5T440-280q0-17 11.5-28.5T480-320q17 0 28.5 11.5T520-280q0 17-11.5 28.5T480-240Zm-160 0q-17 0-28.5-11.5T280-280q0-17 11.5-28.5T320-320q17 0 28.5 11.5T360-280q0 17-11.5 28.5T320-240Zm320 0q-17 0-28.5-11.5T600-280q0-17 11.5-28.5T640-320q17 0 28.5 11.5T680-280q0 17-11.5 28.5T640-240Z\" />\n                </svg>\n            </button>\n\n            <button class=\"btn-view\" [ngClass]=\"{active: mode === 'week'}\" (click)=\"setMode('week')\">\n                <!-- week view -->\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path\n                        d=\"M160-160q-33 0-56.5-23.5T80-240v-480q0-33 23.5-56.5T160-800h640q33 0 56.5 23.5T880-720v480q0 33-23.5 56.5T800-160H160Zm360-80h100v-480H520v480Zm-180 0h100v-480H340v480Zm-180 0h100v-480H160v480Zm540 0h100v-480H700v480Z\" />\n                </svg>\n            </button>\n\n            <button class=\"btn-view\" [ngClass]=\"{active: mode === 'day'}\" (click)=\"setMode('day')\">\n                <!-- day view -->\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path\n                        d=\"M120-160v-80h720v80H120Zm0-560v-80h720v80H120Zm80 400q-33 0-56.5-23.5T120-400v-160q0-33 23.5-56.5T200-640h560q33 0 56.5 23.5T840-560v160q0 33-23.5 56.5T760-320H200Zm0-80h560v-160H200v160Zm0-160v160-160Z\" />\n                </svg>\n            </button>\n        </div>\n    </div>\n\n    <div class=\"view-container\">\n        <lib-calendar [events]=\"events\" [currentMonth]=\"currentMonth\" *ngIf=\"mode === 'month'\" [startAt]=\"startAt\"\n            (eventClick)=\"onEventClick($event)\"></lib-calendar>\n\n        <lib-week *ngIf=\"mode === 'week'\" [startAt]=\"startAt\" [startDate]=\"weekStartDate\"\n            [events]=\"weekEvents\"></lib-week>\n\n        <lib-day *ngIf=\"mode === 'day'\" [date]=\"selectedDate\" [events]=\"selectedDateEvents\"\n            (eventClick)=\"onEventClick($event)\"></lib-day>\n    </div>\n\n</div>"]}
286
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-angular-calendar/src/lib/components/smart-calendar/smart-calendar.component.ts","../../../../../../projects/smart-angular-calendar/src/lib/components/smart-calendar/smart-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { CalendarEvent } from '../../types';\n\n@Component({\n  selector: 'smart-calendar',\n  templateUrl: './smart-calendar.component.html',\n  styleUrls: ['./smart-calendar.component.scss']\n})\nexport class SmartCalendarComponent implements OnInit {\n\n  @Input() mode: 'month' | 'week' | 'day' = 'month';\n\n  @Input() startAt: 'monday' | 'sunday' = 'sunday';\n\n  @Input() currentMonth: { year: number, month: number } = {\n    year: new Date().getFullYear(),\n    month: new Date().getMonth() + 1\n  };\n\n  @Input() events: CalendarEvent[] = [];\n\n  @Output() monthChange = new EventEmitter<{\n    newMonth: { year: number, month: number },\n    oldMonth: { year: number, month: number }\n  }>();\n\n  @Output() dateChanged = new EventEmitter<Date>();\n\n  @Output() eventClick = new EventEmitter<CalendarEvent>();\n\n  @ViewChild('dateSelectorDropdown', { static: false }) dateSelectorDropdown!: ElementRef;\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent) {\n    if (!this.showDateSelector) return;\n    const dropdown = this.dateSelectorDropdown?.nativeElement;\n    const button = document.querySelector('.btn-date-selector');\n    if (dropdown && !dropdown.contains(event.target) && button && !button.contains(event.target as Node)) {\n      this.showDateSelector = false;\n    }\n  }\n\n  showDateSelector: boolean = false;\n\n  selectedDate: Date = new Date();\n  selectedDateEvents: CalendarEvent[] = [];\n\n  weekStartDate: Date = new Date();\n  weekEndDate: Date = new Date(this.weekStartDate.getTime() + 6 * 24 * 60 * 60 * 1000);\n  weekEvents: CalendarEvent[] = [];\n\n  constructor() { }\n\n  ngOnInit(): void {\n    this.selectDate(new Date());\n  }\n\n  toggleDateSelector() {\n    this.showDateSelector = !this.showDateSelector;\n  }\n\n  onMonthSelected(newMonth: { year: number, month: number }) {\n    const oldMonth = { ...this.currentMonth };\n    this.currentMonth = newMonth;\n\n    this.selectDate(new Date(this.currentMonth.year, this.currentMonth.month - 1, 1));\n\n    this.monthChange.emit({\n      newMonth: this.currentMonth,\n      oldMonth\n    });\n\n    this.showDateSelector = false;\n  }\n\n  onEventClick(event: CalendarEvent) {\n    this.eventClick.emit(event);\n  }\n\n  nextMonth() {\n    const oldMonth = { ...this.currentMonth };\n\n    if (this.currentMonth.month === 12) {\n      this.currentMonth = {\n        year: this.currentMonth.year + 1,\n        month: 1\n      };\n    } else {\n      this.currentMonth = {\n        year: this.currentMonth.year,\n        month: this.currentMonth.month + 1\n      };\n    }\n\n    this.selectDate(new Date(this.currentMonth.year, this.currentMonth.month - 1, 1));\n\n    this.monthChange.emit({\n      newMonth: this.currentMonth,\n      oldMonth\n    });\n  }\n\n  prevMonth() {\n    const oldMonth = { ...this.currentMonth };\n    if (this.currentMonth.month === 1) {\n      this.currentMonth = {\n        year: this.currentMonth.year - 1,\n        month: 12\n      };\n    } else {\n      this.currentMonth = {\n        year: this.currentMonth.year,\n        month: this.currentMonth.month - 1\n      };\n    }\n\n    this.selectDate(new Date(this.currentMonth.year, this.currentMonth.month - 1, 1));\n\n    this.monthChange.emit({\n      newMonth: this.currentMonth,\n      oldMonth\n    });\n  }\n\n  nextDay() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.selectedDate);\n    newDate.setDate(newDate.getDate() + 1);\n\n    this.selectDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  prevDay() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.selectedDate);\n    newDate.setDate(newDate.getDate() - 1);\n\n    this.selectDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  nextWeek() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.weekStartDate);\n    newDate.setDate(newDate.getDate() + 7);\n    this.selectWeekByDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  prevWeek() {\n    const oldMonth = { ...this.currentMonth };\n\n    const newDate = new Date(this.weekStartDate);\n    newDate.setDate(newDate.getDate() - 7);\n    this.selectWeekByDate(newDate);\n\n    this.currentMonth = {\n      year: newDate.getFullYear(),\n      month: newDate.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  onNext() {\n    if (this.mode === 'month')\n      this.nextMonth();\n    else if (this.mode === 'week')\n      this.nextWeek();\n    else if (this.mode === 'day')\n      this.nextDay();\n  }\n\n  onPrev() {\n    if (this.mode === 'month')\n      this.prevMonth();\n    else if (this.mode === 'week')\n      this.prevWeek();\n    else if (this.mode === 'day')\n      this.prevDay();\n  }\n\n  goToToday() {\n    const today = new Date();\n    const oldMonth = { ...this.currentMonth };\n\n    this.currentMonth = {\n      year: today.getFullYear(),\n      month: today.getMonth() + 1\n    };\n\n    this.selectDate(today);\n    this.selectWeekByDate(today, false);\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n  }\n\n  setSelectedDateEvents() {\n    this.selectedDateEvents = this.events.filter(event => {\n      const eventDate = new Date(event.start);\n\n      // return events that starts, ends or spans the selected date\n      return (eventDate.getDate() === this.selectedDate.getDate() &&\n        eventDate.getMonth() === this.selectedDate.getMonth() &&\n        eventDate.getFullYear() === this.selectedDate.getFullYear()) ||\n        (event.end &&\n          event.end.getDate() === this.selectedDate.getDate() &&\n          event.end.getMonth() === this.selectedDate.getMonth() &&\n          event.end.getFullYear() === this.selectedDate.getFullYear()) ||\n        (event.start < this.selectedDate && event.end && event.end > this.selectedDate);\n    });\n  }\n\n  selectDate(date: Date) {\n    this.selectedDate = date;\n\n    this.setSelectedDateEvents();\n\n    const oldMonth = this.currentMonth;\n\n    this.currentMonth = {\n      year: date.getFullYear(),\n      month: date.getMonth() + 1\n    };\n\n    if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n      this.monthChange.emit({\n        newMonth: this.currentMonth,\n        oldMonth\n      });\n\n    this.dateChanged.emit(this.selectedDate);\n  }\n\n  selectWeekByDate(date: Date, emitChange: boolean = true) {\n    // Calculate the start date of the week based on startAt\n    const dayOfWeek = date.getDay(); // 0 (Sun) to 6 (Sat)\n    let diffToStart: number;\n\n    if (this.startAt === 'monday') {\n      diffToStart = (dayOfWeek === 0) ? -6 : 1 - dayOfWeek; // If Sunday, go back 6 days\n    } else {\n      diffToStart = -dayOfWeek; // Sunday start\n    }\n\n    this.weekStartDate = new Date(date);\n    this.weekStartDate.setDate(date.getDate() + diffToStart);\n\n    this.weekEndDate = new Date(this.weekStartDate);\n    this.weekEndDate.setDate(this.weekStartDate.getDate() + 6);\n\n    // Filter events for the week\n    this.weekEvents = this.events.filter(event => {\n      const eventStart = new Date(event.start);\n      const eventEnd = event.end ? new Date(event.end) : eventStart;\n      return (eventStart <= this.weekEndDate) && (eventEnd >= this.weekStartDate);\n    });\n\n    if (emitChange) {\n      const oldMonth = this.currentMonth;\n\n      this.currentMonth = {\n        year: this.weekStartDate.getFullYear(),\n        month: this.weekStartDate.getMonth() + 1\n      };\n\n      if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)\n        this.monthChange.emit({\n          newMonth: this.currentMonth,\n          oldMonth\n        });\n    }\n  }\n\n  setMode(newMode: typeof this.mode) {\n    this.mode = newMode;\n    if (newMode === 'day') {\n      this.setSelectedDateEvents();\n    } else if (newMode === 'week') {\n      this.selectWeekByDate(this.selectedDate);\n    }\n  }\n\n}\n","<div class=\"smart-calendar-component\">\n    <div class=\"header\">\n        <div class=\"nav-controls\">\n            <button class=\"btn-prev\" (click)=\"onPrev()\">\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path d=\"M560-240 320-480l240-240 56 56-184 184 184 184-56 56Z\" />\n                </svg>\n            </button>\n\n            <button class=\"btn-today\" (click)=\"goToToday()\">{{'today' | translate}}</button>\n\n            <button class=\"btn-next\" (click)=\"onNext()\">\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path d=\"M504-480 320-664l56-56 240 240-240 240-56-56 184-184Z\" />\n                </svg>\n            </button>\n        </div>\n\n        <div class=\"spacer\"></div>\n\n        <div class=\"date-selector-container\">\n            <button class=\"btn-date-selector\" (click)=\"toggleDateSelector()\">\n                <span *ngIf=\"mode === 'month'\">{{ currentMonth.month | translateMonth}} - {{ currentMonth.year }}</span>\n                <span *ngIf=\"mode === 'week'\">\n                    {{ weekStartDate.toDateString() }} - {{ weekEndDate.toDateString() }}\n                </span>\n                <span *ngIf=\"mode === 'day'\">{{ selectedDate.toDateString() }}</span>\n\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path d=\"M480-360 280-560h400L480-360Z\" />\n                </svg>\n            </button>\n\n            <div class=\"date-selector-dropdown\" *ngIf=\"showDateSelector\" #dateSelectorDropdown>\n                <lib-month-selector [selectedMonth]=\"currentMonth\"\n                    (monthSelected)=\"onMonthSelected($event)\"></lib-month-selector>\n            </div>\n        </div>\n\n        <div class=\"spacer\"></div>\n\n        <div class=\"view-selector\">\n            <button class=\"btn-view\" [ngClass]=\"{active: mode === 'month'}\" (click)=\"setMode('month')\">\n                <!-- month view -->\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path\n                        d=\"M200-80q-33 0-56.5-23.5T120-160v-560q0-33 23.5-56.5T200-800h40v-80h80v80h320v-80h80v80h40q33 0 56.5 23.5T840-720v560q0 33-23.5 56.5T760-80H200Zm0-80h560v-400H200v400Zm0-480h560v-80H200v80Zm0 0v-80 80Zm280 240q-17 0-28.5-11.5T440-440q0-17 11.5-28.5T480-480q17 0 28.5 11.5T520-440q0 17-11.5 28.5T480-400Zm-160 0q-17 0-28.5-11.5T280-440q0-17 11.5-28.5T320-480q17 0 28.5 11.5T360-440q0 17-11.5 28.5T320-400Zm320 0q-17 0-28.5-11.5T600-440q0-17 11.5-28.5T640-480q17 0 28.5 11.5T680-440q0 17-11.5 28.5T640-400ZM480-240q-17 0-28.5-11.5T440-280q0-17 11.5-28.5T480-320q17 0 28.5 11.5T520-280q0 17-11.5 28.5T480-240Zm-160 0q-17 0-28.5-11.5T280-280q0-17 11.5-28.5T320-320q17 0 28.5 11.5T360-280q0 17-11.5 28.5T320-240Zm320 0q-17 0-28.5-11.5T600-280q0-17 11.5-28.5T640-320q17 0 28.5 11.5T680-280q0 17-11.5 28.5T640-240Z\" />\n                </svg>\n            </button>\n\n            <button class=\"btn-view\" [ngClass]=\"{active: mode === 'week'}\" (click)=\"setMode('week')\">\n                <!-- week view -->\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path\n                        d=\"M160-160q-33 0-56.5-23.5T80-240v-480q0-33 23.5-56.5T160-800h640q33 0 56.5 23.5T880-720v480q0 33-23.5 56.5T800-160H160Zm360-80h100v-480H520v480Zm-180 0h100v-480H340v480Zm-180 0h100v-480H160v480Zm540 0h100v-480H700v480Z\" />\n                </svg>\n            </button>\n\n            <button class=\"btn-view\" [ngClass]=\"{active: mode === 'day'}\" (click)=\"setMode('day')\">\n                <!-- day view -->\n                <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\"\n                    fill=\"currentColor\">\n                    <path\n                        d=\"M120-160v-80h720v80H120Zm0-560v-80h720v80H120Zm80 400q-33 0-56.5-23.5T120-400v-160q0-33 23.5-56.5T200-640h560q33 0 56.5 23.5T840-560v160q0 33-23.5 56.5T760-320H200Zm0-80h560v-160H200v160Zm0-160v160-160Z\" />\n                </svg>\n            </button>\n        </div>\n    </div>\n\n    <div class=\"view-container\">\n        <lib-calendar [events]=\"events\" [currentMonth]=\"currentMonth\" *ngIf=\"mode === 'month'\" [startAt]=\"startAt\"\n            (eventClick)=\"onEventClick($event)\"></lib-calendar>\n\n        <lib-week *ngIf=\"mode === 'week'\" [startAt]=\"startAt\" [startDate]=\"weekStartDate\"\n            [events]=\"weekEvents\"></lib-week>\n\n        <lib-day *ngIf=\"mode === 'day'\" [date]=\"selectedDate\" [events]=\"selectedDateEvents\"\n            (eventClick)=\"onEventClick($event)\"></lib-day>\n    </div>\n\n</div>"]}
@@ -892,7 +892,7 @@ class SmartCalendarComponent {
892
892
  month: today.getMonth() + 1
893
893
  };
894
894
  this.selectDate(today);
895
- this.selectWeekByDate(today);
895
+ this.selectWeekByDate(today, false);
896
896
  if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)
897
897
  this.monthChange.emit({
898
898
  newMonth: this.currentMonth,
@@ -928,7 +928,7 @@ class SmartCalendarComponent {
928
928
  });
929
929
  this.dateChanged.emit(this.selectedDate);
930
930
  }
931
- selectWeekByDate(date) {
931
+ selectWeekByDate(date, emitChange = true) {
932
932
  // Calculate the start date of the week based on startAt
933
933
  const dayOfWeek = date.getDay(); // 0 (Sun) to 6 (Sat)
934
934
  let diffToStart;
@@ -948,16 +948,18 @@ class SmartCalendarComponent {
948
948
  const eventEnd = event.end ? new Date(event.end) : eventStart;
949
949
  return (eventStart <= this.weekEndDate) && (eventEnd >= this.weekStartDate);
950
950
  });
951
- const oldMonth = this.currentMonth;
952
- this.currentMonth = {
953
- year: this.weekStartDate.getFullYear(),
954
- month: this.weekStartDate.getMonth() + 1
955
- };
956
- if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)
957
- this.monthChange.emit({
958
- newMonth: this.currentMonth,
959
- oldMonth
960
- });
951
+ if (emitChange) {
952
+ const oldMonth = this.currentMonth;
953
+ this.currentMonth = {
954
+ year: this.weekStartDate.getFullYear(),
955
+ month: this.weekStartDate.getMonth() + 1
956
+ };
957
+ if (this.currentMonth.month !== oldMonth.month || this.currentMonth.year !== oldMonth.year)
958
+ this.monthChange.emit({
959
+ newMonth: this.currentMonth,
960
+ oldMonth
961
+ });
962
+ }
961
963
  }
962
964
  setMode(newMode) {
963
965
  this.mode = newMode;