Refactor UserMenuBuilder to include User type check for better type safety

This commit is contained in:
2025-12-05 14:50:06 +00:00
parent 16c32ed4a9
commit 2f1445a3f3

View File

@@ -12,40 +12,45 @@ declare(strict_types=1);
namespace Chill\CalendarBundle\Menu;
use Chill\CalendarBundle\Repository\InviteRepository;
use Chill\MainBundle\Entity\User;
use Chill\MainBundle\Routing\LocalMenuBuilderInterface;
use Chill\MainBundle\Security\ChillSecurity;
use Knp\Menu\MenuItem;
use Symfony\Component\Security\Core\Security;
use Symfony\Contracts\Translation\TranslatorInterface;
final readonly class UserMenuBuilder implements LocalMenuBuilderInterface
{
public function __construct(
private ChillSecurity $security,
private Security $security,
private TranslatorInterface $translator,
private InviteRepository $inviteRepository,
) {}
public function buildMenu($menuId, MenuItem $menu, array $parameters): void
{
$invitationsPending = $this->inviteRepository->countPendingInvitesByUser($this->security->getUser());
$user = $this->security->getUser();
if ($this->security->isGranted('ROLE_USER')) {
$menu->addChild('My calendar list', [
'route' => 'chill_calendar_calendar_list_my',
])
->setExtras([
'order' => 8,
'icon' => 'tasks',
]);
$menu->addChild(
$this->translator->trans('invite.menu with counter', ['nb' => $invitationsPending]),
['route' => 'chill_calendar_invitations_list_my']
)
->setExtras([
'order' => 9,
'icon' => 'tasks',
'counter' => 0 < $invitationsPending ? $invitationsPending : null,
]);
if ($user instanceof User) {
$invitationsPending = $this->inviteRepository->countPendingInvitesByUser($user);
if ($this->security->isGranted('ROLE_USER')) {
$menu->addChild('My calendar list', [
'route' => 'chill_calendar_calendar_list_my',
])
->setExtras([
'order' => 8,
'icon' => 'tasks',
]);
$menu->addChild(
$this->translator->trans('invite.menu with counter', ['nb' => $invitationsPending]),
['route' => 'chill_calendar_invitations_list_my']
)
->setExtras([
'order' => 9,
'icon' => 'tasks',
'counter' => 0 < $invitationsPending ? $invitationsPending : null,
]);
}
}
}