website refactor
This commit is contained in:
41
apps/website/lib/page-queries/races/RaceDetailPageQuery.ts
Normal file
41
apps/website/lib/page-queries/races/RaceDetailPageQuery.ts
Normal file
@@ -0,0 +1,41 @@
|
||||
import { Result } from '@/lib/contracts/Result';
|
||||
import { PageQuery } from '@/lib/contracts/page-queries/PageQuery';
|
||||
import { PresentationError, mapToPresentationError } from '@/lib/contracts/page-queries/PresentationError';
|
||||
import { RaceDetailViewData } from '@/lib/view-data/races/RaceDetailViewData';
|
||||
import { RacesService } from '@/lib/services/races/RacesService';
|
||||
import { RaceDetailViewDataBuilder } from '@/lib/builders/view-data/RaceDetailViewDataBuilder';
|
||||
|
||||
interface RaceDetailPageQueryParams {
|
||||
raceId: string;
|
||||
driverId?: string;
|
||||
}
|
||||
|
||||
/**
|
||||
* Race Detail Page Query
|
||||
*
|
||||
* Fetches race detail data for the race detail page.
|
||||
* Returns Result<RaceDetailViewData, PresentationError>
|
||||
*/
|
||||
export class RaceDetailPageQuery implements PageQuery<RaceDetailViewData, RaceDetailPageQueryParams> {
|
||||
async execute(params: RaceDetailPageQueryParams): Promise<Result<RaceDetailViewData, PresentationError>> {
|
||||
// Manual wiring: Service creates its own dependencies
|
||||
const service = new RacesService();
|
||||
|
||||
// Get race detail data
|
||||
const result = await service.getRaceDetail(params.raceId, params.driverId || '');
|
||||
|
||||
if (result.isErr()) {
|
||||
return Result.err(mapToPresentationError(result.getError()));
|
||||
}
|
||||
|
||||
// Transform to ViewData using builder
|
||||
const viewData = RaceDetailViewDataBuilder.build(result.unwrap());
|
||||
return Result.ok(viewData);
|
||||
}
|
||||
|
||||
// Static method to avoid object construction in server code
|
||||
static async execute(params: RaceDetailPageQueryParams): Promise<Result<RaceDetailViewData, PresentationError>> {
|
||||
const query = new RaceDetailPageQuery();
|
||||
return await query.execute(params);
|
||||
}
|
||||
}
|
||||
41
apps/website/lib/page-queries/races/RaceResultsPageQuery.ts
Normal file
41
apps/website/lib/page-queries/races/RaceResultsPageQuery.ts
Normal file
@@ -0,0 +1,41 @@
|
||||
import { Result } from '@/lib/contracts/Result';
|
||||
import { PageQuery } from '@/lib/contracts/page-queries/PageQuery';
|
||||
import { PresentationError, mapToPresentationError } from '@/lib/contracts/page-queries/PresentationError';
|
||||
import { RaceResultsViewData } from '@/lib/view-data/races/RaceResultsViewData';
|
||||
import { RaceResultsService } from '@/lib/services/races/RaceResultsService';
|
||||
import { RaceResultsViewDataBuilder } from '@/lib/builders/view-data/RaceResultsViewDataBuilder';
|
||||
|
||||
interface RaceResultsPageQueryParams {
|
||||
raceId: string;
|
||||
driverId?: string;
|
||||
}
|
||||
|
||||
/**
|
||||
* Race Results Page Query
|
||||
*
|
||||
* Fetches race results data for the race results page.
|
||||
* Returns Result<RaceResultsViewData, PresentationError>
|
||||
*/
|
||||
export class RaceResultsPageQuery implements PageQuery<RaceResultsViewData, RaceResultsPageQueryParams> {
|
||||
async execute(params: RaceResultsPageQueryParams): Promise<Result<RaceResultsViewData, PresentationError>> {
|
||||
// Manual wiring: Service creates its own dependencies
|
||||
const service = new RaceResultsService();
|
||||
|
||||
// Get race results data
|
||||
const result = await service.getRaceResultsDetail(params.raceId);
|
||||
|
||||
if (result.isErr()) {
|
||||
return Result.err(mapToPresentationError(result.getError()));
|
||||
}
|
||||
|
||||
// Transform to ViewData using builder
|
||||
const viewData = RaceResultsViewDataBuilder.build(result.unwrap());
|
||||
return Result.ok(viewData);
|
||||
}
|
||||
|
||||
// Static method to avoid object construction in server code
|
||||
static async execute(params: RaceResultsPageQueryParams): Promise<Result<RaceResultsViewData, PresentationError>> {
|
||||
const query = new RaceResultsPageQuery();
|
||||
return await query.execute(params);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,41 @@
|
||||
import { Result } from '@/lib/contracts/Result';
|
||||
import { PageQuery } from '@/lib/contracts/page-queries/PageQuery';
|
||||
import { PresentationError, mapToPresentationError } from '@/lib/contracts/page-queries/PresentationError';
|
||||
import { RaceStewardingViewData } from '@/lib/view-data/races/RaceStewardingViewData';
|
||||
import { RaceStewardingService } from '@/lib/services/races/RaceStewardingService';
|
||||
import { RaceStewardingViewDataBuilder } from '@/lib/builders/view-data/RaceStewardingViewDataBuilder';
|
||||
|
||||
interface RaceStewardingPageQueryParams {
|
||||
raceId: string;
|
||||
driverId?: string;
|
||||
}
|
||||
|
||||
/**
|
||||
* Race Stewarding Page Query
|
||||
*
|
||||
* Fetches race stewarding data for the stewarding page.
|
||||
* Returns Result<RaceStewardingViewData, PresentationError>
|
||||
*/
|
||||
export class RaceStewardingPageQuery implements PageQuery<RaceStewardingViewData, RaceStewardingPageQueryParams> {
|
||||
async execute(params: RaceStewardingPageQueryParams): Promise<Result<RaceStewardingViewData, PresentationError>> {
|
||||
// Manual wiring: Service creates its own dependencies
|
||||
const service = new RaceStewardingService();
|
||||
|
||||
// Get race stewarding data
|
||||
const result = await service.getRaceStewarding(params.raceId);
|
||||
|
||||
if (result.isErr()) {
|
||||
return Result.err(mapToPresentationError(result.getError()));
|
||||
}
|
||||
|
||||
// Transform to ViewData using builder
|
||||
const viewData = RaceStewardingViewDataBuilder.build(result.unwrap());
|
||||
return Result.ok(viewData);
|
||||
}
|
||||
|
||||
// Static method to avoid object construction in server code
|
||||
static async execute(params: RaceStewardingPageQueryParams): Promise<Result<RaceStewardingViewData, PresentationError>> {
|
||||
const query = new RaceStewardingPageQuery();
|
||||
return await query.execute(params);
|
||||
}
|
||||
}
|
||||
36
apps/website/lib/page-queries/races/RacesAllPageQuery.ts
Normal file
36
apps/website/lib/page-queries/races/RacesAllPageQuery.ts
Normal file
@@ -0,0 +1,36 @@
|
||||
import { Result } from '@/lib/contracts/Result';
|
||||
import { PageQuery } from '@/lib/contracts/page-queries/PageQuery';
|
||||
import { PresentationError, mapToPresentationError } from '@/lib/contracts/page-queries/PresentationError';
|
||||
import { RacesAllViewData } from '@/lib/view-data/races/RacesAllViewData';
|
||||
import { RacesService } from '@/lib/services/races/RacesService';
|
||||
import { RacesAllViewDataBuilder } from '@/lib/builders/view-data/RacesAllViewDataBuilder';
|
||||
|
||||
/**
|
||||
* Races All Page Query
|
||||
*
|
||||
* Fetches all races data for the all races page.
|
||||
* Returns Result<RacesAllViewData, PresentationError>
|
||||
*/
|
||||
export class RacesAllPageQuery implements PageQuery<RacesAllViewData, void> {
|
||||
async execute(): Promise<Result<RacesAllViewData, PresentationError>> {
|
||||
// Manual wiring: Service creates its own dependencies
|
||||
const service = new RacesService();
|
||||
|
||||
// Get all races data
|
||||
const result = await service.getAllRacesPageData();
|
||||
|
||||
if (result.isErr()) {
|
||||
return Result.err(mapToPresentationError(result.getError()));
|
||||
}
|
||||
|
||||
// Transform to ViewData using builder
|
||||
const viewData = RacesAllViewDataBuilder.build(result.unwrap());
|
||||
return Result.ok(viewData);
|
||||
}
|
||||
|
||||
// Static method to avoid object construction in server code
|
||||
static async execute(): Promise<Result<RacesAllViewData, PresentationError>> {
|
||||
const query = new RacesAllPageQuery();
|
||||
return await query.execute();
|
||||
}
|
||||
}
|
||||
36
apps/website/lib/page-queries/races/RacesPageQuery.ts
Normal file
36
apps/website/lib/page-queries/races/RacesPageQuery.ts
Normal file
@@ -0,0 +1,36 @@
|
||||
import { Result } from '@/lib/contracts/Result';
|
||||
import { PageQuery } from '@/lib/contracts/page-queries/PageQuery';
|
||||
import { PresentationError, mapToPresentationError } from '@/lib/contracts/page-queries/PresentationError';
|
||||
import { RacesViewData } from '@/lib/view-data/races/RacesViewData';
|
||||
import { RacesService } from '@/lib/services/races/RacesService';
|
||||
import { RacesViewDataBuilder } from '@/lib/builders/view-data/RacesViewDataBuilder';
|
||||
|
||||
/**
|
||||
* Races Page Query
|
||||
*
|
||||
* Fetches races data for the main races page.
|
||||
* Returns Result<RacesViewData, PresentationError>
|
||||
*/
|
||||
export class RacesPageQuery implements PageQuery<RacesViewData, void> {
|
||||
async execute(): Promise<Result<RacesViewData, PresentationError>> {
|
||||
// Manual wiring: Service creates its own dependencies
|
||||
const service = new RacesService();
|
||||
|
||||
// Get races data
|
||||
const result = await service.getRacesPageData();
|
||||
|
||||
if (result.isErr()) {
|
||||
return Result.err(mapToPresentationError(result.getError()));
|
||||
}
|
||||
|
||||
// Transform to ViewData using builder
|
||||
const viewData = RacesViewDataBuilder.build(result.unwrap());
|
||||
return Result.ok(viewData);
|
||||
}
|
||||
|
||||
// Static method to avoid object construction in server code
|
||||
static async execute(): Promise<Result<RacesViewData, PresentationError>> {
|
||||
const query = new RacesPageQuery();
|
||||
return await query.execute();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user