src/Form/RegistrationFormType.php line 20

Open in your IDE?
  1. <?php
  2. namespace App\Form;
  3. use App\Entity\User;
  4. use Symfony\Component\Form\AbstractType;
  5. use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
  6. use Symfony\Component\Form\Extension\Core\Type\PasswordType;
  7. use Symfony\Component\Form\FormBuilderInterface;
  8. use Symfony\Component\OptionsResolver\OptionsResolver;
  9. use Symfony\Component\Validator\Constraints\IsTrue;
  10. use Symfony\Component\Validator\Constraints\Length;
  11. use Symfony\Component\Validator\Constraints\NotBlank;
  12. use Symfony\Component\Form\Extension\Core\Type\EmailType;
  13. use Symfony\Component\Form\Extension\Core\Type\TextType;use Symfony\Component\Form\FormEvent;
  14. use Symfony\Component\Form\FormEvents;
  15. use Symfony\Component\Form\FormError;
  16. use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
  17. class RegistrationFormType extends AbstractType
  18. {
  19.     public function buildForm(FormBuilderInterface $builder, array $options): void
  20.     {
  21.         $builder
  22.             ->add('firstName')
  23.             ->add('lastName')
  24.             ->add('companyName')
  25.             ->add('email'EmailType::class, [
  26.                 'required' => true,
  27.             ])
  28.             ->add('agreeTerms'CheckboxType::class, [
  29.                 'mapped' => false,
  30.                 'required' => true,
  31.                 'constraints' => [
  32.                     new IsTrue([
  33.                         'message' => 'You should agree to our terms.',
  34.                     ]),
  35.                 ],
  36.             ])
  37.             ->add('plainPassword'PasswordType::class, [
  38.                 // instead of being set onto the object directly,
  39.                 // this is read and encoded in the controller
  40.                 'mapped' => false,
  41.                 'required' => true,
  42.                 'attr' => ['autocomplete' => 'new-password'],
  43.                 'constraints' => [
  44.                     new NotBlank([
  45.                         'message' => 'Le mot de passe ne peut être vide',
  46.                     ]),
  47.                     new Length([
  48.                         'min' => 6,
  49.                         'minMessage' => 'Votre mot de passe doit avoir au moins {{ limit }} caractères',
  50.                         // max length allowed by Symfony for security reasons
  51.                         'max' => 4096,
  52.                     ]),
  53.                 ],
  54.             ])
  55.             ->add('phoneNumber'TextType::class, [
  56.                 'label' => 'Numéro de téléphone',
  57.                 'required' => true,
  58.                 'attr' => [
  59.                     'placeholder' => 'Entrez votre numéro de téléphone',
  60.                     'class' => 'phone-number'// Ajoutez une classe pour cibler le champ avec JS
  61.                 ],
  62.             ])
  63.             /*->add('wordpressUrl', TextType::class, [
  64.                 'required' => false,
  65.                 'attr' => [
  66.                     'placeholder' => 'https://www.votresite.fr',
  67.                 ],
  68.             ])
  69.             ->add('wordpressUsername', TextType::class, [
  70.                 'required' => false,
  71.                 'attr' => [
  72.                     'placeholder' => 'Nom d\'utilisateur admin du site wordpress',
  73.                 ],
  74.             ])
  75.             ->add('wordpressPassword', PasswordType::class, [
  76.                 'required' => false,
  77.                 'attr' => [
  78.                     'placeholder' => 'Mot de passe d\'application de votre site wordpress',
  79.                 ],
  80.             ])
  81.             ->add('seoPlugin', ChoiceType::class, [
  82.                 'choices' => [
  83.                     'YoastSEO' => 'yoastseo',
  84.                     'Rankmath' => 'rankmath',
  85.                 ],
  86.                 'expanded' => false, // false pour un dropdown, true pour des boutons radio
  87.                 'multiple' => false,  // false pour une seule sélection, true pour multi-sélection
  88.             ])
  89.             ->add('autoPublish')*/;
  90.     }
  91.     public function configureOptions(OptionsResolver $resolver): void
  92.     {
  93.         $resolver->setDefaults([
  94.             'data_class' => User::class,
  95.         ]);
  96.     }
  97. }