Files
gridpilot.gg/apps/website/lib/view-models/TeamSummaryViewModel.ts
Marc Mintel d97f50ed72
Some checks failed
Contract Testing / contract-tests (pull_request) Failing after 6m4s
Contract Testing / contract-snapshot (pull_request) Has been skipped
view data fixes
2026-01-23 11:59:49 +01:00

72 lines
2.1 KiB
TypeScript

import type { TeamListItemDTO } from '@/lib/types/generated/TeamListItemDTO';
import { ViewModel } from "../contracts/view-models/ViewModel";
export class TeamSummaryViewModel extends ViewModel {
id: string;
name: string;
tag: string;
memberCount: number;
description?: string;
totalWins: number = 0;
totalRaces: number = 0;
performanceLevel: 'beginner' | 'intermediate' | 'advanced' | 'pro' = 'intermediate';
isRecruiting: boolean = false;
specialization: 'endurance' | 'sprint' | 'mixed' | undefined;
region: string | undefined;
languages: string[] = [];
leagues: string[] = [];
logoUrl: string | undefined;
rating: number | undefined;
category: string | undefined;
private maxMembers = 10; // Assuming max members
constructor(dto: TeamListItemDTO) {
this.id = dto.id;
this.name = dto.name;
this.tag = dto.tag;
this.memberCount = dto.memberCount;
this.description = dto.description;
this.specialization = dto.specialization as 'endurance' | 'sprint' | 'mixed' | undefined;
this.region = dto.region;
this.languages = dto.languages ?? [];
this.leagues = dto.leagues;
// Map stats fields from DTO
this.totalWins = dto.totalWins ?? 0;
this.totalRaces = dto.totalRaces ?? 0;
this.performanceLevel = (dto.performanceLevel as 'beginner' | 'intermediate' | 'advanced' | 'pro') ?? 'intermediate';
this.logoUrl = dto.logoUrl;
this.rating = dto.rating;
this.category = dto.category;
this.isRecruiting = dto.isRecruiting ?? false;
}
/** UI-specific: Whether team is full */
get isFull(): boolean {
return this.memberCount >= this.maxMembers;
}
/** UI-specific: Tag display */
get tagDisplay(): string {
return `[${this.tag}]`;
}
/** UI-specific: Member count display */
get memberCountDisplay(): string {
return `${this.memberCount}/${this.maxMembers}`;
}
/** UI-specific: Status indicator */
get statusIndicator(): string {
if (this.isFull) return 'Full';
return 'Open';
}
/** UI-specific: Status color */
get statusColor(): string {
return this.isFull ? 'red' : 'green';
}
}