@smart-solutions-tech/smart-angular-calendar 0.0.13 → 0.0.14

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.
@@ -228,11 +228,12 @@ export class SmartCalendarComponent {
228
228
  this.weekStartDate.setDate(date.getDate() + diffToStart);
229
229
  this.weekEndDate = new Date(this.weekStartDate);
230
230
  this.weekEndDate.setDate(this.weekStartDate.getDate() + 6);
231
- // Filter events for the week
231
+ // Filter events for the week, including multi-day events that overlap any part of the week
232
232
  this.weekEvents = this.events.filter(event => {
233
233
  const eventStart = new Date(event.start);
234
234
  const eventEnd = event.end ? new Date(event.end) : eventStart;
235
- return (eventStart <= this.weekEndDate) && (eventEnd >= this.weekStartDate);
235
+ // Un evento se incluye si cualquier parte de él cae dentro de la semana
236
+ return eventStart <= this.weekEndDate && eventEnd >= this.weekStartDate;
236
237
  });
237
238
  if (emitChange) {
238
239
  const oldMonth = this.currentMonth;
@@ -283,4 +284,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
283
284
  type: HostListener,
284
285
  args: ['document:click', ['$event']]
285
286
  }] } });
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\" [events]=\"weekEvents\"\n            (eventClick)=\"onEventClick($event)\"></lib-week>\n\n        <lib-day *ngIf=\"mode === 'day'\" [date]=\"selectedDate\" [events]=\"selectedDateEvents\"\n            (eventClick)=\"onEventClick($event)\"></lib-day>\n    </div>\n\n</div>"]}
287
+ //# 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, including multi-day events that overlap any part of 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      // Un evento se incluye si cualquier parte de él cae dentro de la semana\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\" [events]=\"weekEvents\"\n            (eventClick)=\"onEventClick($event)\"></lib-week>\n\n        <lib-day *ngIf=\"mode === 'day'\" [date]=\"selectedDate\" [events]=\"selectedDateEvents\"\n            (eventClick)=\"onEventClick($event)\"></lib-day>\n    </div>\n\n</div>"]}
@@ -64,22 +64,28 @@ export class WeekComponent {
64
64
  this.events.forEach(event => this.addEvent(event));
65
65
  }
66
66
  addEvent(event) {
67
- const index = this.weekDayCols.findIndex(col => col.date.getFullYear() === event.start.getFullYear() &&
68
- col.date.getMonth() === event.start.getMonth() &&
69
- col.date.getDate() === event.start.getDate());
70
- if (index === -1)
71
- return;
72
- const eventCols = this.weekDayCols[index].eventCols;
73
- if (event.allDay) {
74
- this.weekDayCols[index].allDayEvents.push(event);
75
- }
76
- else {
77
- const colIndex = this.findAvalailableColumn(event, index);
78
- if (colIndex === eventCols.length) {
79
- eventCols.push({ events: [event] });
80
- }
81
- else {
82
- eventCols[colIndex].events.push(event);
67
+ // Mostrar eventos en todos los días que abarquen
68
+ // Normalizar fechas a solo año, mes y día para comparar correctamente
69
+ const normalize = (d) => new Date(d.getFullYear(), d.getMonth(), d.getDate());
70
+ const eventStart = normalize(event.start);
71
+ const eventEnd = event.end ? normalize(event.end) : eventStart;
72
+ for (let i = 0; i < this.weekDayCols.length; i++) {
73
+ const colDate = normalize(this.weekDayCols[i].date);
74
+ // Si el día está dentro del rango del evento (incluyendo el día de fin)
75
+ if (colDate >= eventStart && colDate <= eventEnd) {
76
+ if (event.allDay) {
77
+ this.weekDayCols[i].allDayEvents.push(event);
78
+ }
79
+ else {
80
+ const colIndex = this.findAvalailableColumn(event, i);
81
+ const eventCols = this.weekDayCols[i].eventCols;
82
+ if (colIndex === eventCols.length) {
83
+ eventCols.push({ events: [event] });
84
+ }
85
+ else {
86
+ eventCols[colIndex].events.push(event);
87
+ }
88
+ }
83
89
  }
84
90
  }
85
91
  }
@@ -136,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
136
142
  }], eventClick: [{
137
143
  type: Output
138
144
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"week.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-angular-calendar/src/lib/components/week/week.component.ts","../../../../../../projects/smart-angular-calendar/src/lib/components/week/week.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { CalendarEvent, WeekDay } from '../../types';\n\n@Component({\n  selector: 'lib-week',\n  templateUrl: './week.component.html',\n  styleUrls: ['./week.component.scss']\n})\nexport class WeekComponent implements OnInit, OnChanges {\n\n  @Input() startAt: 'monday' | 'sunday' = 'sunday';\n\n  @Input() events: CalendarEvent[] = [];\n  @Input() startDate!: Date;\n\n  @Output() eventClick = new EventEmitter<CalendarEvent>();\n\n  weekDays: WeekDay[] = [\n    { tag: 'sun' },\n    { tag: 'mon' },\n    { tag: 'tue' },\n    { tag: 'wed' },\n    { tag: 'thu' },\n    { tag: 'fri' },\n    { tag: 'sat' },\n  ];\n\n  hourBlocks: number[] = Array.from({ length: 24 }, (_, i) => i);\n\n  allDayHeight = 60;\n\n  weekDayCols: {\n    date: Date;\n    eventCols: {\n      events: CalendarEvent[];\n    }[];\n    allDayEvents: CalendarEvent[];\n  }[] = [];\n\n  constructor() { }\n\n  ngOnInit(): void {\n    if (this.startAt === 'monday') {\n      this.weekDays = [\n        { tag: 'mon' },\n        { tag: 'tue' },\n        { tag: 'wed' },\n        { tag: 'thu' },\n        { tag: 'fri' },\n        { tag: 'sat' },\n        { tag: 'sun' },\n      ];\n    }\n\n    this.initWeekDayCols();\n  }\n\n  initWeekDayCols() {\n    this.weekDayCols = [];\n    for (let i = 0; i < 7; i++) {\n      const currentDate = new Date(this.startDate.getTime() + i * 24 * 60 * 60 * 1000);\n      this.weekDayCols.push({\n        date: currentDate,\n        eventCols: [],\n        allDayEvents: []\n      });\n    }\n\n    this.events.forEach(event => this.addEvent(event));\n  }\n\n  addEvent(event: CalendarEvent) {\n    const index = this.weekDayCols.findIndex(col =>\n      col.date.getFullYear() === event.start.getFullYear() &&\n      col.date.getMonth() === event.start.getMonth() &&\n      col.date.getDate() === event.start.getDate()\n    );\n\n    if (index === -1) return;\n\n    const eventCols = this.weekDayCols[index].eventCols;\n\n    if (event.allDay) {\n      this.weekDayCols[index].allDayEvents.push(event);\n    } else {\n      const colIndex = this.findAvalailableColumn(event, index);\n\n      if (colIndex === eventCols.length) {\n        eventCols.push({ events: [event] });\n      } else {\n        eventCols[colIndex].events.push(event);\n      }\n    }\n  }\n\n  findAvalailableColumn(event: CalendarEvent, dayIndex: number): number {\n    const eventCols = this.weekDayCols[dayIndex].eventCols;\n\n    for (let colIndex = 0; colIndex < eventCols.length; colIndex++) {\n      const col = eventCols[colIndex];\n\n      // conflict if event overlaps with any existing event in the column\n      const hasConflict = col.events.some(existingEvent => {\n        const startsDuringExisting = event.start < existingEvent.end! && event.start >= existingEvent.start;\n        const endsDuringExisting = event.end! > existingEvent.start && event.end! <= existingEvent.end!;\n        const spansExisting = event.start <= existingEvent.start && event.end! >= existingEvent.end!;\n        return startsDuringExisting || endsDuringExisting || spansExisting;\n      });\n\n      if (!hasConflict) {\n        return colIndex;\n      }\n    }\n    return eventCols.length;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['events'] || changes['startDate']) {\n      this.initWeekDayCols();\n    }\n  }\n\n  private resizing = false;\n  private startY = 0;\n  private startHeight = 0;\n\n  onResizeMouseDown(event: MouseEvent): void {\n    this.resizing = true;\n    this.startY = event.clientY;\n    this.startHeight = this.allDayHeight;\n    document.addEventListener('mousemove', this.onResizeMouseMove);\n    document.addEventListener('mouseup', this.onResizeMouseUp);\n  }\n\n  onResizeMouseMove = (event: MouseEvent): void => {\n    if (!this.resizing) return;\n    const delta = event.clientY - this.startY;\n    const newHeight = this.startHeight + delta;\n    this.allDayHeight = Math.max(60, newHeight); // mínimo 80px\n  };\n\n  onResizeMouseUp = (): void => {\n    this.resizing = false;\n    document.removeEventListener('mousemove', this.onResizeMouseMove);\n    document.removeEventListener('mouseup', this.onResizeMouseUp);\n  };\n\n  onEventClick(event: CalendarEvent): void {\n    this.eventClick.emit(event);\n  }\n\n  isToday(date: Date): boolean {\n    const today = new Date();\n    return date.getFullYear() === today.getFullYear() &&\n      date.getMonth() === today.getMonth() &&\n      date.getDate() === today.getDate();\n  }\n\n}\n","<div class=\"week-view-component\">\n    <section class=\"all-day-events\" [style.height.px]=\"allDayHeight\">\n        <div class=\"header\">\n            {{'allDayEvents' | translate}}\n        </div>\n\n        <div class=\"days-container\">\n            <div class=\"events-container\" *ngFor=\"let day of weekDayCols; let i = index\">\n                <div class=\"week-day\" [ngClass]=\"{'active': isToday(day.date)}\">\n                    {{ weekDays[i].tag | translate | slice:0:3 }} {{day.date | date:'dd'}}\n                </div>\n\n                <lib-calendar-event *ngFor=\"let event of day.allDayEvents\" [event]=\"event\"\n                    (eventClick)=\"onEventClick($event)\"></lib-calendar-event>\n            </div>\n        </div>\n    </section>\n\n    <div class=\"resize-divider\" (mousedown)=\"onResizeMouseDown($event)\"></div>\n\n    <section class=\"duration-events\">\n        <div class=\"hour-blocks\">\n            <div class=\"hour-block\" *ngFor=\"let hour of hourBlocks\">\n                <span>{{ hour }}:00</span>\n            </div>\n        </div>\n\n        <div class=\"events-wrapper\">\n            <div class=\"time-blocks\">\n                <div class=\"day-block\" *ngFor=\"let day of weekDayCols\">\n                    <div class=\"time-block\" *ngFor=\"let hour of hourBlocks\">\n                        <div class=\"time-block-middle\"></div>\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"days-container\">\n                <div class=\"events-container\" *ngFor=\"let day of weekDayCols\"\n                    [style.gridTemplateColumns]=\"'repeat(' + day.eventCols.length + ', 1fr)'\">\n                    <div class=\"event-column\" *ngFor=\"let col of day.eventCols\">\n\n                        <lib-duration-event *ngFor=\"let event of col.events\" [event]=\"event\" [date]=\"day.date\"\n                            (eventClick)=\"onEventClick($event)\"></lib-duration-event>\n\n                    </div>\n                </div>\n            </div>\n        </div>\n    </section>\n</div>"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"week.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-angular-calendar/src/lib/components/week/week.component.ts","../../../../../../projects/smart-angular-calendar/src/lib/components/week/week.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { CalendarEvent, WeekDay } from '../../types';\n\n@Component({\n  selector: 'lib-week',\n  templateUrl: './week.component.html',\n  styleUrls: ['./week.component.scss']\n})\nexport class WeekComponent implements OnInit, OnChanges {\n\n  @Input() startAt: 'monday' | 'sunday' = 'sunday';\n\n  @Input() events: CalendarEvent[] = [];\n  @Input() startDate!: Date;\n\n  @Output() eventClick = new EventEmitter<CalendarEvent>();\n\n  weekDays: WeekDay[] = [\n    { tag: 'sun' },\n    { tag: 'mon' },\n    { tag: 'tue' },\n    { tag: 'wed' },\n    { tag: 'thu' },\n    { tag: 'fri' },\n    { tag: 'sat' },\n  ];\n\n  hourBlocks: number[] = Array.from({ length: 24 }, (_, i) => i);\n\n  allDayHeight = 60;\n\n  weekDayCols: {\n    date: Date;\n    eventCols: {\n      events: CalendarEvent[];\n    }[];\n    allDayEvents: CalendarEvent[];\n  }[] = [];\n\n  constructor() { }\n\n  ngOnInit(): void {\n    if (this.startAt === 'monday') {\n      this.weekDays = [\n        { tag: 'mon' },\n        { tag: 'tue' },\n        { tag: 'wed' },\n        { tag: 'thu' },\n        { tag: 'fri' },\n        { tag: 'sat' },\n        { tag: 'sun' },\n      ];\n    }\n\n    this.initWeekDayCols();\n  }\n\n  initWeekDayCols() {\n    this.weekDayCols = [];\n    for (let i = 0; i < 7; i++) {\n      const currentDate = new Date(this.startDate.getTime() + i * 24 * 60 * 60 * 1000);\n      this.weekDayCols.push({\n        date: currentDate,\n        eventCols: [],\n        allDayEvents: []\n      });\n    }\n\n    this.events.forEach(event => this.addEvent(event));\n  }\n\n  addEvent(event: CalendarEvent) {\n    // Mostrar eventos en todos los días que abarquen\n    // Normalizar fechas a solo año, mes y día para comparar correctamente\n    const normalize = (d: Date) => new Date(d.getFullYear(), d.getMonth(), d.getDate());\n    const eventStart = normalize(event.start);\n    const eventEnd = event.end ? normalize(event.end) : eventStart;\n\n    for (let i = 0; i < this.weekDayCols.length; i++) {\n      const colDate = normalize(this.weekDayCols[i].date);\n      // Si el día está dentro del rango del evento (incluyendo el día de fin)\n      if (colDate >= eventStart && colDate <= eventEnd) {\n        if (event.allDay) {\n          this.weekDayCols[i].allDayEvents.push(event);\n        } else {\n          const colIndex = this.findAvalailableColumn(event, i);\n          const eventCols = this.weekDayCols[i].eventCols;\n          if (colIndex === eventCols.length) {\n            eventCols.push({ events: [event] });\n          } else {\n            eventCols[colIndex].events.push(event);\n          }\n        }\n      }\n    }\n  }\n\n  findAvalailableColumn(event: CalendarEvent, dayIndex: number): number {\n    const eventCols = this.weekDayCols[dayIndex].eventCols;\n\n    for (let colIndex = 0; colIndex < eventCols.length; colIndex++) {\n      const col = eventCols[colIndex];\n\n      // conflict if event overlaps with any existing event in the column\n      const hasConflict = col.events.some(existingEvent => {\n        const startsDuringExisting = event.start < existingEvent.end! && event.start >= existingEvent.start;\n        const endsDuringExisting = event.end! > existingEvent.start && event.end! <= existingEvent.end!;\n        const spansExisting = event.start <= existingEvent.start && event.end! >= existingEvent.end!;\n        return startsDuringExisting || endsDuringExisting || spansExisting;\n      });\n\n      if (!hasConflict) {\n        return colIndex;\n      }\n    }\n    return eventCols.length;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['events'] || changes['startDate']) {\n      this.initWeekDayCols();\n    }\n  }\n\n  private resizing = false;\n  private startY = 0;\n  private startHeight = 0;\n\n  onResizeMouseDown(event: MouseEvent): void {\n    this.resizing = true;\n    this.startY = event.clientY;\n    this.startHeight = this.allDayHeight;\n    document.addEventListener('mousemove', this.onResizeMouseMove);\n    document.addEventListener('mouseup', this.onResizeMouseUp);\n  }\n\n  onResizeMouseMove = (event: MouseEvent): void => {\n    if (!this.resizing) return;\n    const delta = event.clientY - this.startY;\n    const newHeight = this.startHeight + delta;\n    this.allDayHeight = Math.max(60, newHeight); // mínimo 80px\n  };\n\n  onResizeMouseUp = (): void => {\n    this.resizing = false;\n    document.removeEventListener('mousemove', this.onResizeMouseMove);\n    document.removeEventListener('mouseup', this.onResizeMouseUp);\n  };\n\n  onEventClick(event: CalendarEvent): void {\n    this.eventClick.emit(event);\n  }\n\n  isToday(date: Date): boolean {\n    const today = new Date();\n    return date.getFullYear() === today.getFullYear() &&\n      date.getMonth() === today.getMonth() &&\n      date.getDate() === today.getDate();\n  }\n\n}\n","<div class=\"week-view-component\">\n    <section class=\"all-day-events\" [style.height.px]=\"allDayHeight\">\n        <div class=\"header\">\n            {{'allDayEvents' | translate}}\n        </div>\n\n        <div class=\"days-container\">\n            <div class=\"events-container\" *ngFor=\"let day of weekDayCols; let i = index\">\n                <div class=\"week-day\" [ngClass]=\"{'active': isToday(day.date)}\">\n                    {{ weekDays[i].tag | translate | slice:0:3 }} {{day.date | date:'dd'}}\n                </div>\n\n                <lib-calendar-event *ngFor=\"let event of day.allDayEvents\" [event]=\"event\"\n                    (eventClick)=\"onEventClick($event)\"></lib-calendar-event>\n            </div>\n        </div>\n    </section>\n\n    <div class=\"resize-divider\" (mousedown)=\"onResizeMouseDown($event)\"></div>\n\n    <section class=\"duration-events\">\n        <div class=\"hour-blocks\">\n            <div class=\"hour-block\" *ngFor=\"let hour of hourBlocks\">\n                <span>{{ hour }}:00</span>\n            </div>\n        </div>\n\n        <div class=\"events-wrapper\">\n            <div class=\"time-blocks\">\n                <div class=\"day-block\" *ngFor=\"let day of weekDayCols\">\n                    <div class=\"time-block\" *ngFor=\"let hour of hourBlocks\">\n                        <div class=\"time-block-middle\"></div>\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"days-container\">\n                <div class=\"events-container\" *ngFor=\"let day of weekDayCols\"\n                    [style.gridTemplateColumns]=\"'repeat(' + day.eventCols.length + ', 1fr)'\">\n                    <div class=\"event-column\" *ngFor=\"let col of day.eventCols\">\n\n                        <lib-duration-event *ngFor=\"let event of col.events\" [event]=\"event\" [date]=\"day.date\"\n                            (eventClick)=\"onEventClick($event)\"></lib-duration-event>\n\n                    </div>\n                </div>\n            </div>\n        </div>\n    </section>\n</div>"]}
@@ -653,22 +653,28 @@ class WeekComponent {
653
653
  this.events.forEach(event => this.addEvent(event));
654
654
  }
655
655
  addEvent(event) {
656
- const index = this.weekDayCols.findIndex(col => col.date.getFullYear() === event.start.getFullYear() &&
657
- col.date.getMonth() === event.start.getMonth() &&
658
- col.date.getDate() === event.start.getDate());
659
- if (index === -1)
660
- return;
661
- const eventCols = this.weekDayCols[index].eventCols;
662
- if (event.allDay) {
663
- this.weekDayCols[index].allDayEvents.push(event);
664
- }
665
- else {
666
- const colIndex = this.findAvalailableColumn(event, index);
667
- if (colIndex === eventCols.length) {
668
- eventCols.push({ events: [event] });
669
- }
670
- else {
671
- eventCols[colIndex].events.push(event);
656
+ // Mostrar eventos en todos los días que abarquen
657
+ // Normalizar fechas a solo año, mes y día para comparar correctamente
658
+ const normalize = (d) => new Date(d.getFullYear(), d.getMonth(), d.getDate());
659
+ const eventStart = normalize(event.start);
660
+ const eventEnd = event.end ? normalize(event.end) : eventStart;
661
+ for (let i = 0; i < this.weekDayCols.length; i++) {
662
+ const colDate = normalize(this.weekDayCols[i].date);
663
+ // Si el día está dentro del rango del evento (incluyendo el día de fin)
664
+ if (colDate >= eventStart && colDate <= eventEnd) {
665
+ if (event.allDay) {
666
+ this.weekDayCols[i].allDayEvents.push(event);
667
+ }
668
+ else {
669
+ const colIndex = this.findAvalailableColumn(event, i);
670
+ const eventCols = this.weekDayCols[i].eventCols;
671
+ if (colIndex === eventCols.length) {
672
+ eventCols.push({ events: [event] });
673
+ }
674
+ else {
675
+ eventCols[colIndex].events.push(event);
676
+ }
677
+ }
672
678
  }
673
679
  }
674
680
  }
@@ -948,11 +954,12 @@ class SmartCalendarComponent {
948
954
  this.weekStartDate.setDate(date.getDate() + diffToStart);
949
955
  this.weekEndDate = new Date(this.weekStartDate);
950
956
  this.weekEndDate.setDate(this.weekStartDate.getDate() + 6);
951
- // Filter events for the week
957
+ // Filter events for the week, including multi-day events that overlap any part of the week
952
958
  this.weekEvents = this.events.filter(event => {
953
959
  const eventStart = new Date(event.start);
954
960
  const eventEnd = event.end ? new Date(event.end) : eventStart;
955
- return (eventStart <= this.weekEndDate) && (eventEnd >= this.weekStartDate);
961
+ // Un evento se incluye si cualquier parte de él cae dentro de la semana
962
+ return eventStart <= this.weekEndDate && eventEnd >= this.weekStartDate;
956
963
  });
957
964
  if (emitChange) {
958
965
  const oldMonth = this.currentMonth;