add project/conference filters

This commit is contained in:
Simon Vieille 2022-04-18 16:19:12 +02:00
parent f8db332058
commit 6763eedb39
Signed by: deblan
GPG key ID: 579388D585F70417
6 changed files with 135 additions and 4 deletions

View file

@ -10,6 +10,7 @@ use App\Core\Manager\EntityManager;
use App\Entity\Conference as Entity;
use App\Factory\ConferenceFactory as Factory;
use App\Form\ConferenceType as Type;
use App\Form\ConferenceFilterType as FilterType;
use App\Repository\ConferenceRepositoryQuery as RepositoryQuery;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
@ -101,7 +102,7 @@ class ConferenceAdminController extends CrudController
->setForm('edit', Type::class, [])
->setForm('new', Type::class)
// ->setForm('filter', Type::class)
->setForm('filter', FilterType::class)
->setView('form', 'admin/conference/_form.html.twig')
@ -125,6 +126,11 @@ class ConferenceAdminController extends CrudController
->setField('index', 'Label', Field\TextField::class, [
'property' => 'label',
])
->setField('index', 'Theme type', Field\TextField::class, [
'property' => 'themeType',
'sort' => ['date', '.date'],
'attr' => ['class' => 'col-3'],
])
->setField('index', 'Date', Field\DateField::class, [
'property' => 'date',
'format' => 'd/m/Y',

View file

@ -10,6 +10,7 @@ use App\Core\Manager\EntityManager;
use App\Entity\Project as Entity;
use App\Factory\ProjectFactory as Factory;
use App\Form\ProjectType as Type;
use App\Form\ProjectFilterType as FilterType;
use App\Repository\ProjectRepositoryQuery as RepositoryQuery;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
@ -101,7 +102,7 @@ class ProjectAdminController extends CrudController
->setForm('edit', Type::class, [])
->setForm('new', Type::class)
// ->setForm('filter', Type::class)
->setForm('filter', FilterType::class)
// ->setMaxPerPage('index', 20)

View file

@ -0,0 +1,39 @@
<?php
namespace App\Form;
use App\Entity\ThemeType;
use Doctrine\ORM\EntityRepository;
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
class ConferenceFilterType extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options): void
{
$builder
->add('label', null, [
'required' => false,
])
->add('themeType', EntityType::class, [
'required' => false,
'class' => ThemeType::class,
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('t')
->addOrderBy('t.label', 'ASC')
;
},
])
;
}
public function configureOptions(OptionsResolver $resolver): void
{
$resolver->setDefaults([
'data_class' => null,
'csrf_protection' => false,
]);
}
}

View file

@ -0,0 +1,39 @@
<?php
namespace App\Form;
use App\Entity\Establishment;
use Doctrine\ORM\EntityRepository;
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
class ProjectFilterType extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options): void
{
$builder
->add('label', null, [
'required' => false,
])
->add('establishment', EntityType::class, [
'required' => false,
'class' => Establishment::class,
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('e')
->addOrderBy('e.name', 'ASC')
;
},
])
;
}
public function configureOptions(OptionsResolver $resolver): void
{
$resolver->setDefaults([
'data_class' => null,
'csrf_protection' => false,
]);
}
}

View file

@ -3,8 +3,9 @@
namespace App\Repository;
use App\Core\Repository\RepositoryQuery;
use Knp\Component\Pager\PaginatorInterface;
use App\Entity\ThemeType;
use App\Repository\ConferenceRepository as Repository;
use Knp\Component\Pager\PaginatorInterface;
class ConferenceRepositoryQuery extends RepositoryQuery
{
@ -12,4 +13,25 @@ class ConferenceRepositoryQuery extends RepositoryQuery
{
parent::__construct($repository, 'c', $paginator);
}
public function withThemeType(?ThemeType $themeType): self
{
if (!$themeType) {
return $this;
}
$keyId = 'id'.mt_rand();
return $this
->andWhere('.themeType = :'.$keyId)
->setParameter($keyId, $themeType->getId())
;
}
protected function filterHandler(string $name, $value)
{
if ('themeType' === $name) {
return $this->withThemeType($value);
}
}
}

View file

@ -3,8 +3,9 @@
namespace App\Repository;
use App\Core\Repository\RepositoryQuery;
use Knp\Component\Pager\PaginatorInterface;
use App\Entity\Establishment;
use App\Repository\ProjectRepository as Repository;
use Knp\Component\Pager\PaginatorInterface;
class ProjectRepositoryQuery extends RepositoryQuery
{
@ -24,4 +25,27 @@ class ProjectRepositoryQuery extends RepositoryQuery
->setParameter('ids', $ids)
;
}
public function withEstablishment(?Establishment $establishment): self
{
if (!$establishment) {
return $this;
}
$keyEstablishment = 'k'.mt_rand();
$keyId = 'id'.mt_rand();
return $this
->innerJoin('.establishments', $keyEstablishment)
->andWhere($keyEstablishment.'.id = :'.$keyId)
->setParameter($keyId, $establishment->getId())
;
}
protected function filterHandler(string $name, $value)
{
if ('establishment' === $name) {
return $this->withEstablishment($value);
}
}
}