website refactor
This commit is contained in:
@@ -2,7 +2,7 @@ import { RacesApiClient } from '@/lib/api/races/RacesApiClient';
|
||||
import { ProtestsApiClient } from '@/lib/api/protests/ProtestsApiClient';
|
||||
import { PenaltiesApiClient } from '@/lib/api/penalties/PenaltiesApiClient';
|
||||
import { Result } from '@/lib/contracts/Result';
|
||||
import { DomainError } from '@/lib/contracts/services/Service';
|
||||
import { DomainError, Service } from '@/lib/contracts/services/Service';
|
||||
import { ConsoleLogger } from '@/lib/infrastructure/logging/ConsoleLogger';
|
||||
import { ConsoleErrorReporter } from '@/lib/infrastructure/logging/ConsoleErrorReporter';
|
||||
import { getWebsiteApiBaseUrl } from '@/lib/config/apiBaseUrl';
|
||||
@@ -14,7 +14,7 @@ import { ApiError } from '@/lib/api/base/ApiError';
|
||||
* Orchestration service for race stewarding operations.
|
||||
* Returns raw API DTOs. No ViewModels or UX logic.
|
||||
*/
|
||||
export class RaceStewardingService {
|
||||
export class RaceStewardingService implements Service {
|
||||
private racesApiClient: RacesApiClient;
|
||||
private protestsApiClient: ProtestsApiClient;
|
||||
private penaltiesApiClient: PenaltiesApiClient;
|
||||
@@ -34,7 +34,7 @@ export class RaceStewardingService {
|
||||
* Get race stewarding data
|
||||
* Returns protests and penalties for a race
|
||||
*/
|
||||
async getRaceStewarding(raceId: string): Promise<Result<any, DomainError>> {
|
||||
async getRaceStewarding(raceId: string): Promise<Result<unknown, DomainError>> {
|
||||
try {
|
||||
// Fetch data in parallel
|
||||
const [raceDetail, protests, penalties] = await Promise.all([
|
||||
@@ -44,6 +44,7 @@ export class RaceStewardingService {
|
||||
]);
|
||||
|
||||
// Transform data to match view model structure
|
||||
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||
const protestsData = protests.protests.map((p: any) => ({
|
||||
id: p.id,
|
||||
protestingDriverId: p.protestingDriverId,
|
||||
@@ -56,7 +57,9 @@ export class RaceStewardingService {
|
||||
status: p.status,
|
||||
}));
|
||||
|
||||
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||
const pendingProtests = protestsData.filter((p: any) => p.status === 'pending' || p.status === 'under_review');
|
||||
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||
const resolvedProtests = protestsData.filter((p: any) =>
|
||||
p.status === 'upheld' ||
|
||||
p.status === 'dismissed' ||
|
||||
@@ -77,7 +80,7 @@ export class RaceStewardingService {
|
||||
};
|
||||
|
||||
return Result.ok(data);
|
||||
} catch (error) {
|
||||
} catch (error: unknown) {
|
||||
if (error instanceof ApiError) {
|
||||
return Result.err({
|
||||
type: this.mapApiErrorType(error.type),
|
||||
@@ -86,7 +89,7 @@ export class RaceStewardingService {
|
||||
}
|
||||
return Result.err({
|
||||
type: 'unknown',
|
||||
message: 'Failed to fetch stewarding data'
|
||||
message: (error as Error).message || 'Failed to fetch stewarding data'
|
||||
});
|
||||
}
|
||||
}
|
||||
@@ -107,4 +110,4 @@ export class RaceStewardingService {
|
||||
return 'unknown';
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user