]> Raphaƫl G. Git Repositories - userbundle/blobdiff - Form/RegisterType.php
Add bundle translations
[userbundle] / Form / RegisterType.php
index 71a0dcd8742e0f4834e9cf55aeeaf0829ca94cf8..00c17b2d53c173f53d07d8fd8c7d6fab48e6b3b1 100644 (file)
 
 namespace Rapsys\UserBundle\Form;
 
 
 namespace Rapsys\UserBundle\Form;
 
+use Rapsys\PackBundle\Form\CaptchaType;
+
+use Rapsys\UserBundle\Entity\Civility;
+
 use Symfony\Bridge\Doctrine\Form\Type\EntityType;
 use Symfony\Bridge\Doctrine\Form\Type\EntityType;
-use Symfony\Component\Form\AbstractType;
+use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
 use Symfony\Component\Form\Extension\Core\Type\EmailType;
 use Symfony\Component\Form\Extension\Core\Type\PasswordType;
 use Symfony\Component\Form\Extension\Core\Type\RepeatedType;
 use Symfony\Component\Form\Extension\Core\Type\EmailType;
 use Symfony\Component\Form\Extension\Core\Type\PasswordType;
 use Symfony\Component\Form\Extension\Core\Type\RepeatedType;
@@ -23,54 +27,74 @@ use Symfony\Component\OptionsResolver\OptionsResolver;
 use Symfony\Component\Validator\Constraints\Email;
 use Symfony\Component\Validator\Constraints\NotBlank;
 
 use Symfony\Component\Validator\Constraints\Email;
 use Symfony\Component\Validator\Constraints\NotBlank;
 
-use Rapsys\UserBundle\Entity\Civility;
-
-class RegisterType extends AbstractType {
+/**
+ * {@inheritdoc}
+ */
+class RegisterType extends CaptchaType {
        /**
         * {@inheritdoc}
         */
        /**
         * {@inheritdoc}
         */
-       public function buildForm(FormBuilderInterface $builder, array $options): FormBuilderInterface {
-               //Create form
-               $form = $builder;
-
+       public function buildForm(FormBuilderInterface $builder, array $options): void {
                //Add extra mail field
                if (!empty($options['mail'])) {
                //Add extra mail field
                if (!empty($options['mail'])) {
-                       $form->add('mail', EmailType::class, ['attr' => ['placeholder' => 'Your mail'], 'constraints' => [new NotBlank(['message' => 'Please provide your mail']), new Email(['message' => 'Your mail doesn\'t seems to be valid'])], 'required' => true]);
+                       $builder->add('mail', EmailType::class, ['attr' => ['placeholder' => 'Your mail'], 'constraints' => [new NotBlank(['message' => 'Please provide your mail']), new Email(['message' => 'Your mail doesn\'t seems to be valid'])], 'required' => true]);
                }
 
                //Add extra password field
                if (!empty($options['password'])) {
                }
 
                //Add extra password field
                if (!empty($options['password'])) {
-                       $form->add('password', RepeatedType::class, ['type' => PasswordType::class, 'invalid_message' => 'The password and confirmation must match', 'first_options' => ['attr' => ['placeholder' => 'Your password'], 'label' => 'Password'], 'second_options' => ['attr' => ['placeholder' => 'Your password confirmation'], 'label' => 'Confirm password'], 'options' => ['constraints' => [new NotBlank(['message' => 'Please provide your password'])]], 'required' => true]);
+                       //Add password repeated field
+                       if (!empty($options['password_repeated'])) {
+                               $builder->add('password', RepeatedType::class, ['type' => PasswordType::class, 'invalid_message' => 'The password and confirmation must match', 'first_options' => ['attr' => ['placeholder' => 'Your password'], 'label' => 'Password'], 'second_options' => ['attr' => ['placeholder' => 'Your password confirmation'], 'label' => 'Confirm password'], 'options' => ['constraints' => [new NotBlank(['message' => 'Please provide your password'])]], 'required' => true]);
+                       //Add password field
+                       } else {
+                               $builder->add('password', PasswordType::class, ['attr' => ['placeholder' => 'Your password'], 'constraints' => [new NotBlank(['message' => 'Please provide your password'])], 'required' => true]);
+                       }
                }
 
                //Add extra civility field
                if (!empty($options['civility'])) {
                }
 
                //Add extra civility field
                if (!empty($options['civility'])) {
-                       $form->add('civility', EntityType::class, ['class' => $options['civility_class'], 'attr' => ['placeholder' => 'Your civility'], 'choice_translation_domain' => true, 'empty_data' => $options['civility_default'], 'required' => true]);
+                       $builder->add('civility', EntityType::class, ['class' => $options['civility_class'], 'attr' => ['placeholder' => 'Your civility'], 'choice_translation_domain' => true, 'empty_data' => $options['civility_default'], 'required' => true]);
                }
 
                //Add extra forename field
                if (!empty($options['forename'])) {
                }
 
                //Add extra forename field
                if (!empty($options['forename'])) {
-                       $form->add('forename', TextType::class, ['attr' => ['placeholder' => 'Your forename']]);
+                       $builder->add('forename', TextType::class, ['attr' => ['placeholder' => 'Your forename']]);
                }
 
                //Add extra surname field
                if (!empty($options['surname'])) {
                }
 
                //Add extra surname field
                if (!empty($options['surname'])) {
-                       $form->add('surname', TextType::class, ['attr' => ['placeholder' => 'Your surname']]);
+                       $builder->add('surname', TextType::class, ['attr' => ['placeholder' => 'Your surname']]);
+               }
+
+               //Add extra active field
+               if (!empty($options['active'])) {
+                       $builder->add('active', CheckboxType::class, ['attr' => ['placeholder' => 'Your active']]);
+               }
+
+               //Add extra enable field
+               if (!empty($options['enable'])) {
+                       $builder->add('enable', CheckboxType::class, ['attr' => ['placeholder' => 'Your enable']]);
                }
 
                //Add submit
                }
 
                //Add submit
-               $form->add('submit', SubmitType::class, ['label' => 'Send', 'attr' => ['class' => 'submit']]);
+               $builder->add('submit', SubmitType::class, ['label' => 'Send', 'attr' => ['class' => 'submit']]);
 
 
-               //Return form
-               return $form;
+               //Call parent
+               parent::buildForm($builder, $options);
        }
 
        /**
         * {@inheritdoc}
         */
        public function configureOptions(OptionsResolver $resolver): void {
        }
 
        /**
         * {@inheritdoc}
         */
        public function configureOptions(OptionsResolver $resolver): void {
+               //Call parent configure options
+               parent::configureOptions($resolver);
+
                //Set defaults
                //Set defaults
-               $resolver->setDefaults(['error_bubbling' => true, 'civility_class' => 'RapsysUserBundle:Civility', 'civility_default' => null, 'mail' => true, 'civility' => true, 'forename' => true, 'surname' => true, 'password' => true]);
+               $resolver->setDefaults(['error_bubbling' => true, 'civility' => true, 'civility_class' => 'RapsysUserBundle:Civility', 'civility_default' => null, 'mail' => true, 'password' => true, 'password_repeated' => true, 'forename' => true, 'surname' => true, 'active' => false, 'enable' => false]);
+
+               //Add extra civility option
+               $resolver->setAllowedTypes('civility', 'boolean');
 
                //Add civility class
                $resolver->setAllowedTypes('civility_class', 'string');
 
                //Add civility class
                $resolver->setAllowedTypes('civility_class', 'string');
@@ -82,8 +106,11 @@ class RegisterType extends AbstractType {
                //Add extra mail option
                $resolver->setAllowedTypes('mail', 'boolean');
 
                //Add extra mail option
                $resolver->setAllowedTypes('mail', 'boolean');
 
-               //Add extra civility option
-               $resolver->setAllowedTypes('civility', 'boolean');
+               //Add extra password option
+               $resolver->setAllowedTypes('password', 'boolean');
+
+               //Add extra password repeated option
+               $resolver->setAllowedTypes('password_repeated', 'boolean');
 
                //Add extra forename option
                $resolver->setAllowedTypes('forename', 'boolean');
 
                //Add extra forename option
                $resolver->setAllowedTypes('forename', 'boolean');
@@ -91,14 +118,17 @@ class RegisterType extends AbstractType {
                //Add extra surname option
                $resolver->setAllowedTypes('surname', 'boolean');
 
                //Add extra surname option
                $resolver->setAllowedTypes('surname', 'boolean');
 
-               //Add extra password option
-               $resolver->setAllowedTypes('password', 'boolean');
+               //Add extra active option
+               $resolver->setAllowedTypes('active', 'boolean');
+
+               //Add extra enable option
+               $resolver->setAllowedTypes('enable', 'boolean');
        }
 
        /**
         * {@inheritdoc}
         */
        public function getName(): string {
        }
 
        /**
         * {@inheritdoc}
         */
        public function getName(): string {
-               return 'rapsys_user_register';
+               return 'rapsysuser_register';
        }
 }
        }
 }