38 lines
1.3 KiB
TypeScript
38 lines
1.3 KiB
TypeScript
import type { ILeagueRepository } from '../../domain/repositories/ILeagueRepository';
|
|
import type { ILeagueMembershipRepository } from '../../domain/repositories/ILeagueMembershipRepository';
|
|
import type { IAllLeaguesWithCapacityPresenter } from '../presenters/IAllLeaguesWithCapacityPresenter';
|
|
|
|
/**
|
|
* Use Case for retrieving all leagues with capacity information.
|
|
* Orchestrates domain logic and delegates presentation to the presenter.
|
|
*/
|
|
export class GetAllLeaguesWithCapacityUseCase {
|
|
constructor(
|
|
private readonly leagueRepository: ILeagueRepository,
|
|
private readonly leagueMembershipRepository: ILeagueMembershipRepository,
|
|
public readonly presenter: IAllLeaguesWithCapacityPresenter,
|
|
) {}
|
|
|
|
async execute(): Promise<void> {
|
|
const leagues = await this.leagueRepository.findAll();
|
|
|
|
const memberCounts = new Map<string, number>();
|
|
|
|
for (const league of leagues) {
|
|
const members = await this.leagueMembershipRepository.getLeagueMembers(league.id);
|
|
|
|
const usedSlots = members.filter(
|
|
(m) =>
|
|
m.status === 'active' &&
|
|
(m.role === 'owner' ||
|
|
m.role === 'admin' ||
|
|
m.role === 'steward' ||
|
|
m.role === 'member'),
|
|
).length;
|
|
|
|
memberCounts.set(league.id, usedSlots);
|
|
}
|
|
|
|
this.presenter.present(leagues, memberCounts);
|
|
}
|
|
} |