mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
issue641: form select2 list activated socialissues and sort by ordering
This commit is contained in:
parent
8d7b6fea71
commit
de7ba29853
@ -12,6 +12,7 @@ declare(strict_types=1);
|
|||||||
namespace Chill\PersonBundle\Form\Type;
|
namespace Chill\PersonBundle\Form\Type;
|
||||||
|
|
||||||
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
||||||
|
use Chill\PersonBundle\Repository\SocialWork\SocialIssueRepository;
|
||||||
use Chill\PersonBundle\Templating\Entity\SocialIssueRender;
|
use Chill\PersonBundle\Templating\Entity\SocialIssueRender;
|
||||||
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
|
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
|
||||||
use Symfony\Component\Form\AbstractType;
|
use Symfony\Component\Form\AbstractType;
|
||||||
@ -21,9 +22,14 @@ class Select2SocialIssueType extends AbstractType
|
|||||||
{
|
{
|
||||||
private SocialIssueRender $issueRender;
|
private SocialIssueRender $issueRender;
|
||||||
|
|
||||||
public function __construct(SocialIssueRender $issueRender)
|
private SocialIssueRepository $issueRepository;
|
||||||
{
|
|
||||||
|
public function __construct(
|
||||||
|
SocialIssueRender $issueRender,
|
||||||
|
SocialIssueRepository $issueRepository
|
||||||
|
) {
|
||||||
$this->issueRender = $issueRender;
|
$this->issueRender = $issueRender;
|
||||||
|
$this->issueRepository = $issueRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function configureOptions(OptionsResolver $resolver)
|
public function configureOptions(OptionsResolver $resolver)
|
||||||
@ -31,6 +37,7 @@ class Select2SocialIssueType extends AbstractType
|
|||||||
$resolver
|
$resolver
|
||||||
->setDefaults([
|
->setDefaults([
|
||||||
'class' => SocialIssue::class,
|
'class' => SocialIssue::class,
|
||||||
|
'choices' => $this->issueRepository->findIssuesNotDesactivated(),
|
||||||
'choice_label' => function (SocialIssue $si) {
|
'choice_label' => function (SocialIssue $si) {
|
||||||
return $this->issueRender->renderString($si, []);
|
return $this->issueRender->renderString($si, []);
|
||||||
},
|
},
|
||||||
|
@ -14,6 +14,7 @@ namespace Chill\PersonBundle\Repository\SocialWork;
|
|||||||
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
use Doctrine\ORM\EntityRepository;
|
use Doctrine\ORM\EntityRepository;
|
||||||
|
use Doctrine\ORM\QueryBuilder;
|
||||||
use Doctrine\Persistence\ObjectRepository;
|
use Doctrine\Persistence\ObjectRepository;
|
||||||
|
|
||||||
final class SocialIssueRepository implements ObjectRepository
|
final class SocialIssueRepository implements ObjectRepository
|
||||||
@ -61,4 +62,21 @@ final class SocialIssueRepository implements ObjectRepository
|
|||||||
{
|
{
|
||||||
return SocialIssue::class;
|
return SocialIssue::class;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function findIssuesNotDesactivated(): array
|
||||||
|
{
|
||||||
|
return $this->buildQueryWithDesactivatedDateCriteria()->getQuery()->getResult();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function buildQueryWithDesactivatedDateCriteria(): QueryBuilder
|
||||||
|
{
|
||||||
|
$qb = $this->repository->createQueryBuilder('si');
|
||||||
|
|
||||||
|
$qb ->where('si.desactivationDate is null')
|
||||||
|
->orWhere('si.desactivationDate > :now')
|
||||||
|
->orderBy('si.ordering', 'ASC')
|
||||||
|
->setParameter('now', new \DateTime('now'));
|
||||||
|
|
||||||
|
return $qb;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user