import { Calendar, CalendarEvent } from '/lib/types.ts'; import { getWeeksForMonth } from '/lib/utils.ts'; interface CalendarViewWeekProps { startDate: Date; visibleCalendars: Pick[]; calendarEvents: CalendarEvent[]; onClickAddEvent: (startDate?: Date, isAllDay?: boolean) => void; onClickOpenEvent: (calendarEvent: CalendarEvent) => void; } export default function CalendarViewWeek( { startDate, visibleCalendars, calendarEvents, onClickAddEvent, onClickOpenEvent }: CalendarViewWeekProps, ) { const today = new Date().toISOString().substring(0, 10); const hourFormat = new Intl.DateTimeFormat('en-GB', { hour12: false, hour: '2-digit', minute: '2-digit' }); const weeks = getWeeksForMonth(new Date(startDate)); return (
Mon
Tue
Wed
Thu
Fri
Sat
Sun
{weeks.map((week, weekIndex) => week.map((day, dayIndex) => { const shortIsoDate = day.date.toISOString().substring(0, 10); const startDayDate = new Date(shortIsoDate); const endDayDate = new Date(shortIsoDate); endDayDate.setHours(23); endDayDate.setMinutes(59); endDayDate.setSeconds(59); endDayDate.setMilliseconds(999); const isBottomLeftDay = weekIndex === weeks.length - 1 && dayIndex === 0; const isBottomRightDay = weekIndex === weeks.length - 1 && dayIndex === week.length - 1; const isToday = today === shortIsoDate; const dayEvents = calendarEvents.filter((calendarEvent) => { const eventStartDate = new Date(calendarEvent.start_date); const eventEndDate = new Date(calendarEvent.end_date); // Event starts and ends on this day if (eventStartDate >= startDayDate && eventEndDate <= endDayDate) { return true; } // Event starts before and ends after this day if (eventStartDate <= startDayDate && eventEndDate >= endDayDate) { return true; } // Event starts on and ends after this day if ( eventStartDate >= startDayDate && eventStartDate <= endDayDate && eventEndDate >= endDayDate ) { return true; } // Event starts before and ends on this day if ( eventStartDate <= startDayDate && eventEndDate >= startDayDate && eventEndDate <= endDayDate ) { return true; } return false; }); return (
{dayEvents.length > 0 ? (
    {[...dayEvents].slice(0, 2).map((dayEvent) => (
  1. calendar.id === dayEvent.calendar_id) ?.color || 'bg-gray-700' }`} onClick={() => onClickOpenEvent(dayEvent)} >

    {dayEvent.title}

  2. ))} {dayEvents.length > 2 ? (
  3. ...{dayEvents.length - 2} more event{dayEvents.length - 2 === 1 ? '' : 's'}

  4. ) : null}
) : null}
); }) )}
); }