website refactor

This commit is contained in:
2026-01-17 16:23:51 +01:00
parent 72a626ce71
commit 846667c3d1
27 changed files with 140 additions and 154 deletions

View File

@@ -1,3 +1,4 @@
import { injectable, unmanaged } from 'inversify';
import { RacesApiClient } from '@/lib/api/races/RacesApiClient';
import { Result } from '@/lib/contracts/Result';
import { DomainError, Service } from '@/lib/contracts/services/Service';
@@ -15,10 +16,11 @@ import { ImportRaceResultsSummaryViewModel } from '@/lib/view-models/ImportRaceR
* Orchestration service for race results operations.
* Returns raw API DTOs. No ViewModels or UX logic.
*/
@injectable()
export class RaceResultsService implements Service {
private apiClient: RacesApiClient;
constructor(apiClient?: RacesApiClient) {
constructor(@unmanaged() apiClient?: RacesApiClient) {
if (apiClient) {
this.apiClient = apiClient;
} else {

View File

@@ -1,3 +1,4 @@
import { injectable } from 'inversify';
import { RacesApiClient } from '@/lib/api/races/RacesApiClient';
import { Result } from '@/lib/contracts/Result';
import { DomainError, Service } from '@/lib/contracts/services/Service';
@@ -12,6 +13,7 @@ import { ApiError } from '@/lib/api/base/ApiError';
* Returns raw API DTOs. No ViewModels or UX logic.
* All client-side presentation logic must be handled by hooks/components.
*/
@injectable()
export class RaceService implements Service {
private apiClient: RacesApiClient;

View File

@@ -1,3 +1,4 @@
import { injectable, unmanaged } from 'inversify';
import { RacesApiClient } from '@/lib/api/races/RacesApiClient';
import { ProtestsApiClient } from '@/lib/api/protests/ProtestsApiClient';
import { PenaltiesApiClient } from '@/lib/api/penalties/PenaltiesApiClient';
@@ -15,12 +16,17 @@ import { RaceStewardingViewModel } from '@/lib/view-models/RaceStewardingViewMod
* Orchestration service for race stewarding operations.
* Returns raw API DTOs. No ViewModels or UX logic.
*/
@injectable()
export class RaceStewardingService implements Service {
private racesApiClient: RacesApiClient;
private protestsApiClient: ProtestsApiClient;
private penaltiesApiClient: PenaltiesApiClient;
constructor(racesApiClient?: RacesApiClient, protestsApiClient?: ProtestsApiClient, penaltiesApiClient?: PenaltiesApiClient) {
constructor(
@unmanaged() racesApiClient?: RacesApiClient,
@unmanaged() protestsApiClient?: ProtestsApiClient,
@unmanaged() penaltiesApiClient?: PenaltiesApiClient
) {
if (racesApiClient && protestsApiClient && penaltiesApiClient) {
this.racesApiClient = racesApiClient;
this.protestsApiClient = protestsApiClient;