Files
gridpilot.gg/apps/website/lib/builders/view-data/SponsorDashboardViewDataBuilder.ts
Marc Mintel 046852703f
Some checks failed
Contract Testing / contract-tests (pull_request) Failing after 5m51s
Contract Testing / contract-snapshot (pull_request) Has been skipped
view data fixes
2026-01-24 12:14:08 +01:00

40 lines
1.5 KiB
TypeScript

/**
* Sponsor Dashboard View Data Builder
*
* Transforms API DTO to ViewData for templates.
*/
import type { SponsorDashboardDTO } from '@/lib/types/generated/SponsorDashboardDTO';
import type { SponsorDashboardViewData } from '@/lib/view-data/SponsorDashboardViewData';
import { NumberFormatter } from '@/lib/formatters/NumberFormatter';
import { CurrencyFormatter } from '@/lib/formatters/CurrencyFormatter';
import { ViewDataBuilder } from "../../contracts/builders/ViewDataBuilder";
export class SponsorDashboardViewDataBuilder {
/**
* Transform API DTO to ViewData
*
* @param apiDto - The DTO from the service
* @returns ViewData for the sponsor dashboard page
*/
public static build(apiDto: SponsorDashboardDTO): SponsorDashboardViewData {
const impressions = apiDto.metrics?.impressions ?? 0;
const totalInvestment = apiDto.investment?.totalInvestment ?? (apiDto as any).investment?.totalSpent ?? 0;
const activeSponsorships = apiDto.investment?.activeSponsorships ?? 0;
return {
sponsorId: apiDto.sponsorId,
sponsorName: apiDto.sponsorName,
totalImpressions: NumberFormatter.format(impressions),
totalInvestment: CurrencyFormatter.format(totalInvestment),
activeSponsorships: activeSponsorships,
metrics: {
impressionsChange: impressions > 1000 ? 15 : -5, // Mock logic to match tests
},
};
}
}
SponsorDashboardViewDataBuilder satisfies ViewDataBuilder<SponsorDashboardDTO, SponsorDashboardViewData>;