Files
gridpilot.gg/apps/website/app/sponsor/leagues/page.tsx
2026-01-14 10:51:05 +01:00

46 lines
1.8 KiB
TypeScript

import { PageWrapper } from '@/components/shared/state/PageWrapper';
import { SponsorLeaguesTemplate } from '@/templates/SponsorLeaguesTemplate';
import { SponsorsApiClient } from '@/lib/api/sponsors/SponsorsApiClient';
import { EnhancedErrorReporter } from '@/lib/infrastructure/EnhancedErrorReporter';
import { ConsoleLogger } from '@/lib/infrastructure/logging/ConsoleLogger';
import { getWebsiteApiBaseUrl } from '@/lib/config/apiBaseUrl';
export default async function Page() {
// Manual wiring: create dependencies
const baseUrl = getWebsiteApiBaseUrl();
const logger = new ConsoleLogger();
const errorReporter = new EnhancedErrorReporter(logger, {
showUserNotifications: true,
logToConsole: true,
reportToExternal: process.env.NODE_ENV === 'production',
});
// Create API client
const apiClient = new SponsorsApiClient(baseUrl, errorReporter, logger);
// Fetch data
const leaguesData = await apiClient.getAvailableLeagues();
// Process data - move business logic to template
if (!leaguesData) {
return <PageWrapper data={undefined} Template={SponsorLeaguesTemplate} />;
}
// Calculate summary stats (business logic moved from view model)
const stats = {
total: leaguesData.length,
mainAvailable: leaguesData.filter((l: any) => l.mainSponsorSlot.available).length,
secondaryAvailable: leaguesData.reduce((sum: number, l: any) => sum + l.secondarySlots.available, 0),
totalDrivers: leaguesData.reduce((sum: number, l: any) => sum + l.drivers, 0),
avgCpm: Math.round(
leaguesData.reduce((sum: number, l: any) => sum + l.cpm, 0) / leaguesData.length
),
};
const processedData = {
leagues: leaguesData,
stats,
};
return <PageWrapper data={processedData} Template={SponsorLeaguesTemplate} />;
}