81 lines
3.2 KiB
TypeScript
81 lines
3.2 KiB
TypeScript
import { TeamsApiClient } from '@/lib/api/teams/TeamsApiClient';
|
|
import type { TeamListItemDTO } from '@/lib/types/generated/TeamListItemDTO';
|
|
import { TeamMemberViewModel } from '@/lib/view-models/TeamMemberViewModel';
|
|
import { Result } from '@/lib/contracts/Result';
|
|
import { DomainError, Service } from '@/lib/contracts/services/Service';
|
|
import { ConsoleLogger } from '@/lib/infrastructure/logging/ConsoleLogger';
|
|
import { EnhancedErrorReporter } from '@/lib/infrastructure/EnhancedErrorReporter';
|
|
import { getWebsiteApiBaseUrl } from '@/lib/config/apiBaseUrl';
|
|
import { isProductionEnvironment } from '@/lib/config/env';
|
|
|
|
/**
|
|
* Team Service - DTO Only
|
|
*
|
|
* Returns raw API DTOs. No ViewModels or UX logic.
|
|
* All client-side presentation logic must be handled by hooks/components.
|
|
*/
|
|
export class TeamService implements Service {
|
|
private apiClient: TeamsApiClient;
|
|
|
|
constructor() {
|
|
const baseUrl = getWebsiteApiBaseUrl();
|
|
const logger = new ConsoleLogger();
|
|
const errorReporter = new EnhancedErrorReporter(logger, {
|
|
showUserNotifications: true,
|
|
logToConsole: true,
|
|
reportToExternal: isProductionEnvironment(),
|
|
});
|
|
this.apiClient = new TeamsApiClient(baseUrl, errorReporter, logger);
|
|
}
|
|
|
|
async getAllTeams(): Promise<Result<TeamListItemDTO[], DomainError>> {
|
|
try {
|
|
const result = await this.apiClient.getAll();
|
|
return Result.ok(result.teams);
|
|
} catch (error: unknown) {
|
|
return Result.err({ type: 'unknown', message: (error as Error).message || 'Failed to fetch teams' });
|
|
}
|
|
}
|
|
|
|
async getTeamDetails(teamId: string, _: string): Promise<Result<unknown, DomainError>> {
|
|
try {
|
|
const result = await this.apiClient.getDetails(teamId);
|
|
if (!result) {
|
|
return Result.err({ type: 'notFound', message: 'Team not found' });
|
|
}
|
|
return Result.ok(result);
|
|
} catch (error: unknown) {
|
|
return Result.err({ type: 'unknown', message: (error as Error).message || 'Failed to fetch team details' });
|
|
}
|
|
}
|
|
|
|
async getTeamMembers(teamId: string, currentDriverId: string, ownerId: string): Promise<Result<TeamMemberViewModel[], DomainError>> {
|
|
try {
|
|
const result = await this.apiClient.getMembers(teamId);
|
|
return Result.ok(result.members.map(member => new TeamMemberViewModel(member, currentDriverId, ownerId)));
|
|
} catch (error: unknown) {
|
|
return Result.err({ type: 'unknown', message: (error as Error).message || 'Failed to fetch team members' });
|
|
}
|
|
}
|
|
|
|
async getTeamJoinRequests(_: string): Promise<Result<unknown, DomainError>> {
|
|
return Result.err({ type: 'notImplemented', message: 'getTeamJoinRequests' });
|
|
}
|
|
|
|
async createTeam(__: unknown): Promise<Result<unknown, DomainError>> {
|
|
return Result.err({ type: 'notImplemented', message: 'createTeam' });
|
|
}
|
|
|
|
async updateTeam(_: string, __: unknown): Promise<Result<unknown, DomainError>> {
|
|
return Result.err({ type: 'notImplemented', message: 'updateTeam' });
|
|
}
|
|
|
|
async getDriverTeam(_: string): Promise<Result<unknown, DomainError>> {
|
|
return Result.err({ type: 'notImplemented', message: 'getDriverTeam' });
|
|
}
|
|
|
|
async getMembership(_: string, __: string): Promise<Result<unknown, DomainError>> {
|
|
return Result.err({ type: 'notImplemented', message: 'getMembership' });
|
|
}
|
|
}
|