<?php namespace App\Membership; use App\Dashboard\Blocks\Block; use App\Member\Membership; use Illuminate\Database\Eloquent\Builder; class AgeGroupCountBlock extends Block { /** * @return Builder<Membership> */ public function memberQuery(): Builder { return Membership::select('subactivities.slug', 'subactivities.name') ->selectRaw('COUNT(member_id) AS count') ->join('activities', 'memberships.activity_id', 'activities.id') ->join('subactivities', 'memberships.subactivity_id', 'subactivities.id') ->isAgeGroup() ->isMember() ->active() ->groupBy('subactivities.slug', 'subactivities.name') ->orderBy('subactivity_id'); } /** * @return Builder<Membership> */ public function leaderQuery(): Builder { return Membership::selectRaw('"leiter" AS slug, "Leiter" AS name, COUNT(member_id) AS count') ->join('activities', 'memberships.activity_id', 'activities.id') ->join('subactivities', 'memberships.subactivity_id', 'subactivities.id') ->active() ->isLeader(); } protected function data(): array { return [ 'groups' => [ ...$this->memberQuery()->get()->toArray(), ...$this->leaderQuery()->get()->toArray(), ], ]; } public function component(): string { return 'age-group-count'; } public function title(): string { return 'Gruppierungs-Verteilung'; } }