<?php
namespace App\MDS\VenuesBundle\Form;
use App\Entity\Client;
use App\Entity\DocContractModel;
use App\MDS\VenuesBundle\Entity\Reservation;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
use Symfony\Component\Form\Extension\Core\Type\IntegerType;
use Symfony\Component\Form\Extension\Core\Type\HiddenType;
use Symfony\Component\Form\Extension\Core\Type\DateType;
use Symfony\Component\Form\FormEvent;
use Symfony\Component\Form\FormEvents;
class ReservationType extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options): void
{
$builder
->add('title', TextType::class, [
'required' => true,
'label' => 'Title'
])
->add('sucoe', CheckboxType::class, [
'label' => '¿Es SUCOE?',
'required' => false,
// 'attr' => ['class' => 'switchery-info boolDelete'] // Se puede poner aquí o en la vista
])
->add('client', EntityType::class, [
'class' => Client::class,
'choice_label' => 'name',
'placeholder' => 'Select a client',
'required' => false,
'label' => 'Client',
])
// Si clientContact es una entidad, usa EntityType. Si es texto manual, TextType.
// Lo mantengo como Hidden para respetar tu lógica actual de JS, pero lo ideal es EntityType.
->add('clientContact', HiddenType::class)
// Campos "No registrados"
->add('contactUnregistered', TextType::class, [
'required' => false,
'label' => 'Correo electrónico'
])
->add('nameContactUnregistered', TextType::class, [
'required' => false,
'label' => 'Nombre y apellido'
])
->add('phoneContactUnregistered', TextType::class, [
'required' => false,
'label' => 'Teléfono'
])
->add('status', ChoiceType::class, [
'required' => false,
'choices' => [
'INICIADO' => 'Iniciado',
'BLOQUEO' => 'Bloqueo',
'CONFIRMADO' => 'Confirmed',
'COTIZADO' => 'Cotizado',
'FACTURADO *' => 'Invoiced',
'CANCELADO' => 'Deleted',
'PENDIENTE' => 'Pendiente',
],
'placeholder' => 'Select a status',
'label' => 'Status',
'choice_attr' => function($choice, $key, $value) use ($options) {
if ($value === 'Invoiced' && !$options['invoiced']) {
return ['disabled' => 'disabled'];
}
if ($value === 'Cotizado' && !$options['cotizable']) {
return ['disabled' => 'disabled'];
}
return [];
},
])
->add('daysBlock', IntegerType::class, [
'label' => 'Días de bloqueo',
'required' => false
])
// Usar DateType para que Symfony maneje la conversión de fecha automáticamente
->add('days', DateType::class, [
'widget' => 'single_text',
'html5' => true, // Renderiza <input type="date">
'required' => false,
'label' => 'Fecha límite bloqueo'
])
->add('dateNextMailAlert', DateType::class, [
'widget' => 'single_text',
'html5' => true,
'required' => false,
'label' => 'Fecha de próxima notificación',
'mapped' => false
])
->add('priority', HiddenType::class)
->add('contract', HiddenType::class) // Asumiendo que es un campo simple
->add('comHtGp', TextType::class, [
'required' => false,
'label' => 'Catering commission'
])
->add('description', TextareaType::class, [
'required' => false,
'label' => 'Description - Briefing',
'attr' => ['rows' => 7, 'class' => 'summernote']
])
->add('save', SubmitType::class, ['label' => 'Save']);
$builder->addEventListener(FormEvents::PRE_SET_DATA, function (FormEvent $event) {
/** @var Reservation|null $reservation */
$reservation = $event->getData();
$form = $event->getForm();
// Si $reservation es null (formulario sin datos iniciales) no hacemos nada.
if (!$reservation) {
return;
}
// Comprobamos si tiene ID. Si NO tiene ID, es una creación nueva.
if (null === $reservation->getId()) {
$form->add('pax', IntegerType::class, [
// 'mapped' => false, // No se guarda en la entidad Reservation automáticamente
'required' => false,
'label' => 'Personas Total',
'attr' => [
'placeholder' => 'Pax Total',
'class' => 'form-control' // Ayuda a que se vea bien en Bootstrap 3 por defecto
]
]);
}
});
}
public function configureOptions(OptionsResolver $resolver): void
{
$resolver->setDefaults([
'data_class' => Reservation::class,
// Permitimos pasar variables extra al formulario para la lógica de visualización
'allow_extra_fields' => true,
'confirmable' => false,
'cotizable' => false,
'invoiced' => false,
]);
$resolver->setAllowedTypes('confirmable', 'bool');
$resolver->setAllowedTypes('cotizable', 'bool');
$resolver->setAllowedTypes('invoiced', 'bool');
}
public function getBlockPrefix(): string
{
return 'mds_venuesbundle_reservation';
}
}