import { Handlers } from 'fresh/server.ts'; import { FreshContextState } from '/lib/types.ts'; import { CalendarEvent, CalendarEventModel, CalendarModel } from '/lib/models/calendar.ts'; import { getDateRangeForCalendarView } from '/lib/utils/calendar.ts'; interface Data {} export interface RequestBody { calendarIds: string[]; calendarView: 'day' | 'week' | 'month'; calendarStartDate: string; calendarId: string; calendarEventId: string; } export interface ResponseBody { success: boolean; newCalendarEvents: CalendarEvent[]; } export const handler: Handlers = { async POST(request, context) { if (!context.state.user) { return new Response('Unauthorized', { status: 401 }); } const requestBody = await request.clone().json() as RequestBody; if ( !requestBody.calendarId || !requestBody.calendarIds || !requestBody.calendarEventId || !requestBody.calendarEventId || !requestBody.calendarView || !requestBody.calendarStartDate ) { return new Response('Bad Request', { status: 400 }); } const calendar = await CalendarModel.get(context.state.user.id, requestBody.calendarId); if (!calendar) { return new Response('Not Found', { status: 404 }); } const calendarEvent = await CalendarEventModel.get( context.state.user.id, calendar.uid!, requestBody.calendarEventId, ); if (!calendarEvent || requestBody.calendarId !== calendarEvent.calendarId) { return new Response('Not Found', { status: 404 }); } await CalendarEventModel.delete(context.state.user.id, calendarEvent.url); const dateRange = getDateRangeForCalendarView(requestBody.calendarStartDate, requestBody.calendarView); const newCalendarEvents = await CalendarEventModel.list(context.state.user.id, requestBody.calendarIds, dateRange); const responseBody: ResponseBody = { success: true, newCalendarEvents }; return new Response(JSON.stringify(responseBody)); }, };