person creation: fix bug + improve multi_center

The center is hidden in page "check if the person exists in the db"
This commit is contained in:
Julien Fastré 2015-12-16 12:19:16 +01:00
parent 07ed6a9751
commit b45b529dba
3 changed files with 53 additions and 25 deletions

View File

@ -174,10 +174,12 @@ class PersonController extends Controller
->setCenter($defaultCenter);
$form = $this->createForm(
new CreationPersonType(CreationPersonType::FORM_NOT_REVIEWED),
CreationPersonType::NAME,
$person,
array('action' => $this->generateUrl('chill_person_review'))
);
array(
'action' => $this->generateUrl('chill_person_review'),
'form_status' => CreationPersonType::FORM_NOT_REVIEWED
));
return $this->_renderNewForm($form);
}
@ -254,9 +256,12 @@ class PersonController extends Controller
}
$form = $this->createForm(
new CreationPersonType(CreationPersonType::FORM_BEING_REVIEWED),
CreationPersonType::NAME,
new Person(),
array('action' => $this->generateUrl('chill_person_create')));
array(
'action' => $this->generateUrl('chill_person_create'),
'form_status' => CreationPersonType::FORM_BEING_REVIEWED
));
$form->handleRequest($request);
@ -277,9 +282,12 @@ class PersonController extends Controller
}
$form = $this->createForm(
new CreationPersonType(CreationPersonType::FORM_NOT_REVIEWED),
CreationPersonType::NAME,
new Person(),
array('action' => $this->generateUrl('chill_person_review')));
array(
'action' => $this->generateUrl('chill_person_review'),
'form_status' => CreationPersonType::FORM_NOT_REVIEWED
));
$form->handleRequest($request);
@ -338,10 +346,12 @@ class PersonController extends Controller
return $r;
}
$form = $this->createForm(new CreationPersonType());
$form = $this->createForm(CreationPersonType::NAME, null, array(
'form_status' => CreationPersonType::FORM_REVIEWED
));
$form->handleRequest($request);
var_dump($form->getData());
$person = $this->_bindCreationForm($form);
$errors = $this->_validatePersonAndAccompanyingPeriod($person);

View File

@ -23,23 +23,28 @@ namespace Chill\PersonBundle\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Chill\PersonBundle\Form\Type\GenderType;
use Symfony\Component\Form\Extension\Core\DataTransformer\DateTimeToStringTransformer;
use Chill\MainBundle\Form\Type\DataTransformer\CenterTransformer;
class CreationPersonType extends AbstractType
{
private $form_status;
const NAME = 'chill_personbundle_person_creation';
const FORM_NOT_REVIEWED = 'not_reviewed';
const FORM_REVIEWED = 'reviewed' ;
const FORM_BEING_REVIEWED = 'being_reviewed';
public function __construct($form_status = self::FORM_NOT_REVIEWED) {
$this->setStatus($form_status);
/**
*
* @var CenterTransformer
*/
private $centerTransformer;
public function __construct(CenterTransformer $centerTransformer) {
$this->centerTransformer = $centerTransformer;
}
/**
@ -48,7 +53,7 @@ class CreationPersonType extends AbstractType
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
if ($this->form_status === self::FORM_BEING_REVIEWED) {
if ($options['form_status'] === self::FORM_BEING_REVIEWED) {
$dateToStringTransformer = new DateTimeToStringTransformer(
null, null, 'd-m-Y', false);
@ -63,14 +68,17 @@ class CreationPersonType extends AbstractType
'mapped' => false
))
->add('form_status', 'hidden', array(
'mapped' => false
'mapped' => false,
'data' => $options['form_status']
))
->add('center', 'center')
->add('center', 'hidden')
;
$builder->get('birthdate')
->addModelTransformer($dateToStringTransformer);
$builder->get('creation_date', 'hidden')
$builder->get('creation_date')
->addModelTransformer($dateToStringTransformer);
$builder->get('center')
->addModelTransformer($this->centerTransformer);
} else {
$builder
->add('firstName')
@ -87,26 +95,29 @@ class CreationPersonType extends AbstractType
'mapped' => false,
'data' => new \DateTime()))
->add('form_status', 'hidden', array(
'data' => $this->form_status,
'data' => $options['form_status'],
'mapped' => false
))
->add('center', 'center')
;
}
}
private function setStatus($status) {
$this->form_status = $status;
}
/**
* @param OptionsResolverInterface $resolver
* @param OptionsResolver $resolver
*/
public function setDefaultOptions(OptionsResolverInterface $resolver)
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'Chill\PersonBundle\Entity\Person'
));
$resolver->setRequired('form_status')
->setAllowedValues('form_status', array(
self::FORM_BEING_REVIEWED,
self::FORM_NOT_REVIEWED,
self::FORM_REVIEWED
));
}
/**

View File

@ -56,3 +56,10 @@ services:
tags:
- { name: validator.constraint_validator, alias: birthdate_not_before }
chill.main.form.person_creation:
class: Chill\PersonBundle\Form\CreationPersonType
arguments:
- "@chill.main.form.data_transformer.center_transformer"
tags:
- { name: form.type, alias: chill_personbundle_person_creation }