mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
Controllers adjusted for use with person or household
This commit is contained in:
parent
9065ec40b1
commit
0fcf21bd35
@ -56,10 +56,18 @@ abstract class AbstractElementController extends Controller
|
|||||||
protected function _delete(AbstractElement $element, Request $request, $template, $flashMessage): Response
|
protected function _delete(AbstractElement $element, Request $request, $template, $flashMessage): Response
|
||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted(BudgetElementVoter::DELETE, $element, 'You are not '
|
$this->denyAccessUnlessGranted(BudgetElementVoter::DELETE, $element, 'You are not '
|
||||||
. 'allowed to delete this family membership');
|
. 'allowed to delete this item');
|
||||||
|
|
||||||
$form = $this->createDeleteForm();
|
$form = $this->createDeleteForm();
|
||||||
|
|
||||||
|
if (null != $element->getPerson()) {
|
||||||
|
$entity = $element->getPerson();
|
||||||
|
$indexPage = 'chill_budget_elements_index';
|
||||||
|
} else {
|
||||||
|
$entity = $element->getHousehold();
|
||||||
|
$indexPage = 'chill_budget_elements_household_index';
|
||||||
|
}
|
||||||
|
|
||||||
if ($request->getMethod() === Request::METHOD_DELETE) {
|
if ($request->getMethod() === Request::METHOD_DELETE) {
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
@ -79,8 +87,8 @@ abstract class AbstractElementController extends Controller
|
|||||||
$this->addFlash('success', $this->translator
|
$this->addFlash('success', $this->translator
|
||||||
->trans($flashMessage));
|
->trans($flashMessage));
|
||||||
|
|
||||||
return $this->redirectToRoute('chill_budget_elements_index', [
|
return $this->redirectToRoute($indexPage, [
|
||||||
'id' => $element->getPerson()->getId(),
|
'id' => $entity->getId(),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -99,6 +107,18 @@ abstract class AbstractElementController extends Controller
|
|||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted(BudgetElementVoter::UPDATE, $element);
|
$this->denyAccessUnlessGranted(BudgetElementVoter::UPDATE, $element);
|
||||||
|
|
||||||
|
if (null != $element->getPerson()) {
|
||||||
|
$entity = $element->getPerson();
|
||||||
|
$entityStr = 'person';
|
||||||
|
$indexPage = 'chill_budget_elements_index';
|
||||||
|
} else {
|
||||||
|
$entity = $element->getHousehold();
|
||||||
|
$entityStr = 'household';
|
||||||
|
$indexPage = 'chill_budget_elements_household_index';
|
||||||
|
}
|
||||||
|
|
||||||
|
$entity = null != $element->getPerson() ? : $element->getHousehold();
|
||||||
|
|
||||||
$form = $this->createForm($this->getType(), $element);
|
$form = $this->createForm($this->getType(), $element);
|
||||||
$form->add('submit', SubmitType::class);
|
$form->add('submit', SubmitType::class);
|
||||||
|
|
||||||
@ -110,15 +130,15 @@ abstract class AbstractElementController extends Controller
|
|||||||
|
|
||||||
$this->addFlash('success', $this->translator->trans($flashOnSuccess));
|
$this->addFlash('success', $this->translator->trans($flashOnSuccess));
|
||||||
|
|
||||||
return $this->redirectToRoute('chill_budget_elements_index', [
|
return $this->redirectToRoute($indexPage, [
|
||||||
'id' => $element->getPerson()->getId(),
|
'id' => $entity->getId(),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->render($template, [
|
return $this->render($template, [
|
||||||
'element' => $element,
|
'element' => $element,
|
||||||
'form' => $form->createView(),
|
'form' => $form->createView(),
|
||||||
'person' => $element->getPerson(),
|
$entityStr => $entity,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -126,13 +146,22 @@ abstract class AbstractElementController extends Controller
|
|||||||
* @param mixed $template
|
* @param mixed $template
|
||||||
* @param mixed $flashMessageOnSuccess
|
* @param mixed $flashMessageOnSuccess
|
||||||
*/
|
*/
|
||||||
protected function _new(Person $person, Request $request, $template, $flashMessageOnSuccess)
|
protected function _new($entity, Request $request, $template, $flashMessageOnSuccess)
|
||||||
{
|
{
|
||||||
/** @var AbstractElement $element */
|
/** @var AbstractElement $element */
|
||||||
$element = $this->createNewElement()
|
$element = new AbstractElement();
|
||||||
->setPerson($person);
|
|
||||||
|
|
||||||
$this->denyAccessUnlessGranted(BudgetElementVoter::CREATE, $element);
|
if ($entity instanceof Person) {
|
||||||
|
$element->setPerson($entity);
|
||||||
|
$entityStr = 'person';
|
||||||
|
$indexPage = 'chill_budget_elements_index';
|
||||||
|
} else {
|
||||||
|
$element->setHousehold($entity);
|
||||||
|
$entityStr = 'household';
|
||||||
|
$indexPage = 'chill_budget_elements_household_index';
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->denyAccessUnlessGranted(BudgetElementVoter::CREATE, $entity);
|
||||||
|
|
||||||
$form = $this->createForm($this->getType(), $element);
|
$form = $this->createForm($this->getType(), $element);
|
||||||
$form->add('submit', SubmitType::class);
|
$form->add('submit', SubmitType::class);
|
||||||
@ -146,8 +175,8 @@ abstract class AbstractElementController extends Controller
|
|||||||
|
|
||||||
$this->addFlash('success', $this->translator->trans($flashMessageOnSuccess));
|
$this->addFlash('success', $this->translator->trans($flashMessageOnSuccess));
|
||||||
|
|
||||||
return $this->redirectToRoute('chill_budget_elements_index', [
|
return $this->redirectToRoute($indexPage, [
|
||||||
'id' => $person->getId(),
|
'id' => $entity->getId(),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,7 +186,7 @@ abstract class AbstractElementController extends Controller
|
|||||||
|
|
||||||
return $this->render($template, [
|
return $this->render($template, [
|
||||||
'form' => $form->createView(),
|
'form' => $form->createView(),
|
||||||
'person' => $person,
|
$entityStr => $entity,
|
||||||
'element' => $element,
|
'element' => $element,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,7 @@ use Chill\BudgetBundle\Calculator\CalculatorManager;
|
|||||||
use Chill\BudgetBundle\Entity\Charge;
|
use Chill\BudgetBundle\Entity\Charge;
|
||||||
use Chill\BudgetBundle\Entity\Resource;
|
use Chill\BudgetBundle\Entity\Resource;
|
||||||
use Chill\BudgetBundle\Security\Authorization\BudgetElementVoter;
|
use Chill\BudgetBundle\Security\Authorization\BudgetElementVoter;
|
||||||
|
use Chill\PersonBundle\Entity\Household\Household;
|
||||||
use Chill\PersonBundle\Entity\Person;
|
use Chill\PersonBundle\Entity\Person;
|
||||||
use DateTime;
|
use DateTime;
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
@ -28,25 +29,13 @@ use function count;
|
|||||||
|
|
||||||
class ElementController extends Controller
|
class ElementController extends Controller
|
||||||
{
|
{
|
||||||
/**
|
protected CalculatorManager $calculator;
|
||||||
* @var CalculatorManager
|
|
||||||
*/
|
|
||||||
protected $calculator;
|
|
||||||
|
|
||||||
/**
|
protected LoggerInterface $chillMainLogger;
|
||||||
* @var LoggerInterface
|
|
||||||
*/
|
|
||||||
protected $chillMainLogger;
|
|
||||||
|
|
||||||
/**
|
protected EntityManagerInterface $em;
|
||||||
* @var EntityManagerInterface
|
|
||||||
*/
|
|
||||||
protected $em;
|
|
||||||
|
|
||||||
/**
|
protected TranslatorInterface $translator;
|
||||||
* @var TranslatorInterface
|
|
||||||
*/
|
|
||||||
protected $translator;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
EntityManagerInterface $em,
|
EntityManagerInterface $em,
|
||||||
@ -68,11 +57,12 @@ class ElementController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function indexAction(Person $person)
|
public function indexAction(Person $person)
|
||||||
{
|
{
|
||||||
// $this->denyAccessUnlessGranted(BudgetElementVoter::SHOW, $person);
|
$this->denyAccessUnlessGranted(BudgetElementVoter::SEE, $person);
|
||||||
|
|
||||||
$charges = $this->em
|
$charges = $this->em
|
||||||
->getRepository(Charge::class)
|
->getRepository(Charge::class)
|
||||||
->findByPerson($person);
|
->findByPerson($person);
|
||||||
|
|
||||||
$ressources = $this->em
|
$ressources = $this->em
|
||||||
->getRepository(Resource::class)
|
->getRepository(Resource::class)
|
||||||
->findByPerson($person);
|
->findByPerson($person);
|
||||||
@ -81,10 +71,10 @@ class ElementController extends Controller
|
|||||||
|
|
||||||
$actualCharges = $this->em
|
$actualCharges = $this->em
|
||||||
->getRepository(Charge::class)
|
->getRepository(Charge::class)
|
||||||
->findByPersonAndDate($person, $now);
|
->findByEntityAndDate($person, $now);
|
||||||
$actualResources = $this->em
|
$actualResources = $this->em
|
||||||
->getRepository(Resource::class)
|
->getRepository(Resource::class)
|
||||||
->findByPersonAndDate($person, $now);
|
->findByEntityAndDate($person, $now);
|
||||||
|
|
||||||
$elements = array_merge($actualCharges, $actualResources);
|
$elements = array_merge($actualCharges, $actualResources);
|
||||||
|
|
||||||
@ -92,11 +82,52 @@ class ElementController extends Controller
|
|||||||
$results = $this->calculator->calculateDefault($elements);
|
$results = $this->calculator->calculateDefault($elements);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->render('ChillBudgetBundle:Element:index.html.twig', [
|
return $this->render('ChillBudgetBundle:Person:index.html.twig', [
|
||||||
'person' => $person,
|
'person' => $person,
|
||||||
'charges' => $charges,
|
'charges' => $charges,
|
||||||
'resources' => $ressources,
|
'resources' => $ressources,
|
||||||
'results' => $results ?? [],
|
'results' => $results ?? [],
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Route(
|
||||||
|
* "{_locale}/budget/elements/by-household/{id}",
|
||||||
|
* name="chill_budget_elements_household_index"
|
||||||
|
* )
|
||||||
|
*/
|
||||||
|
public function indexHouseholdAction(Household $household)
|
||||||
|
{
|
||||||
|
// $this->denyAccessUnlessGranted(BudgetElementVoter::SEE, $household);
|
||||||
|
|
||||||
|
$charges = $this->em
|
||||||
|
->getRepository(Charge::class)
|
||||||
|
->findByHousehold($household);
|
||||||
|
|
||||||
|
$ressources = $this->em
|
||||||
|
->getRepository(Resource::class)
|
||||||
|
->findByHousehold($household);
|
||||||
|
|
||||||
|
$now = new DateTime('now');
|
||||||
|
|
||||||
|
$actualCharges = $this->em
|
||||||
|
->getRepository(Charge::class)
|
||||||
|
->findByEntityAndDate($household, $now);
|
||||||
|
$actualResources = $this->em
|
||||||
|
->getRepository(Resource::class)
|
||||||
|
->findByEntityAndDate($household, $now);
|
||||||
|
|
||||||
|
$elements = array_merge($actualCharges, $actualResources);
|
||||||
|
|
||||||
|
if (count($elements) > 0) {
|
||||||
|
$results = $this->calculator->calculateDefault($elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->render('ChillBudgetBundle:Household:index.html.twig', [
|
||||||
|
'household' => $household,
|
||||||
|
'charges' => $charges,
|
||||||
|
'resources' => $ressources,
|
||||||
|
'results' => $results ?? [],
|
||||||
|
]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,104 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Chill is a software for social workers
|
|
||||||
*
|
|
||||||
* For the full copyright and license information, please view
|
|
||||||
* the LICENSE file that was distributed with this source code.
|
|
||||||
*/
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace Chill\BudgetBundle\Controller;
|
|
||||||
|
|
||||||
use Chill\BudgetBundle\Calculator\CalculatorManager;
|
|
||||||
use Chill\BudgetBundle\Entity\Charge;
|
|
||||||
use Chill\BudgetBundle\Entity\Resource;
|
|
||||||
use Chill\PersonBundle\Entity\Household\Household;
|
|
||||||
use Chill\PersonBundle\Entity\Person;
|
|
||||||
use DateTime;
|
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
|
||||||
use Psr\Log\LoggerInterface;
|
|
||||||
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
|
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
|
|
||||||
use Symfony\Contracts\Translation\TranslatorInterface;
|
|
||||||
|
|
||||||
use function array_merge;
|
|
||||||
use function count;
|
|
||||||
|
|
||||||
class ElementHouseholdController extends Controller
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @var CalculatorManager
|
|
||||||
*/
|
|
||||||
protected $calculator;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var LoggerInterface
|
|
||||||
*/
|
|
||||||
protected $chillMainLogger;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var EntityManagerInterface
|
|
||||||
*/
|
|
||||||
protected $em;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var TranslatorInterface
|
|
||||||
*/
|
|
||||||
protected $translator;
|
|
||||||
|
|
||||||
public function __construct(
|
|
||||||
EntityManagerInterface $em,
|
|
||||||
TranslatorInterface $translator,
|
|
||||||
LoggerInterface $chillMainLogger,
|
|
||||||
CalculatorManager $calculator
|
|
||||||
) {
|
|
||||||
$this->em = $em;
|
|
||||||
$this->translator = $translator;
|
|
||||||
$this->chillMainLogger = $chillMainLogger;
|
|
||||||
$this->calculator = $calculator;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Route(
|
|
||||||
* "{_locale}/budget/elements/by-household/{household_id}",
|
|
||||||
* name="chill_person_household_budget_index"
|
|
||||||
* )
|
|
||||||
*/
|
|
||||||
public function indexAction(Household $household)
|
|
||||||
{
|
|
||||||
// $this->denyAccessUnlessGranted(BudgetElementVoter::SEE, $household);
|
|
||||||
|
|
||||||
// $charges = $this->em
|
|
||||||
// ->getRepository(Charge::class)
|
|
||||||
// ->findByPerson($person);
|
|
||||||
// $ressources = $this->em
|
|
||||||
// ->getRepository(Resource::class)
|
|
||||||
// ->findByPerson($person);
|
|
||||||
|
|
||||||
// $now = new DateTime('now');
|
|
||||||
|
|
||||||
// $actualCharges = $this->em
|
|
||||||
// ->getRepository(Charge::class)
|
|
||||||
// ->findByPersonAndDate($person, $now);
|
|
||||||
// $actualResources = $this->em
|
|
||||||
// ->getRepository(Resource::class)
|
|
||||||
// ->findByPersonAndDate($person, $now);
|
|
||||||
|
|
||||||
// $elements = array_merge($actualCharges, $actualResources);
|
|
||||||
|
|
||||||
// if (count($elements) > 0) {
|
|
||||||
// $results = $this->calculator->calculateDefault($elements);
|
|
||||||
// }
|
|
||||||
|
|
||||||
// return $this->render('ChillBudgetBundle:Element:index.html.twig', [
|
|
||||||
// 'person' => $person,
|
|
||||||
// 'charges' => $charges,
|
|
||||||
// 'resources' => $ressources,
|
|
||||||
// 'results' => $results ?? [],
|
|
||||||
// ]);
|
|
||||||
|
|
||||||
return 'hello world';
|
|
||||||
}
|
|
||||||
}
|
|
@ -13,6 +13,7 @@ namespace Chill\BudgetBundle\Controller;
|
|||||||
|
|
||||||
use Chill\BudgetBundle\Entity\Resource;
|
use Chill\BudgetBundle\Entity\Resource;
|
||||||
use Chill\BudgetBundle\Form\ResourceType;
|
use Chill\BudgetBundle\Form\ResourceType;
|
||||||
|
use Chill\PersonBundle\Entity\Household\Household;
|
||||||
use Chill\PersonBundle\Entity\Person;
|
use Chill\PersonBundle\Entity\Person;
|
||||||
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
|
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
@ -53,6 +54,8 @@ class ResourceController extends AbstractElementController
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Create a new budget element for a person
|
||||||
|
*
|
||||||
* @Route(
|
* @Route(
|
||||||
* "{_locale}/budget/resource/by-person/{id}/new",
|
* "{_locale}/budget/resource/by-person/{id}/new",
|
||||||
* name="chill_budget_resource_new"
|
* name="chill_budget_resource_new"
|
||||||
@ -68,6 +71,24 @@ class ResourceController extends AbstractElementController
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create new budget element for a household
|
||||||
|
*
|
||||||
|
* @Route(
|
||||||
|
* "{_locale}/budget/resource/by-household/{id}/new",
|
||||||
|
* name="chill_budget_resource_new"
|
||||||
|
* )
|
||||||
|
*/
|
||||||
|
public function newHouseholdAction(Request $request, Household $household): Response
|
||||||
|
{
|
||||||
|
return $this->_new(
|
||||||
|
$household,
|
||||||
|
$request,
|
||||||
|
'@ChillBudget/Resource/new.html.twig',
|
||||||
|
'Resource created'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Route(
|
* @Route(
|
||||||
* "{_locale}/budget/resource/{id}/view",
|
* "{_locale}/budget/resource/{id}/view",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user