Calendar/src/v2/features/date/DateRenderer.ts
Janus C. H. Knudsen a0c0ef9e8d Refactor calendar V2 core with DI and new features
Introduces dependency injection container and composition root
Adds core services like DateService and NavigationAnimator
Simplifies CalendarOrchestrator with improved store handling
Implements mock stores and demo application for V2 calendar
2025-12-07 14:31:16 +01:00

29 lines
1.1 KiB
TypeScript

import { IGroupingRenderer } from '../../core/IGroupingRenderer';
import { RenderContext } from '../../core/RenderContext';
import { DateService } from '../../core/DateService';
export class DateRenderer implements IGroupingRenderer {
readonly type = 'date';
constructor(private dateService: DateService) {}
render(context: RenderContext): void {
for (const dateStr of context.values) {
const date = this.dateService.parseISO(dateStr);
const headerCell = document.createElement('swp-day-header');
headerCell.dataset.date = dateStr;
headerCell.innerHTML = `
<swp-day-name>${this.dateService.getDayName(date, 'short')}</swp-day-name>
<swp-day-date>${date.getDate()}</swp-day-date>
`;
context.headerContainer.appendChild(headerCell);
const column = document.createElement('swp-day-column');
column.dataset.date = dateStr;
if (context.parentId) column.dataset.parentId = context.parentId;
column.innerHTML = '<swp-events-layer></swp-events-layer>';
context.columnContainer.appendChild(column);
}
}
}