]> Raphaël G. Git Repositories - blogbundle/blob - Form/ContactType.php
Add form_theme template
[blogbundle] / Form / ContactType.php
1 <?php declare(strict_types=1);
2
3 /*
4 * This file is part of the Rapsys BlogBundle package.
5 *
6 * (c) Raphaël Gertz <symfony@rapsys.eu>
7 *
8 * For the full copyright and license information, please view the LICENSE
9 * file that was distributed with this source code.
10 */
11
12 namespace Rapsys\BlogBundle\Form;
13
14 use Symfony\Component\Form\FormBuilderInterface;
15 use Symfony\Component\OptionsResolver\OptionsResolver;
16 use Symfony\Component\Form\Extension\Core\Type\TextType;
17 use Symfony\Component\Form\Extension\Core\Type\TextareaType;
18 use Symfony\Component\Form\Extension\Core\Type\EmailType;
19 use Symfony\Component\Form\Extension\Core\Type\SubmitType;
20 use Symfony\Component\Validator\Constraints\Email;
21 use Symfony\Component\Validator\Constraints\NotBlank;
22
23 use Rapsys\PackBundle\Form\CaptchaType;
24
25 class ContactType extends CaptchaType {
26 /**
27 * {@inheritdoc}
28 */
29 public function buildForm(FormBuilderInterface $builder, array $options): void {
30 //Add fields
31 $builder
32 ->add('name', TextType::class, ['attr' => ['placeholder' => 'Your name'], 'constraints' => [new NotBlank(['message' => 'Please provide your name'])]])
33 ->add('subject', TextType::class, ['attr' => ['placeholder' => 'Subject'], 'constraints' => [new NotBlank(['message' => 'Please provide your subject'])]])
34 ->add('mail', EmailType::class, ['attr' => ['placeholder' => 'Your mail'], 'constraints' => [new NotBlank(['message' => 'Please provide a valid mail']), new Email(['message' => 'Your mail doesn\'t seems to be valid'])]])
35 ->add('message', TextareaType::class, ['attr' => ['placeholder' => 'Your message', 'cols' => 50, 'rows' => 15], 'constraints' => [new NotBlank(['message' => 'Please provide your message'])]])
36 ->add('submit', SubmitType::class, ['label' => 'Send', 'attr' => ['class' => 'submit']]);
37
38 //Call parent
39 parent::buildForm($builder, $options);
40 }
41
42 /**
43 * {@inheritdoc}
44 */
45 public function configureOptions(OptionsResolver $resolver): void {
46 //Set defaults
47 $resolver->setDefaults(['error_bubbling' => true]);
48 }
49
50 /**
51 * {@inheritdoc}
52 */
53 public function getName() {
54 return 'contact_form';
55 }
56 }