add project/conference filters
This commit is contained in:
parent
f8db332058
commit
6763eedb39
|
@ -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',
|
||||
|
|
|
@ -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)
|
||||
|
||||
|
|
39
src/Form/ConferenceFilterType.php
Normal file
39
src/Form/ConferenceFilterType.php
Normal 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,
|
||||
]);
|
||||
}
|
||||
}
|
39
src/Form/ProjectFilterType.php
Normal file
39
src/Form/ProjectFilterType.php
Normal 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,
|
||||
]);
|
||||
}
|
||||
}
|
|
@ -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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue