improve activity form

- create as a service with required depedencies (required for scope)
- add scope
- fix date show
- adapt controller accordingly
This commit is contained in:
Julien Fastré 2015-07-02 23:36:43 +02:00
parent 86b24f58ac
commit be78c25091
4 changed files with 102 additions and 13 deletions

View File

@ -27,6 +27,8 @@ use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Chill\ActivityBundle\Entity\Activity; use Chill\ActivityBundle\Entity\Activity;
use Chill\ActivityBundle\Form\ActivityType; use Chill\ActivityBundle\Form\ActivityType;
use Symfony\Component\Security\Core\Role\Role;
use Chill\PersonBundle\Entity\Person;
/** /**
* Activity controller. * Activity controller.
@ -59,6 +61,12 @@ class ActivityController extends Controller
$em = $this->getDoctrine()->getManager(); $em = $this->getDoctrine()->getManager();
$person = $em->getRepository('ChillPersonBundle:Person')->find($person_id); $person = $em->getRepository('ChillPersonBundle:Person')->find($person_id);
/**if ($person === NULL) {
throw $this->createNotFoundException('person not found');
}*/
$this->denyAccessUnlessGranted('CHILL_PERSON_SEE', $person);
$entity = new Activity(); $entity = new Activity();
$form = $this->createCreateForm($entity, $person); $form = $this->createCreateForm($entity, $person);
$form->handleRequest($request); $form->handleRequest($request);
@ -85,12 +93,16 @@ class ActivityController extends Controller
* *
* @return \Symfony\Component\Form\Form The form * @return \Symfony\Component\Form\Form The form
*/ */
private function createCreateForm(Activity $entity, $person) private function createCreateForm(Activity $entity, Person $person)
{ {
$form = $this->createForm(new ActivityType(), $entity, array( $form = $this->createForm('chill_activitybundle_activity', $entity,
'action' => $this->generateUrl('chill_activity_activity_create', ['person_id' => $person->getId()]), array(
'method' => 'POST', 'action' => $this->generateUrl('chill_activity_activity_create', ['person_id' => $person->getId()]),
)); 'method' => 'POST',
'center' => $person->getCenter(),
'role' => new Role('CHILL_ACTIVITY_CREATE')
)
);
$form->add('submit', 'submit', array('label' => 'Create')); $form->add('submit', 'submit', array('label' => 'Create'));

View File

@ -99,7 +99,7 @@ class Activity
* *
* @return Activity * @return Activity
*/ */
public function setUserr(User $user) public function setUser(User $user)
{ {
$this->user = $user; $this->user = $user;

View File

@ -4,10 +4,57 @@ namespace Chill\ActivityBundle\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\OptionsResolver;
use Chill\MainBundle\Form\Type\AppendScopeChoiceTypeTrait;
use Chill\MainBundle\Security\Authorization\AuthorizationHelper;
use Doctrine\Common\Persistence\ObjectManager;
use Chill\MainBundle\Templating\TranslatableStringHelper;
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
use Chill\MainBundle\Entity\User;
class ActivityType extends AbstractType class ActivityType extends AbstractType
{ {
use AppendScopeChoiceTypeTrait;
/**
* the user running this form
*
* @var User
*/
protected $user;
/**
*
* @var AuthorizationHelper
*/
protected $authorizationHelper;
/**
*
* @var ObjectManager
*/
protected $om;
/**
*
* @var TranslatableStringHelper
*/
protected $translatableStringHelper;
public function __construct(TokenStorageInterface $tokenStorage,
AuthorizationHelper $authorizationHelper, ObjectManager $om,
TranslatableStringHelper $translatableStringHelper)
{
if (!$tokenStorage->getToken()->getUser() instanceof User) {
throw new \RuntimeException("you should have a valid user");
}
$this->user = $tokenStorage->getToken()->getUser();
$this->authorizationHelper = $authorizationHelper;
$this->om = $om;
$this->translatableStringHelper = $translatableStringHelper;
}
/** /**
* @param FormBuilderInterface $builder * @param FormBuilderInterface $builder
* @param array $options * @param array $options
@ -15,26 +62,46 @@ class ActivityType extends AbstractType
public function buildForm(FormBuilderInterface $builder, array $options) public function buildForm(FormBuilderInterface $builder, array $options)
{ {
$builder $builder
->add('date') ->add('date', 'date', array(
'required' => true,
'widget' => 'single_text',
'format' => 'dd-MM-yyyy')
)
->add('durationTime') ->add('durationTime')
->add('remark') ->add('remark', 'textarea', array(
->add('attendee') 'required' => false,
'empty_data' => ''
))
->add('attendee', 'choice', array(
'expanded' => true,
'required' => false,
'choices' => array(
true => 'present',
false => 'not present'
)
))
->add('user') ->add('user')
//->add('scope') //->add('scope')
//->add('reason') //->add('reason')
//->add('type') //->add('type')
//->add('person') //->add('person')
; ;
$this->appendScopeChoices($builder, $options['role'],
$options['center'], $this->user, $this->authorizationHelper,
$this->translatableStringHelper, $this->om);
} }
/** /**
* @param OptionsResolverInterface $resolver * @param OptionsResolverInterface $resolver
*/ */
public function setDefaultOptions(OptionsResolverInterface $resolver) public function configureOptions(OptionsResolver $resolver)
{ {
$resolver->setDefaults(array( $resolver->setDefaults(array(
'data_class' => 'Chill\ActivityBundle\Entity\Activity' 'data_class' => 'Chill\ActivityBundle\Entity\Activity'
)); ));
$this->appendScopeChoicesOptions($resolver);
} }
/** /**

View File

@ -1,7 +1,17 @@
services: services:
chill.activity.form.type.translatableactivityreasoncategory: chill.activity.form.type.translatableactivityreasoncategory:
class: Chill\ActivityBundle\Form\Type\TranslatableActivityReasonCategory class: Chill\ActivityBundle\Form\Type\TranslatableActivityReasonCategory
arguments: arguments:
- "@request_stack" - "@request_stack"
tags: tags:
- { name: form.type, alias: translatable_activity_reason_category } - { name: form.type, alias: translatable_activity_reason_category }
chill.activity.form.type.activity:
class: Chill\ActivityBundle\Form\ActivityType
arguments:
- "@security.token_storage"
- "@chill.main.security.authorization.helper"
- "@doctrine.orm.entity_manager"
- "@chill.main.helper.translatable_string"
tags:
- { name: form.type, alias: chill_activitybundle_activity }