import { EventBus } from '../core/EventBus'; import { IEventBus, CalendarEvent, ResourceCalendarData } from '../types/CalendarTypes'; import { EventTypes } from '../constants/EventTypes'; import { StateEvents } from '../types/CalendarState'; import { calendarConfig } from '../core/CalendarConfig'; /** * EventManager - Administrerer event lifecycle og CRUD operationer * Håndterer mock data og event synchronization */ export class EventManager { private eventBus: IEventBus; private events: CalendarEvent[] = []; constructor(eventBus: IEventBus) { console.log('EventManager: Constructor called'); this.eventBus = eventBus; this.setupEventListeners(); console.log('EventManager: Waiting for CALENDAR_INITIALIZED before loading data'); } private setupEventListeners(): void { // Keep only UI-related event listeners here if needed // Data loading is now handled via direct method calls } /** * Public method to load data - called directly by CalendarManager */ public async loadData(): Promise { console.log('EventManager: Loading data via direct call'); await this.loadMockData(); console.log(`EventManager: Data loaded successfully - ${this.events.length} events`); // Debug: Log first few events if (this.events.length > 0) { console.log('EventManager: First event:', { title: this.events[0].title, start: this.events[0].start, end: this.events[0].end }); } } private async loadMockData(): Promise { try { const calendarType = calendarConfig.getCalendarMode(); let jsonFile: string; console.log(`EventManager: Calendar type detected: '${calendarType}'`); if (calendarType === 'resource') { jsonFile = '/src/data/mock-resource-events.json'; } else { jsonFile = '/src/data/mock-events.json'; } console.log(`EventManager: Loading ${calendarType} calendar data from ${jsonFile}`); const response = await fetch(jsonFile); if (!response.ok) { throw new Error(`Failed to load mock events: ${response.status}`); } const data = await response.json(); console.log(`EventManager: Loaded data for ${calendarType} calendar`); // Store raw data for GridManager this.rawData = data; // Process data for internal use this.processCalendarData(calendarType, data); } catch (error) { console.error('EventManager: Failed to load mock events:', error); this.events = []; // Fallback to empty array } } private processCalendarData(calendarType: string, data: any): void { if (calendarType === 'resource') { const resourceData = data as ResourceCalendarData; this.events = resourceData.resources.flatMap(resource => resource.events.map(event => ({ ...event, resourceName: resource.name, resourceDisplayName: resource.displayName, resourceEmployeeId: resource.employeeId })) ); console.log(`EventManager: Processed ${this.events.length} events from ${resourceData.resources.length} resources`); } else { this.events = data as CalendarEvent[]; console.log(`EventManager: Processed ${this.events.length} date events`); } } private syncEvents(): void { // Events are now synced via StateEvents.DATA_LOADED during initialization // This method maintained for internal state management only console.log(`EventManager: Internal sync - ${this.events.length} events in memory`); } public getEvents(): CalendarEvent[] { return [...this.events]; } /** * Get raw resource data for resource calendar mode */ public getResourceData(): any { return this.rawData; } private rawData: any = null; public getEventById(id: string): CalendarEvent | undefined { return this.events.find(event => event.id === id); } public addEvent(event: Omit): CalendarEvent { const newEvent: CalendarEvent = { ...event, id: Date.now().toString() }; this.events.push(newEvent); this.syncEvents(); this.eventBus.emit(EventTypes.EVENT_CREATED, { event: newEvent }); return newEvent; } public updateEvent(id: string, updates: Partial): CalendarEvent | null { const eventIndex = this.events.findIndex(event => event.id === id); if (eventIndex === -1) return null; const updatedEvent = { ...this.events[eventIndex], ...updates }; this.events[eventIndex] = updatedEvent; this.syncEvents(); this.eventBus.emit(EventTypes.EVENT_UPDATED, { event: updatedEvent }); return updatedEvent; } public deleteEvent(id: string): boolean { const eventIndex = this.events.findIndex(event => event.id === id); if (eventIndex === -1) return false; const deletedEvent = this.events[eventIndex]; this.events.splice(eventIndex, 1); this.syncEvents(); this.eventBus.emit(EventTypes.EVENT_DELETED, { event: deletedEvent }); return true; } public refresh(): void { this.syncEvents(); } public destroy(): void { this.events = []; } }