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\Entity\Conference as Entity;
|
||||||
use App\Factory\ConferenceFactory as Factory;
|
use App\Factory\ConferenceFactory as Factory;
|
||||||
use App\Form\ConferenceType as Type;
|
use App\Form\ConferenceType as Type;
|
||||||
|
use App\Form\ConferenceFilterType as FilterType;
|
||||||
use App\Repository\ConferenceRepositoryQuery as RepositoryQuery;
|
use App\Repository\ConferenceRepositoryQuery as RepositoryQuery;
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
|
@ -101,7 +102,7 @@ class ConferenceAdminController extends CrudController
|
||||||
|
|
||||||
->setForm('edit', Type::class, [])
|
->setForm('edit', Type::class, [])
|
||||||
->setForm('new', Type::class)
|
->setForm('new', Type::class)
|
||||||
// ->setForm('filter', Type::class)
|
->setForm('filter', FilterType::class)
|
||||||
|
|
||||||
->setView('form', 'admin/conference/_form.html.twig')
|
->setView('form', 'admin/conference/_form.html.twig')
|
||||||
|
|
||||||
|
@ -125,6 +126,11 @@ class ConferenceAdminController extends CrudController
|
||||||
->setField('index', 'Label', Field\TextField::class, [
|
->setField('index', 'Label', Field\TextField::class, [
|
||||||
'property' => 'label',
|
'property' => 'label',
|
||||||
])
|
])
|
||||||
|
->setField('index', 'Theme type', Field\TextField::class, [
|
||||||
|
'property' => 'themeType',
|
||||||
|
'sort' => ['date', '.date'],
|
||||||
|
'attr' => ['class' => 'col-3'],
|
||||||
|
])
|
||||||
->setField('index', 'Date', Field\DateField::class, [
|
->setField('index', 'Date', Field\DateField::class, [
|
||||||
'property' => 'date',
|
'property' => 'date',
|
||||||
'format' => 'd/m/Y',
|
'format' => 'd/m/Y',
|
||||||
|
|
|
@ -10,6 +10,7 @@ use App\Core\Manager\EntityManager;
|
||||||
use App\Entity\Project as Entity;
|
use App\Entity\Project as Entity;
|
||||||
use App\Factory\ProjectFactory as Factory;
|
use App\Factory\ProjectFactory as Factory;
|
||||||
use App\Form\ProjectType as Type;
|
use App\Form\ProjectType as Type;
|
||||||
|
use App\Form\ProjectFilterType as FilterType;
|
||||||
use App\Repository\ProjectRepositoryQuery as RepositoryQuery;
|
use App\Repository\ProjectRepositoryQuery as RepositoryQuery;
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
|
@ -101,7 +102,7 @@ class ProjectAdminController extends CrudController
|
||||||
|
|
||||||
->setForm('edit', Type::class, [])
|
->setForm('edit', Type::class, [])
|
||||||
->setForm('new', Type::class)
|
->setForm('new', Type::class)
|
||||||
// ->setForm('filter', Type::class)
|
->setForm('filter', FilterType::class)
|
||||||
|
|
||||||
// ->setMaxPerPage('index', 20)
|
// ->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;
|
namespace App\Repository;
|
||||||
|
|
||||||
use App\Core\Repository\RepositoryQuery;
|
use App\Core\Repository\RepositoryQuery;
|
||||||
use Knp\Component\Pager\PaginatorInterface;
|
use App\Entity\ThemeType;
|
||||||
use App\Repository\ConferenceRepository as Repository;
|
use App\Repository\ConferenceRepository as Repository;
|
||||||
|
use Knp\Component\Pager\PaginatorInterface;
|
||||||
|
|
||||||
class ConferenceRepositoryQuery extends RepositoryQuery
|
class ConferenceRepositoryQuery extends RepositoryQuery
|
||||||
{
|
{
|
||||||
|
@ -12,4 +13,25 @@ class ConferenceRepositoryQuery extends RepositoryQuery
|
||||||
{
|
{
|
||||||
parent::__construct($repository, 'c', $paginator);
|
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;
|
namespace App\Repository;
|
||||||
|
|
||||||
use App\Core\Repository\RepositoryQuery;
|
use App\Core\Repository\RepositoryQuery;
|
||||||
use Knp\Component\Pager\PaginatorInterface;
|
use App\Entity\Establishment;
|
||||||
use App\Repository\ProjectRepository as Repository;
|
use App\Repository\ProjectRepository as Repository;
|
||||||
|
use Knp\Component\Pager\PaginatorInterface;
|
||||||
|
|
||||||
class ProjectRepositoryQuery extends RepositoryQuery
|
class ProjectRepositoryQuery extends RepositoryQuery
|
||||||
{
|
{
|
||||||
|
@ -24,4 +25,27 @@ class ProjectRepositoryQuery extends RepositoryQuery
|
||||||
->setParameter('ids', $ids)
|
->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