X-Git-Url: https://git.rapsys.eu/airbundle/blobdiff_plain/76dd9123eb88b0d6117664dafaaa3d423bd0cce6..2884b5c8b4514b0e1c0dd0449db2af5be32382b6:/Form/SessionType.php

diff --git a/Form/SessionType.php b/Form/SessionType.php
index e7c238b..d6f1ba3 100644
--- a/Form/SessionType.php
+++ b/Form/SessionType.php
@@ -2,7 +2,8 @@
 
 namespace Rapsys\AirBundle\Form;
 
-use Symfony\Bridge\Doctrine\RegistryInterface;
+use Doctrine\Persistence\ManagerRegistry;
+use Symfony\Bridge\Doctrine\Form\Type\EntityType;
 use Symfony\Component\Form\AbstractType;
 use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
 use Symfony\Component\Form\Extension\Core\Type\DateType;
@@ -11,11 +12,12 @@ use Symfony\Component\Form\Extension\Core\Type\TimeType;
 use Symfony\Component\Form\FormBuilderInterface;
 use Symfony\Component\OptionsResolver\OptionsResolver;
 use Symfony\Component\Translation\TranslatorInterface;
-use Symfony\Component\Validator\Constraints\Date;
+use Symfony\Component\Validator\Constraints\Type;
 use Symfony\Component\Validator\Constraints\NotBlank;
-use Symfony\Component\Validator\Constraints\Time;
 
+use Rapsys\AirBundle\Entity\Dance;
 use Rapsys\AirBundle\Entity\Location;
+use Rapsys\AirBundle\Entity\Slot;
 use Rapsys\AirBundle\Entity\User;
 
 class SessionType extends AbstractType {
@@ -25,14 +27,19 @@ class SessionType extends AbstractType {
 	/**
 	 * {@inheritdoc}
 	 */
-	public function __construct(RegistryInterface $doctrine) {
+	public function __construct(ManagerRegistry $doctrine) {
 		$this->doctrine = $doctrine;
 	}
 
 	/**
+	 * @todo: clean that shit
+	 * @todo: mapped => false for each button not related with session !!!!
+	 * @todo: set stuff in the SessionController, no loggic here please !!!
+	 * @todo: add the dance link stuff
+	 *
 	 * {@inheritdoc}
 	 */
-	public function buildForm(FormBuilderInterface $builder, array $options) {
+	public function buildForm(FormBuilderInterface $builder, array $options): void {
 		//Is admin or user with rainfall >= 2
 		if (!empty($options['raincancel'])) {
 			//Add raincancel item
@@ -46,14 +53,21 @@ class SessionType extends AbstractType {
 		//Is admin or owner
 		if (!empty($options['modify'])) {
 			if (!empty($options['admin'])) {
-				$builder->add('date', DateType::class, ['attr' => ['placeholder' => 'Your date', 'class' => 'date'], 'html5' => true, 'input' => 'datetime', 'widget' => 'single_text', 'format' => 'yyyy-MM-dd', 'data' => $options['date'], 'constraints' => [new NotBlank(['message' => 'Please provide your date']), new Date(['message' => 'Your date doesn\'t seems to be valid'])]]);
+				$builder
+					//Add dance field
+					->add('dance', EntityType::class, ['class' => 'Rapsys\AirBundle\Entity\Dance', 'choices' => $options['dance_choices'], 'preferred_choices' => $options['dance_favorites'], 'attr' => ['placeholder' => 'Your dance'], 'choice_translation_domain' => true, 'constraints' => [new NotBlank(['message' => 'Please provide your dance'])], 'data' => $options['dance_default']])
+
+					//Add slot field
+					->add('slot', EntityType::class, ['class' => 'Rapsys\AirBundle\Entity\Slot', 'attr' => ['placeholder' => 'Your slot'], 'constraints' => [new NotBlank(['message' => 'Please provide your slot'])], 'choice_translation_domain' => true, 'data' => $options['slot_default']])
+					//Add date field
+					->add('date', DateType::class, ['attr' => ['placeholder' => 'Your date', 'class' => 'date'], 'html5' => true, 'input' => 'datetime', 'widget' => 'single_text', 'format' => 'yyyy-MM-dd', 'data' => $options['date'], 'constraints' => [new NotBlank(['message' => 'Please provide your date']), new Type(['type' => \DateTime::class, 'message' => 'Your date doesn\'t seems to be valid'])]]);
 			}
 
 			$builder
 				//TODO: avertissement + minimum et maximum ???
-				->add('begin', TimeType::class, ['attr' => ['placeholder' => 'Your begin', 'class' => 'time'], 'html5' => true, 'input' => 'datetime', 'widget' => 'single_text', 'data' => $options['begin'], 'constraints' => [new NotBlank(['message' => 'Please provide your begin']), new Time(['message' => 'Your begin doesn\'t seems to be valid'])]])
+				->add('begin', TimeType::class, ['attr' => ['placeholder' => 'Your begin', 'class' => 'time'], 'html5' => true, 'input' => 'datetime', 'widget' => 'single_text', 'data' => $options['begin'], 'constraints' => [new NotBlank(['message' => 'Please provide your begin']), new Type(['type' => \DateTime::class, 'message' => 'Your begin doesn\'t seems to be valid'])]])
 				//TODO: avertissement + minimum et maximum ???
-				->add('length', TimeType::class, ['attr' => ['placeholder' => 'Your length', 'class' => 'time'], 'html5' => true, 'input' => 'datetime', 'widget' => 'single_text', 'data' => $options['length'], 'constraints' => [new NotBlank(['message' => 'Please provide your length']), new Time(['message' => 'Your length doesn\'t seems to be valid'])]])
+				->add('length', TimeType::class, ['attr' => ['placeholder' => 'Your length', 'class' => 'time'], 'html5' => true, 'input' => 'datetime', 'widget' => 'single_text', 'data' => $options['length'], 'constraints' => [new NotBlank(['message' => 'Please provide your length']), new Type(['type' => \DateTime::class, 'message' => 'Your length doesn\'t seems to be valid'])]])
 				->add('modify', SubmitType::class, ['label' => 'Modify', 'attr' => ['class' => 'submit']]);
 		}
 
@@ -75,7 +89,7 @@ class SessionType extends AbstractType {
 		//Add extra user field
 		if (!empty($options['admin'])) {
 			//Load users
-			$users = $this->doctrine->getRepository(User::class)->findAllApplicantBySession($options['session']);
+			$users = $this->doctrine->getRepository(User::class)->findBySessionId($options['session']);
 			//Add admin fields
 			$builder
 				//TODO: class admin en rouge ???
@@ -90,34 +104,61 @@ class SessionType extends AbstractType {
 					->add('autoattribute', SubmitType::class, ['label' => 'Auto attribute', 'attr' => ['class' => 'submit']]);
 			}
 		}
-
-		//Return form
-		return $builder;
 	}
 
 	/**
 	 * {@inheritdoc}
 	 */
-	public function configureOptions(OptionsResolver $resolver) {
-		$resolver->setDefaults(['error_bubbling' => true, 'admin' => false, 'date' => null, 'begin' => null, 'length' => null, 'cancel' => false, 'raincancel' => false, 'modify' => false, 'move' => false, 'attribute' => false, 'user' => null, 'session' => null]);
+	public function configureOptions(OptionsResolver $resolver): void {
+		$resolver->setDefaults(['error_bubbling' => true, 'admin' => false, 'dance_choices' => [], 'dance_default' => null, 'dance_favorites' => [], 'date' => null, 'begin' => null, 'length' => null, 'cancel' => false, 'raincancel' => false, 'modify' => false, 'move' => false, 'attribute' => false, 'user' => null, 'session' => null, 'slot_default' => null]);
+
+		//Add admin
 		$resolver->setAllowedTypes('admin', 'boolean');
-		#TODO: voir si c'est le bon type
+
+		//Add dance choices
+		$resolver->setAllowedTypes('dance_choices', 'array');
+
+		//Add dance default
+		$resolver->setAllowedTypes('dance_default', [Dance::class, 'null']);
+
+		//Add dance favorites
+		$resolver->setAllowedTypes('dance_favorites', 'array');
+
+		//Add date
 		$resolver->setAllowedTypes('date', 'datetime');
+
+		//Add begin
 		$resolver->setAllowedTypes('begin', 'datetime');
+
+		//Add length
 		$resolver->setAllowedTypes('length', 'datetime');
+
+		//Add cancel
 		$resolver->setAllowedTypes('cancel', 'boolean');
+
+		//Add raincancel
 		$resolver->setAllowedTypes('raincancel', 'boolean');
+
+		//Add modify
 		$resolver->setAllowedTypes('modify', 'boolean');
+
+		//Add move
 		$resolver->setAllowedTypes('move', 'boolean');
+
+		//Add attribute
 		$resolver->setAllowedTypes('attribute', 'boolean');
+
+		//Add user
 		$resolver->setAllowedTypes('user', 'integer');
+
+		//Add session
 		$resolver->setAllowedTypes('session', 'integer');
 	}
 
 	/**
 	 * {@inheritdoc}
 	 */
-	public function getName() {
-		return 'rapsys_air_session_edit';
+	public function getName(): string {
+		return 'rapsysair_session_edit';
 	}
 }