Mathieu Jaumotte 2021-02-03 18:50:34 +01:00
parent 03cafbf4c6
commit c76e401021
6 changed files with 152 additions and 78 deletions

View File

@ -55,8 +55,10 @@ class AccompanyingPeriodController extends AbstractController
$this->eventDispatcher = $eventDispatcher; $this->eventDispatcher = $eventDispatcher;
} }
/**
* @param $person_id
* @return Response
*/
public function listAction($person_id){ public function listAction($person_id){
$person = $this->_getPerson($person_id); $person = $this->_getPerson($person_id);
@ -71,8 +73,15 @@ class AccompanyingPeriodController extends AbstractController
array('accompanying_periods' => $person->getAccompanyingPeriodsOrdered(), array('accompanying_periods' => $person->getAccompanyingPeriodsOrdered(),
'person' => $person)); 'person' => $person));
} }
public function createAction($person_id, Request $request) { /**
* @param $person_id
* @param Request $request
* @return \Symfony\Component\HttpFoundation\RedirectResponse|Response
*/
public function createAction($person_id, Request $request)
{
$person = $this->_getPerson($person_id); $person = $this->_getPerson($person_id);
$this->denyAccessUnlessGranted(PersonVoter::UPDATE, $person, $this->denyAccessUnlessGranted(PersonVoter::UPDATE, $person,
@ -91,7 +100,7 @@ class AccompanyingPeriodController extends AbstractController
'period_action' => 'create', 'period_action' => 'create',
'center' => $person->getCenter() 'center' => $person->getCenter()
]); ]);
if ($request->getMethod() === 'POST') { if ($request->getMethod() === 'POST') {
$form->handleRequest($request); $form->handleRequest($request);
$errors = $this->_validatePerson($person); $errors = $this->_validatePerson($person);
@ -127,7 +136,13 @@ class AccompanyingPeriodController extends AbstractController
) )
); );
} }
/**
* @param $person_id
* @param $period_id
* @param Request $request
* @return \Symfony\Component\HttpFoundation\RedirectResponse|Response|\Symfony\Component\HttpKernel\Exception\NotFoundHttpException
*/
public function updateAction($person_id, $period_id, Request $request){ public function updateAction($person_id, $period_id, Request $request){
$em = $this->getDoctrine()->getManager(); $em = $this->getDoctrine()->getManager();
@ -180,8 +195,16 @@ class AccompanyingPeriodController extends AbstractController
'accompanying_period' => $accompanyingPeriod 'accompanying_period' => $accompanyingPeriod
) ); ) );
} }
public function closeAction($person_id, Request $request) { /**
* @param $person_id
* @param Request $request
* @return \Symfony\Component\HttpFoundation\RedirectResponse|Response
* @throws \Exception
*/
public function closeAction($person_id, Request $request)
{
$person = $this->_getPerson($person_id); $person = $this->_getPerson($person_id);
$this->denyAccessUnlessGranted(PersonVoter::UPDATE, $person, $this->denyAccessUnlessGranted(PersonVoter::UPDATE, $person,
@ -200,6 +223,7 @@ class AccompanyingPeriodController extends AbstractController
} }
$current = $person->getCurrentAccompanyingPeriod(); $current = $person->getCurrentAccompanyingPeriod();
$form = $this->createForm(AccompanyingPeriodType::class, $current, array( $form = $this->createForm(AccompanyingPeriodType::class, $current, array(
'period_action' => 'close', 'period_action' => 'close',
'center' => $person->getCenter() 'center' => $person->getCenter()
@ -256,10 +280,9 @@ class AccompanyingPeriodController extends AbstractController
'accompanying_period' => $current 'accompanying_period' => $current
)); ));
} }
/** /**
* * @param Person $person
* @param Chill\PersonBundle\Entity\Person $person
* @return \Symfony\Component\Validator\ConstraintViolationListInterface * @return \Symfony\Component\Validator\ConstraintViolationListInterface
*/ */
private function _validatePerson(Person $person) { private function _validatePerson(Person $person) {
@ -274,8 +297,12 @@ class AccompanyingPeriodController extends AbstractController
return $errors; return $errors;
} }
/**
* @param $person_id
* @param Request $request
* @return \Symfony\Component\HttpFoundation\RedirectResponse|Response
*/
public function openAction($person_id, Request $request) { public function openAction($person_id, Request $request) {
$person = $this->_getPerson($person_id); $person = $this->_getPerson($person_id);
@ -343,7 +370,13 @@ class AccompanyingPeriodController extends AbstractController
'person' => $person, 'person' => $person,
'accompanying_period' => $accompanyingPeriod)); 'accompanying_period' => $accompanyingPeriod));
} }
/**
* @param $person_id
* @param $period_id
* @param Request $request
* @return object|\Symfony\Component\HttpFoundation\RedirectResponse|Response
*/
public function reOpenAction($person_id, $period_id, Request $request) public function reOpenAction($person_id, $period_id, Request $request)
{ {
$person = $this->_getPerson($person_id); $person = $this->_getPerson($person_id);

View File

@ -2,6 +2,7 @@
namespace Chill\PersonBundle\Form; namespace Chill\PersonBundle\Form;
use Chill\MainBundle\Entity\Center;
use Symfony\Component\Form\AbstractType; use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface; use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver; use Symfony\Component\OptionsResolver\OptionsResolver;
@ -16,6 +17,11 @@ use Chill\MainBundle\Form\Type\UserPickerType;
use Symfony\Component\Security\Core\Role\Role; use Symfony\Component\Security\Core\Role\Role;
use Chill\PersonBundle\Form\Type\ClosingMotivePickerType; use Chill\PersonBundle\Form\Type\ClosingMotivePickerType;
/**
* Class AccompanyingPeriodType
*
* @package Chill\PersonBundle\Form
*/
class AccompanyingPeriodType extends AbstractType class AccompanyingPeriodType extends AbstractType
{ {
/** /**
@ -26,7 +32,7 @@ class AccompanyingPeriodType extends AbstractType
* *
* @var string[] * @var string[]
*/ */
protected $config = array(); protected $config = [];
/** /**
* *
@ -46,35 +52,36 @@ class AccompanyingPeriodType extends AbstractType
//if the period_action is close, date opening should not be seen //if the period_action is close, date opening should not be seen
if ($options['period_action'] !== 'close') { if ($options['period_action'] !== 'close') {
$builder $builder
->add('openingDate', DateType::class, array( ->add('openingDate', DateType::class, [
"required" => true, "required" => true,
'widget' => 'single_text', 'widget' => 'single_text',
'format' => 'dd-MM-yyyy' 'format' => 'dd-MM-yyyy'
)); ])
;
} }
// the closingDate should be seen only if period_action = close
// or period_action = update AND accopanying period is already closed
$builder->addEventListener(
FormEvents::PRE_SET_DATA, function (FormEvent $event) use ($options) {
$accompanyingPeriod = $event->getData();
$form = $event->getForm();
//add date opening
if (
//if the period_action is "close, should not be shown"
($options['period_action'] === 'close')
OR
($options['period_action'] === 'create')
OR
($options['period_action'] === 'update' AND !$accompanyingPeriod->isOpen())
) {
$form->add('closingDate', DateType::class, array('required' => true,
'widget' => 'single_text', 'format' => 'dd-MM-yyyy'));
$form->add('closingMotive', ClosingMotivePickerType::class);
}
});
// closingDate should be seen only if
// period_action = close
// OR ( period_action = update AND accompanying period is already closed )
$accompanyingPeriod = $options['data'];
if (
($options['period_action'] === 'close')
OR
($options['period_action'] === 'create')
OR
($options['period_action'] === 'update' AND !$accompanyingPeriod->isOpen())
) {
$builder->add('closingDate', DateType::class, [
'required' => true,
'widget' => 'single_text',
'format' => 'dd-MM-yyyy'
]);
$builder->add('closingMotive', ClosingMotivePickerType::class);
}
if ($this->config['user'] === 'visible') { if ($this->config['user'] === 'visible') {
$builder->add('user', UserPickerType::class, [ $builder->add('user', UserPickerType::class, [
'center' => $options['center'], 'center' => $options['center'],
@ -82,10 +89,9 @@ class AccompanyingPeriodType extends AbstractType
]); ]);
} }
$builder->add('remark', TextareaType::class, array( $builder->add('remark', TextareaType::class, [
'required' => false 'required' => false
)) ]);
;
} }
/** /**
@ -93,20 +99,24 @@ class AccompanyingPeriodType extends AbstractType
*/ */
public function configureOptions(OptionsResolver $resolver) public function configureOptions(OptionsResolver $resolver)
{ {
$resolver->setDefaults(array( $resolver->setDefaults([
'data_class' => 'Chill\PersonBundle\Entity\AccompanyingPeriod' 'data_class' => 'Chill\PersonBundle\Entity\AccompanyingPeriod'
)); ]);
$resolver $resolver
->setRequired(array('period_action')) ->setRequired(['period_action'])
->addAllowedTypes('period_action', 'string') ->addAllowedTypes('period_action', 'string')
->addAllowedValues('period_action', array( ->addAllowedValues('period_action', ['update', 'open', 'close', 'create'])
'update', 'open', 'close', 'create'))
->setRequired('center') ->setRequired('center')
->setAllowedTypes('center', \Chill\MainBundle\Entity\Center::class) ->setAllowedTypes('center', Center::class)
; ;
} }
/**
* @param FormView $view
* @param FormInterface $form
* @param array $options
*/
public function buildView(FormView $view, FormInterface $form, array $options) public function buildView(FormView $view, FormInterface $form, array $options)
{ {
$view->vars['action'] = $options['period_action']; $view->vars['action'] = $options['period_action'];

View File

@ -21,17 +21,23 @@ namespace Chill\PersonBundle\Form;
use Symfony\Component\Form\AbstractType; use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface; use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver; use Symfony\Component\OptionsResolver\OptionsResolver;
use Chill\PersonBundle\Entity\AccompanyingPeriod\ClosingMotive;
use Chill\PersonBundle\Form\Type\ClosingMotivePickerType; use Chill\PersonBundle\Form\Type\ClosingMotivePickerType;
use Chill\MainBundle\Form\Type\TranslatableStringFormType; use Chill\MainBundle\Form\Type\TranslatableStringFormType;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType; use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
use Symfony\Component\Form\Extension\Core\Type\NumberType; use Symfony\Component\Form\Extension\Core\Type\NumberType;
/** /**
* * Class ClosingMotiveType
* *
* @package Chill\PersonBundle\Form
*/ */
class ClosingMotiveType extends AbstractType class ClosingMotiveType extends AbstractType
{ {
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options) public function buildForm(FormBuilderInterface $builder, array $options)
{ {
$builder $builder
@ -57,10 +63,13 @@ class ClosingMotiveType extends AbstractType
; ;
} }
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver) public function configureOptions(OptionsResolver $resolver)
{ {
$resolver $resolver
->setDefault('class', \Chill\PersonBundle\Entity\AccompanyingPeriod\ClosingMotive::class) ->setDefault('class', ClosingMotive::class)
; ;
} }
} }

View File

@ -14,30 +14,36 @@ use Symfony\Component\OptionsResolver\Options;
use Chill\PersonBundle\Repository\ClosingMotiveRepository; use Chill\PersonBundle\Repository\ClosingMotiveRepository;
/** /**
* Class ClosingMotivePickerType
* A type to add a closing motive * A type to add a closing motive
* *
* @package Chill\PersonBundle\Form\Type
*/ */
class ClosingMotivePickerType extends AbstractType class ClosingMotivePickerType extends AbstractType
{ {
/** /**
*
* @var TranslatableStringHelper * @var TranslatableStringHelper
*/ */
protected $translatableStringHelper; protected $translatableStringHelper;
/** /**
*
* @var ChillEntityRenderExtension * @var ChillEntityRenderExtension
*/ */
protected $entityRenderExtension; protected $entityRenderExtension;
/** /**
*
* @var ClosingMotiveRepository * @var ClosingMotiveRepository
*/ */
protected $repository; protected $repository;
/**
* ClosingMotivePickerType constructor.
*
* @param TranslatableStringHelper $translatableStringHelper
* @param ChillEntityRenderExtension $chillEntityRenderExtension
* @param ClosingMotiveRepository $closingMotiveRepository
*/
public function __construct( public function __construct(
TranslatableStringHelper $translatableStringHelper, TranslatableStringHelper $translatableStringHelper,
ChillEntityRenderExtension $chillEntityRenderExtension, ChillEntityRenderExtension $chillEntityRenderExtension,
@ -47,35 +53,46 @@ class ClosingMotivePickerType extends AbstractType
$this->entityRenderExtension = $chillEntityRenderExtension; $this->entityRenderExtension = $chillEntityRenderExtension;
$this->repository = $closingMotiveRepository; $this->repository = $closingMotiveRepository;
} }
public function getBlockPrefix() /**
* @return string
*/
public function getBlockPrefix()
{ {
return 'closing_motive'; return 'closing_motive';
} }
/**
* @return null|string
*/
public function getParent() public function getParent()
{ {
return EntityType::class; return EntityType::class;
} }
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver) public function configureOptions(OptionsResolver $resolver)
{ {
$resolver->setDefaults(array(
'class' => ClosingMotive::class, $resolver->setDefaults([
'empty_data' => null, 'class' => ClosingMotive::class,
'placeholder' => 'Choose a motive', 'empty_data' => null,
'choice_label' => function(ClosingMotive $cm) { 'placeholder' => 'Choose a motive',
return $this->entityRenderExtension->renderString($cm); 'choice_label' => function(ClosingMotive $cm) {
}, return $this->entityRenderExtension->renderString($cm);
'only_leaf' => true },
) 'only_leaf' => true
); ]);
$resolver $resolver
->setAllowedTypes('only_leaf', 'bool') ->setAllowedTypes('only_leaf', 'bool')
->setNormalizer('choices', function (Options $options) { ->setNormalizer('choices', function (Options $options) {
return $this->repository->getActiveClosingMotive($options['only_leaf']); return $this->repository
}); ->getActiveClosingMotive($options['only_leaf']);
})
;
} }
} }

View File

@ -17,15 +17,22 @@
*/ */
namespace Chill\PersonBundle\Repository; namespace Chill\PersonBundle\Repository;
use Doctrine\ORM\EntityRepository;
use Doctrine\ORM\QueryBuilder; use Doctrine\ORM\QueryBuilder;
use Doctrine\ORM\Query\ResultSetMappingBuilder; use Doctrine\ORM\Query\ResultSetMappingBuilder;
/** /**
* Class ClosingMotiveRepository
* Entity repository for closing motives * Entity repository for closing motives
* *
* @package Chill\PersonBundle\Repository
*/ */
class ClosingMotiveRepository extends \Doctrine\ORM\EntityRepository class ClosingMotiveRepository extends EntityRepository
{ {
/**
* @param bool $onlyLeaf
* @return mixed
*/
public function getActiveClosingMotive(bool $onlyLeaf = true) public function getActiveClosingMotive(bool $onlyLeaf = true)
{ {
$rsm = new ResultSetMappingBuilder($this->getEntityManager()); $rsm = new ResultSetMappingBuilder($this->getEntityManager());

View File

@ -12,5 +12,3 @@ services:
factory: ['@doctrine.orm.entity_manager', getRepository] factory: ['@doctrine.orm.entity_manager', getRepository]
arguments: arguments:
- 'Chill\PersonBundle\Entity\AccompanyingPeriod\ClosingMotive' - 'Chill\PersonBundle\Entity\AccompanyingPeriod\ClosingMotive'
tags:
- { name: doctrine.repository_service }