import { Calendar, CalendarEvent } from '/lib/types.ts'; import { getCalendarEventColor } from '/lib/utils/calendar.ts'; interface CalendarViewDayProps { startDate: Date; visibleCalendars: Pick[]; calendarEvents: CalendarEvent[]; onClickAddEvent: (startDate?: Date, isAllDay?: boolean) => void; onClickOpenEvent: (calendarEvent: CalendarEvent) => void; } export default function CalendarViewDay( { startDate, visibleCalendars, calendarEvents, onClickAddEvent, onClickOpenEvent }: CalendarViewDayProps, ) { const today = new Date().toISOString().substring(0, 10); const hourFormat = new Intl.DateTimeFormat('en-GB', { hour12: false, hour: '2-digit', minute: '2-digit' }); const dayFormat = new Intl.DateTimeFormat('en-GB', { weekday: 'long', day: 'numeric', month: 'long', year: 'numeric', }); const allDayEvents: CalendarEvent[] = calendarEvents.filter((calendarEvent) => { if (!calendarEvent.is_all_day) { return false; } const startDayDate = new Date(startDate); const endDayDate = new Date(startDate); endDayDate.setHours(23); endDayDate.setMinutes(59); endDayDate.setSeconds(59); endDayDate.setMilliseconds(999); 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; }); const hours: { date: Date; isCurrentHour: boolean }[] = Array.from({ length: 24 }).map((_, index) => { const hourNumber = index; const date = new Date(startDate); date.setHours(hourNumber); const shortIsoDate = date.toISOString().substring(0, 10); const isCurrentHour = shortIsoDate === today && new Date().getHours() === hourNumber; return { date, isCurrentHour, }; }); return (
{dayFormat.format(startDate)}
{allDayEvents.length > 0 ? (
    {allDayEvents.map((calendarEvent) => (
  1. onClickOpenEvent(calendarEvent)} >

    {calendarEvent.title}

  2. ))}
) : null} {hours.map((hour, hourIndex) => { const shortIsoDate = hour.date.toISOString().substring(0, 10); const startHourDate = new Date(shortIsoDate); startHourDate.setHours(hour.date.getHours()); const endHourDate = new Date(shortIsoDate); endHourDate.setHours(hour.date.getHours()); endHourDate.setMinutes(59); endHourDate.setSeconds(59); endHourDate.setMilliseconds(999); const isLastHour = hourIndex === 23; const hourEvents = calendarEvents.filter((calendarEvent) => { if (calendarEvent.is_all_day) { return false; } const eventStartDate = new Date(calendarEvent.start_date); const eventEndDate = new Date(calendarEvent.end_date); eventEndDate.setSeconds(eventEndDate.getSeconds() - 1); // Take one second back so events don't bleed into the next hour // Event starts and ends on this hour if (eventStartDate >= startHourDate && eventEndDate <= endHourDate) { return true; } // Event starts before and ends after this hour if (eventStartDate <= startHourDate && eventEndDate >= endHourDate) { return true; } // Event starts on and ends after this hour if ( eventStartDate >= startHourDate && eventStartDate <= endHourDate && eventEndDate >= endHourDate ) { return true; } // Event starts before and ends on this hour if ( eventStartDate <= startHourDate && eventEndDate >= startHourDate && eventEndDate <= endHourDate ) { return true; } return false; }); return (
{hourEvents.length > 0 ? (
    {hourEvents.map((hourEvent) => (
  1. onClickOpenEvent(hourEvent)} >

    {hourEvent.title}

  2. ))}
) : null}
); })}
); }