Calendar/src/repositories/MockEventRepository.ts

87 lines
2.8 KiB
TypeScript
Raw Normal View History

import { ICalendarEvent, EntityType, CalendarEventType } from '../types/CalendarTypes';
import { IApiRepository } from './IApiRepository';
2025-11-03 14:54:57 +01:00
interface RawEventData {
id: string;
title: string;
start: string | Date;
end: string | Date;
type: string;
allDay?: boolean;
bookingId?: string;
resourceId?: string;
customerId?: string;
description?: string;
recurringId?: string;
metadata?: Record<string, unknown>;
2025-11-03 14:54:57 +01:00
[key: string]: unknown;
}
/**
* MockEventRepository - Loads event data from local JSON file
2025-11-03 14:54:57 +01:00
*
* Used for development and testing. Only fetchAll() is implemented.
2025-11-03 14:54:57 +01:00
*/
export class MockEventRepository implements IApiRepository<ICalendarEvent> {
public readonly entityType: EntityType = 'Event';
2025-11-03 14:54:57 +01:00
private readonly dataUrl = 'data/mock-events.json';
/**
* Fetch all events from mock JSON file
*/
public async fetchAll(): Promise<ICalendarEvent[]> {
2025-11-03 14:54:57 +01:00
try {
const response = await fetch(this.dataUrl);
if (!response.ok) {
throw new Error(`Failed to load mock events: ${response.status} ${response.statusText}`);
}
const rawData: RawEventData[] = await response.json();
return this.processCalendarData(rawData);
} catch (error) {
console.error('Failed to load event data:', error);
throw error;
}
}
public async sendCreate(_event: ICalendarEvent): Promise<ICalendarEvent> {
throw new Error('MockEventRepository does not support sendCreate. Mock data is read-only.');
}
public async sendUpdate(_id: string, _updates: Partial<ICalendarEvent>): Promise<ICalendarEvent> {
throw new Error('MockEventRepository does not support sendUpdate. Mock data is read-only.');
}
public async sendDelete(_id: string): Promise<void> {
throw new Error('MockEventRepository does not support sendDelete. Mock data is read-only.');
}
2025-11-03 21:30:50 +01:00
private processCalendarData(data: RawEventData[]): ICalendarEvent[] {
return data.map((event): ICalendarEvent => {
// Validate customer event constraints
if (event.type === 'customer') {
if (!event.bookingId) console.warn(`Customer event ${event.id} missing bookingId`);
if (!event.resourceId) console.warn(`Customer event ${event.id} missing resourceId`);
if (!event.customerId) console.warn(`Customer event ${event.id} missing customerId`);
}
return {
id: event.id,
title: event.title,
description: event.description,
start: new Date(event.start),
end: new Date(event.end),
type: event.type as CalendarEventType,
allDay: event.allDay || false,
bookingId: event.bookingId,
resourceId: event.resourceId,
customerId: event.customerId,
recurringId: event.recurringId,
metadata: event.metadata,
syncStatus: 'synced' as const
};
});
2025-11-03 14:54:57 +01:00
}
}