mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-12 13:24:25 +00:00
CRUD: improve index view
This commit is contained in:
parent
278d7f5772
commit
937792fa2d
13
CHANGELOG.md
13
CHANGELOG.md
@ -81,12 +81,6 @@ Version 1.5.9
|
|||||||
- [closing motive] Add an admin section for closing motives ;
|
- [closing motive] Add an admin section for closing motives ;
|
||||||
|
|
||||||
<<<<<<< HEAD
|
<<<<<<< HEAD
|
||||||
Master branch
|
|
||||||
=============
|
|
||||||
|
|
||||||
- [CRUD] add step delete
|
|
||||||
|
|
||||||
=======
|
|
||||||
Version 1.5.10
|
Version 1.5.10
|
||||||
==============
|
==============
|
||||||
|
|
||||||
@ -103,3 +97,10 @@ Version 1.5.12
|
|||||||
- [addresses] add a homeless to person's addresses, and this information into
|
- [addresses] add a homeless to person's addresses, and this information into
|
||||||
person list
|
person list
|
||||||
|
|
||||||
|
Master branch
|
||||||
|
=============
|
||||||
|
|
||||||
|
|
||||||
|
- [CRUD] add step delete
|
||||||
|
- [CRUD] improve index view in person CRUD
|
||||||
|
|
||||||
|
@ -27,14 +27,26 @@ use Chill\PersonBundle\Entity\Person;
|
|||||||
*/
|
*/
|
||||||
class EntityPersonCRUDController extends CRUDController
|
class EntityPersonCRUDController extends CRUDController
|
||||||
{
|
{
|
||||||
protected function createEntity($action, Request $request): object
|
/**
|
||||||
|
* Extract the person from the request
|
||||||
|
*
|
||||||
|
* the person parameter will be `person_id` and must be
|
||||||
|
* present in the query
|
||||||
|
*
|
||||||
|
* If the parameter is not set, this method will return null.
|
||||||
|
*
|
||||||
|
* If the person id does not exists, the method will throw a
|
||||||
|
* Symfony\Component\HttpKernel\Exception\NotFoundHttpException
|
||||||
|
*
|
||||||
|
* @param Request $request
|
||||||
|
* @throws Symfony\Component\HttpKernel\Exception\NotFoundHttpException if the person with given id is not found
|
||||||
|
*/
|
||||||
|
protected function getPerson(Request $request): ?Person
|
||||||
{
|
{
|
||||||
if (FALSE === $request->query->has('person_id')) {
|
if (FALSE === $request->query->has('person_id')) {
|
||||||
throw $this->createNotFoundException('the person is not set');
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$entity = parent::createEntity($action, $request);
|
|
||||||
|
|
||||||
$person = $this->getDoctrine()
|
$person = $this->getDoctrine()
|
||||||
->getRepository(Person::class)
|
->getRepository(Person::class)
|
||||||
->find($request->query->getInt('person_id'))
|
->find($request->query->getInt('person_id'))
|
||||||
@ -44,11 +56,38 @@ class EntityPersonCRUDController extends CRUDController
|
|||||||
throw $this->createNotFoundException('the person with this id is not found');
|
throw $this->createNotFoundException('the person with this id is not found');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $person;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function createEntity($action, Request $request): object
|
||||||
|
{
|
||||||
|
$entity = parent::createEntity($action, $request);
|
||||||
|
|
||||||
|
$person = $this->getPerson($request);
|
||||||
|
|
||||||
$entity->setPerson($person);
|
$entity->setPerson($person);
|
||||||
|
|
||||||
return $entity;
|
return $entity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function generateTemplateParameter(string $action, $entity, Request $request, array $defaultTemplateParameters = array()): array
|
||||||
|
{
|
||||||
|
$person = $this->getPerson($request);
|
||||||
|
|
||||||
|
if (NULL === $person) {
|
||||||
|
throw new \Exception("the `person_id` parameter is not set in the query. "
|
||||||
|
. "You should set it or override the current method to allow another "
|
||||||
|
. "behaviour: ".__METHOD__);
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::generateTemplateParameter(
|
||||||
|
$action,
|
||||||
|
$entity,
|
||||||
|
$request,
|
||||||
|
\array_merge([ 'person' => $person ], $defaultTemplateParameters)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
protected function getTemplateFor($action, $entity, Request $request)
|
protected function getTemplateFor($action, $entity, Request $request)
|
||||||
{
|
{
|
||||||
if ($this->hasCustomTemplate($action, $entity, $request)) {
|
if ($this->hasCustomTemplate($action, $entity, $request)) {
|
||||||
@ -64,6 +103,8 @@ class EntityPersonCRUDController extends CRUDController
|
|||||||
return '@ChillPerson/CRUD/view.html.twig';
|
return '@ChillPerson/CRUD/view.html.twig';
|
||||||
case 'delete':
|
case 'delete':
|
||||||
return '@ChillPerson/CRUD/delete.html.twig';
|
return '@ChillPerson/CRUD/delete.html.twig';
|
||||||
|
case 'index':
|
||||||
|
return '@ChillPerson/CRUD/index.html.twig';
|
||||||
default:
|
default:
|
||||||
return parent::getTemplateFor($action, $entity, $request);
|
return parent::getTemplateFor($action, $entity, $request);
|
||||||
}
|
}
|
||||||
@ -76,7 +117,7 @@ class EntityPersonCRUDController extends CRUDController
|
|||||||
switch ($next) {
|
switch ($next) {
|
||||||
case "save-and-close":
|
case "save-and-close":
|
||||||
return $this->redirectToRoute('chill_crud_'.$this->getCrudName().'_index', [
|
return $this->redirectToRoute('chill_crud_'.$this->getCrudName().'_index', [
|
||||||
'id' => $entity->getPerson()->getId()
|
'person_id' => $entity->getPerson()->getId()
|
||||||
]);
|
]);
|
||||||
case "save-and-new":
|
case "save-and-new":
|
||||||
return $this->redirectToRoute('chill_crud_'.$this->getCrudName().'_new', [
|
return $this->redirectToRoute('chill_crud_'.$this->getCrudName().'_new', [
|
||||||
@ -88,4 +129,6 @@ class EntityPersonCRUDController extends CRUDController
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
15
Resources/views/CRUD/index.html.twig
Normal file
15
Resources/views/CRUD/index.html.twig
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
{% extends '@ChillPerson/layout.html.twig' %}
|
||||||
|
|
||||||
|
{% set activeRouteKey = '' %}
|
||||||
|
|
||||||
|
{% block title %}{{ ('crud.' ~ crud_name ~ '.index.title')|trans({'%crud_name%': crud_name}) }}{% endblock %}
|
||||||
|
|
||||||
|
{% block personcontent %}
|
||||||
|
{% embed '@ChillMain/CRUD/_index.html.twig' %}
|
||||||
|
{% block add_new %}
|
||||||
|
<li>
|
||||||
|
<a href="{{ chill_path_add_return_path('chill_crud_' ~ crud_name ~ '_new', { 'person_id': person.id } ) }}" class="sc-button bt-new">{{ ('crud.'~crud_name~'.index.add_new')|trans( {'%crud_name%': crud_name} ) }}</a>
|
||||||
|
</li>
|
||||||
|
{% endblock %}
|
||||||
|
{% endembed %}
|
||||||
|
{% endblock personcontent %}
|
Loading…
x
Reference in New Issue
Block a user