mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
fix: Fix FamilyMemberController and Repository.
This commit is contained in:
parent
dfc853a876
commit
162db60f59
@ -1,38 +1,46 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
namespace Chill\AMLI\FamilyMembersBundle\Controller;
|
namespace Chill\AMLI\FamilyMembersBundle\Controller;
|
||||||
|
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
|
use Chill\AMLI\FamilyMembersBundle\Repository\FamilyMemberRepository;
|
||||||
use Chill\PersonBundle\Entity\Person;
|
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
|
use Chill\PersonBundle\Entity\Person;
|
||||||
|
use Symfony\Component\Form\FormInterface;
|
||||||
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
use Chill\AMLI\FamilyMembersBundle\Entity\FamilyMember;
|
use Chill\AMLI\FamilyMembersBundle\Entity\FamilyMember;
|
||||||
use Chill\AMLI\FamilyMembersBundle\Security\Voter\FamilyMemberVoter;
|
use Chill\AMLI\FamilyMembersBundle\Security\Voter\FamilyMemberVoter;
|
||||||
use Chill\AMLI\FamilyMembersBundle\Form\FamilyMemberType;
|
use Chill\AMLI\FamilyMembersBundle\Form\FamilyMemberType;
|
||||||
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
|
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
|
||||||
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
use Symfony\Component\Translation\TranslatorInterface;
|
use Symfony\Component\Translation\TranslatorInterface;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
use Symfony\Component\Routing\Annotation\Route;
|
use Symfony\Component\Routing\Annotation\Route;
|
||||||
|
|
||||||
class FamilyMemberController extends Controller
|
class FamilyMemberController extends AbstractController
|
||||||
{
|
{
|
||||||
protected EntityManagerInterface $em;
|
private EntityManagerInterface $em;
|
||||||
|
|
||||||
protected TranslatorInterface $translator;
|
protected TranslatorInterface $translator;
|
||||||
|
|
||||||
protected LoggerInterface $chillMainLogger;
|
protected LoggerInterface $chillMainLogger;
|
||||||
|
|
||||||
|
private FamilyMemberRepository $familyMemberRepository;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
EntityManagerInterface $em,
|
EntityManagerInterface $entityManager,
|
||||||
TranslatorInterface $translator,
|
TranslatorInterface $translator,
|
||||||
LoggerInterface $chillMainLogger
|
LoggerInterface $chillMainLogger,
|
||||||
|
FamilyMemberRepository $familyMemberRepository
|
||||||
) {
|
) {
|
||||||
$this->em = $em;
|
$this->em = $entityManager;
|
||||||
$this->translator = $translator;
|
$this->translator = $translator;
|
||||||
$this->chillMainLogger = $chillMainLogger;
|
$this->chillMainLogger = $chillMainLogger;
|
||||||
|
$this->familyMemberRepository = $familyMemberRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Route(
|
* @Route(
|
||||||
* "{_locale}/family-members/family-members/by-person/{id}",
|
* "{_locale}/family-members/family-members/by-person/{id}",
|
||||||
@ -43,14 +51,12 @@ class FamilyMemberController extends Controller
|
|||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted(FamilyMemberVoter::SHOW, $person);
|
$this->denyAccessUnlessGranted(FamilyMemberVoter::SHOW, $person);
|
||||||
|
|
||||||
$familyMembers = $this->em
|
$familyMembers = $this->familyMemberRepository->findByPerson($person);
|
||||||
->getRepository(FamilyMember::class)
|
|
||||||
->findByPerson($person);
|
|
||||||
|
|
||||||
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:index.html.twig', array(
|
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:index.html.twig', [
|
||||||
'person' => $person,
|
'person' => $person,
|
||||||
'familyMembers' => $familyMembers
|
'familyMembers' => $familyMembers
|
||||||
));
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -61,8 +67,7 @@ class FamilyMemberController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function newAction(Person $person, Request $request)
|
public function newAction(Person $person, Request $request)
|
||||||
{
|
{
|
||||||
$familyMember = (new FamilyMember())
|
$familyMember = (new FamilyMember())->setPerson($person);
|
||||||
->setPerson($person);
|
|
||||||
|
|
||||||
$this->denyAccessUnlessGranted(FamilyMemberVoter::CREATE, $familyMember);
|
$this->denyAccessUnlessGranted(FamilyMemberVoter::CREATE, $familyMember);
|
||||||
|
|
||||||
@ -71,10 +76,9 @@ class FamilyMemberController extends Controller
|
|||||||
|
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
if ($form->isSubmitted() and $form->isValid()) {
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
$em = $this->getDoctrine()->getManager();
|
$this->em->persist($familyMember);
|
||||||
$em->persist($familyMember);
|
$this->em->flush();
|
||||||
$em->flush();
|
|
||||||
|
|
||||||
$this->addFlash('success', $this->translator->trans('Family member created'));
|
$this->addFlash('success', $this->translator->trans('Family member created'));
|
||||||
|
|
||||||
@ -83,10 +87,10 @@ class FamilyMemberController extends Controller
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:new.html.twig', array(
|
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:new.html.twig', [
|
||||||
'form' => $form->createView(),
|
'form' => $form->createView(),
|
||||||
'person' => $person
|
'person' => $person
|
||||||
));
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -104,9 +108,8 @@ class FamilyMemberController extends Controller
|
|||||||
|
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
if ($form->isSubmitted() and $form->isValid()) {
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
$em = $this->getDoctrine()->getManager();
|
$this->em->flush();
|
||||||
$em->flush();
|
|
||||||
|
|
||||||
$this->addFlash('success', $this->translator->trans('Family member updated'));
|
$this->addFlash('success', $this->translator->trans('Family member updated'));
|
||||||
|
|
||||||
@ -115,11 +118,11 @@ class FamilyMemberController extends Controller
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:edit.html.twig', array(
|
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:edit.html.twig', [
|
||||||
'familyMember' => $familyMember,
|
'familyMember' => $familyMember,
|
||||||
'form' => $form->createView(),
|
'form' => $form->createView(),
|
||||||
'person' => $familyMember->getPerson()
|
'person' => $familyMember->getPerson()
|
||||||
));
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -128,47 +131,42 @@ class FamilyMemberController extends Controller
|
|||||||
* "{_locale}/family-members/family-members/{id}/delete",
|
* "{_locale}/family-members/family-members/{id}/delete",
|
||||||
* name="chill_family_members_family_members_delete"
|
* name="chill_family_members_family_members_delete"
|
||||||
* )
|
* )
|
||||||
*
|
|
||||||
* @param FamilyMember $familyMember
|
|
||||||
* @param Request $request
|
|
||||||
* @return \Symfony\Component\BrowserKit\Response
|
|
||||||
*/
|
*/
|
||||||
public function deleteAction(FamilyMember $familyMember, Request $request)
|
public function deleteAction(FamilyMember $familyMember, Request $request): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted(FamilyMemberVoter::DELETE, $familyMember, 'You are not '
|
$this->denyAccessUnlessGranted(FamilyMemberVoter::DELETE, $familyMember, 'You are not '
|
||||||
. 'allowed to delete this family membership');
|
. 'allowed to delete this family membership');
|
||||||
|
|
||||||
$form = $this->createDeleteForm($id);
|
$form = $this->createDeleteForm();
|
||||||
|
|
||||||
if ($request->getMethod() === Request::METHOD_DELETE) {
|
if ($request->getMethod() === Request::METHOD_DELETE) {
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
if ($form->isValid()) {
|
if ($form->isValid()) {
|
||||||
$this->chillMainLogger->notice("A family member has been removed", array(
|
$this->chillMainLogger->notice("A family member has been removed", [
|
||||||
'by_user' => $this->getUser()->getUsername(),
|
'by_user' => $this->getUser()->getUsername(),
|
||||||
'family_member_id' => $familyMember->getId(),
|
'family_member_id' => $familyMember->getId(),
|
||||||
'name' => $familyMember->getFirstname()." ".$familyMember->getLastname(),
|
'name' => $familyMember->getFirstname()." ".$familyMember->getLastname(),
|
||||||
'link' => $familyMember->getLink()
|
'link' => $familyMember->getLink()
|
||||||
));
|
]);
|
||||||
|
|
||||||
$em = $this->getDoctrine()->getManager();
|
$this->em->remove($familyMember);
|
||||||
$em->remove($familyMember);
|
$this->em->flush();
|
||||||
$em->flush();
|
|
||||||
|
|
||||||
$this->addFlash('success', $this->translator
|
$this->addFlash('success', $this->translator
|
||||||
->trans("The family member has been successfully removed."));
|
->trans("The family member has been successfully removed."));
|
||||||
|
|
||||||
return $this->redirectToRoute('chill_family_members_family_members_index', array(
|
return $this->redirectToRoute('chill_family_members_family_members_index', [
|
||||||
'id' => $familyMember->getPerson()->getId()
|
'id' => $familyMember->getPerson()->getId()
|
||||||
));
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:confirm_delete.html.twig', array(
|
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:confirm_delete.html.twig', [
|
||||||
'familyMember' => $familyMember,
|
'familyMember' => $familyMember,
|
||||||
'delete_form' => $form->createView()
|
'delete_form' => $form->createView()
|
||||||
));
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -181,23 +179,20 @@ class FamilyMemberController extends Controller
|
|||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted(FamilyMemberVoter::SHOW, $familyMember);
|
$this->denyAccessUnlessGranted(FamilyMemberVoter::SHOW, $familyMember);
|
||||||
|
|
||||||
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:view.html.twig', array(
|
return $this->render('ChillAMLIFamilyMembersBundle:FamilyMember:view.html.twig', [
|
||||||
'familyMember' => $familyMember
|
'familyMember' => $familyMember
|
||||||
));
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a form to delete a help request entity by id.
|
* Creates a form to delete a help request entity by id.
|
||||||
*
|
|
||||||
* @param mixed $id The entity id
|
|
||||||
*
|
|
||||||
* @return \Symfony\Component\Form\Form The form
|
|
||||||
*/
|
*/
|
||||||
private function createDeleteForm($id)
|
private function createDeleteForm(): FormInterface
|
||||||
{
|
{
|
||||||
return $this->createFormBuilder()
|
return $this
|
||||||
|
->createFormBuilder()
|
||||||
->setMethod(Request::METHOD_DELETE)
|
->setMethod(Request::METHOD_DELETE)
|
||||||
->add('submit', SubmitType::class, array('label' => 'Delete'))
|
->add('submit', SubmitType::class, ['label' => 'Delete'])
|
||||||
->getForm()
|
->getForm()
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
@ -1,17 +1,32 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
namespace Chill\AMLI\FamilyMembersBundle\Repository;
|
namespace Chill\AMLI\FamilyMembersBundle\Repository;
|
||||||
|
|
||||||
|
use Chill\AMLI\FamilyMembersBundle\Entity\FamilyMember;
|
||||||
use Chill\PersonBundle\Entity\Person;
|
use Chill\PersonBundle\Entity\Person;
|
||||||
|
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
||||||
|
use Doctrine\Persistence\ManagerRegistry;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* FamilyMemberRepository
|
* @method FamilyMember|null find($id, $lockMode = null, $lockVersion = null)
|
||||||
*
|
* @method FamilyMember|null findOneBy(array $criteria, array $orderBy = null)
|
||||||
|
* @method FamilyMember[] findAll()
|
||||||
|
* @method FamilyMember[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
|
||||||
*/
|
*/
|
||||||
class FamilyMemberRepository extends \Doctrine\ORM\EntityRepository
|
class FamilyMemberRepository extends ServiceEntityRepository
|
||||||
{
|
{
|
||||||
public function findActiveByPerson(Person $person)
|
public function __construct(ManagerRegistry $registry)
|
||||||
{
|
{
|
||||||
return $this->findBy([ 'person' => $person ]);
|
parent::__construct($registry, FamilyMember::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return FamilyMember[]
|
||||||
|
*/
|
||||||
|
public function findByPerson(Person $person): array
|
||||||
|
{
|
||||||
|
return $this->findBy(['person' => $person]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user