improve person creation to fix error handling

This commit is contained in:
Julien Fastré 2015-12-10 14:55:49 +01:00
parent 04c56f667a
commit 9fe0ae1889
2 changed files with 60 additions and 36 deletions

View File

@ -170,12 +170,12 @@ class PersonController extends Controller
->getGroupCenters()[0] ->getGroupCenters()[0]
->getCenter(); ->getCenter();
$person = (new Person()) $person = (new Person(new \DateTime('now')))
->setCenter($defaultCenter); ->setCenter($defaultCenter);
$form = $this->createForm( $form = $this->createForm(
new CreationPersonType(CreationPersonType::FORM_NOT_REVIEWED), new CreationPersonType(CreationPersonType::FORM_NOT_REVIEWED),
array('creation_date' => new \DateTime(), 'center' => $defaultCenter), $person,
array('action' => $this->generateUrl('chill_person_review')) array('action' => $this->generateUrl('chill_person_review'))
); );
@ -197,18 +197,22 @@ class PersonController extends Controller
*/ */
private function _bindCreationForm($form) private function _bindCreationForm($form)
{ {
$date = new \DateTime(); /**
$person = new Person($form['creation_date']->getData()); * @var Person
*/
$person = $form->getData();
$periods = $person->getAccompanyingPeriodsOrdered();
$date_of_birth = new \DateTime(); $period = $periods[0];
$period->setOpeningDate($form['creation_date']->getData());
$person->setFirstName($form['firstName']->getData()) // $person = new Person($form['creation_date']->getData());
->setLastName($form['lastName']->getData()) //
->setGender($form['gender']->getData()) // $person->setFirstName($form['firstName']->getData())
->setBirthdate($form['birthdate']->getData()) // ->setLastName($form['lastName']->getData())
->setCenter($form['center']->getData()) // ->setGender($form['gender']->getData())
; // ->setBirthdate($form['birthdate']->getData())
// ->setCenter($form['center']->getData())
// ;
return $person; return $person;
} }
@ -251,15 +255,18 @@ class PersonController extends Controller
$form = $this->createForm( $form = $this->createForm(
new CreationPersonType(CreationPersonType::FORM_BEING_REVIEWED), new CreationPersonType(CreationPersonType::FORM_BEING_REVIEWED),
null, array('action' => $this->generateUrl('chill_person_create'))); new Person(),
array('action' => $this->generateUrl('chill_person_create')));
$form->handleRequest($request); $form->handleRequest($request);
$person = $this->_bindCreationForm($form); $person = $this->_bindCreationForm($form);
var_dump($person);
$errors = $this->_validatePersonAndAccompanyingPeriod($person); $errors = $this->_validatePersonAndAccompanyingPeriod($person);
$this->get('logger')->info(sprintf('Person created with %d errors ', count($errors)));
if ( count($errors) > 0) {
if ($errors->count() > 0) {
$this->get('logger')->info('The created person has errors');
$flashBag = $this->get('session')->getFlashBag(); $flashBag = $this->get('session')->getFlashBag();
$translator = $this->get('translator'); $translator = $this->get('translator');
@ -271,11 +278,14 @@ class PersonController extends Controller
$form = $this->createForm( $form = $this->createForm(
new CreationPersonType(CreationPersonType::FORM_NOT_REVIEWED), new CreationPersonType(CreationPersonType::FORM_NOT_REVIEWED),
array('action' => $this->generateUrl('chill_person_create'))); new Person(),
array('action' => $this->generateUrl('chill_person_review')));
$form->handleRequest($request); $form->handleRequest($request);
return $this->_renderNewForm($form); return $this->_renderNewForm($form);
} else {
$this->get('logger')->info('Person created without errors');
} }
$em = $this->getDoctrine()->getManager(); $em = $this->getDoctrine()->getManager();
@ -331,7 +341,7 @@ class PersonController extends Controller
$form = $this->createForm(new CreationPersonType()); $form = $this->createForm(new CreationPersonType());
$form->handleRequest($request); $form->handleRequest($request);
var_dump($form->getData());
$person = $this->_bindCreationForm($form); $person = $this->_bindCreationForm($form);
$errors = $this->_validatePersonAndAccompanyingPeriod($person); $errors = $this->_validatePersonAndAccompanyingPeriod($person);
@ -349,7 +359,11 @@ class PersonController extends Controller
return $this->redirect($this->generateUrl('chill_person_general_edit', return $this->redirect($this->generateUrl('chill_person_general_edit',
array('person_id' => $person->getId()))); array('person_id' => $person->getId())));
} else { } else {
$r = new Response('this should not happen if you reviewed your submission'); $text = "this should not happen if you reviewed your submission\n";
foreach ($errors as $error) {
$text .= $error->getMessage()."\n";
}
$r = new Response($text);
$r->setStatusCode(400); $r->setStatusCode(400);
return $r; return $r;
} }

View File

@ -24,9 +24,7 @@ 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\OptionsResolverInterface; use Symfony\Component\OptionsResolver\OptionsResolverInterface;
use Chill\PersonBundle\Form\Type\CivilType;
use Chill\PersonBundle\Form\Type\GenderType; use Chill\PersonBundle\Form\Type\GenderType;
use CL\BelgianNationalNumberBundle\Form\BelgianNationalNumberType;
use Symfony\Component\Form\Extension\Core\DataTransformer\DateTimeToStringTransformer; use Symfony\Component\Form\Extension\Core\DataTransformer\DateTimeToStringTransformer;
class CreationPersonType extends AbstractType class CreationPersonType extends AbstractType
@ -53,20 +51,26 @@ class CreationPersonType extends AbstractType
if ($this->form_status === self::FORM_BEING_REVIEWED) { if ($this->form_status === self::FORM_BEING_REVIEWED) {
$dateToStringTransformer = new DateTimeToStringTransformer( $dateToStringTransformer = new DateTimeToStringTransformer(
null, null, 'dd-MM-yyyy', true); null, null, 'd-m-Y', false);
$builder->add('firstName', 'hidden') $builder->add('firstName', 'hidden')
->add('lastName', 'hidden') ->add('lastName', 'hidden')
->add( $builder->create('birthdate', 'hidden') ->add('birthdate', 'hidden', array(
->addModelTransformer($dateToStringTransformer) 'property_path' => 'birthdate'
) ))
->add('gender', 'hidden') ->add('gender', 'hidden')
->add( $builder->create('creation_date', 'hidden') ->add('creation_date', 'hidden', array(
->addModelTransformer($dateToStringTransformer) 'mapped' => false
) ))
->add('form_status', 'hidden') ->add('form_status', 'hidden', array(
'mapped' => false
))
->add('center', 'center') ->add('center', 'center')
; ;
$builder->get('birthdate')
->addModelTransformer($dateToStringTransformer);
$builder->get('creation_date', 'hidden')
->addModelTransformer($dateToStringTransformer);
} else { } else {
$builder $builder
->add('firstName') ->add('firstName')
@ -76,10 +80,16 @@ class CreationPersonType extends AbstractType
->add('gender', new GenderType(), array( ->add('gender', new GenderType(), array(
'required' => true, 'empty_value' => null 'required' => true, 'empty_value' => null
)) ))
->add('creation_date', 'date', array('required' => true, ->add('creation_date', 'date', array(
'widget' => 'single_text', 'format' => 'dd-MM-yyyy', 'required' => true,
'widget' => 'single_text',
'format' => 'dd-MM-yyyy',
'mapped' => false,
'data' => new \DateTime())) 'data' => new \DateTime()))
->add('form_status', 'hidden', array('data' => $this->form_status)) ->add('form_status', 'hidden', array(
'data' => $this->form_status,
'mapped' => false
))
->add('center', 'center') ->add('center', 'center')
; ;
} }
@ -94,9 +104,9 @@ class CreationPersonType extends AbstractType
*/ */
public function setDefaultOptions(OptionsResolverInterface $resolver) public function setDefaultOptions(OptionsResolverInterface $resolver)
{ {
// $resolver->setDefaults(array( $resolver->setDefaults(array(
// 'data_class' => 'Chill\PersonBundle\Entity\Person' 'data_class' => 'Chill\PersonBundle\Entity\Person'
// )); ));
} }
/** /**