<?php
// src/Form/EventListener/AddNameFieldSubscriber.php
namespace App\FormSubscriber;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\FormEvent;
use Symfony\Component\Form\FormEvents;
use Symfony\Component\Form\Form;
use Doctrine\ORM\EntityManagerInterface;
class GHMatrizEntrenamientoSubscriber implements EventSubscriberInterface {
private $entityManager;
public function __construct(
EntityManagerInterface $entityManager
) {
$this->entityManager = $entityManager;
}
public static function getSubscribedEvents(): array {
// Tells the dispatcher that you want to listen on the form.pre_set_data
// event and that the preSetData method should be called.
return [FormEvents::PRE_SUBMIT => 'preSubmit'];
}
public function preSubmit(FormEvent $event): void {
$data = $event->getData();
//data es un arreglo con los valores establecidos por el usuario en el form.
//como $data contiene el pais seleccionado por el usuario al enviar el formulario,
// usamos el valor de la posicion $data['country'] para filtrar el sql de los estados
if (isset($data['perfilCargo'])) {
$idBusqueda = $data['perfilCargo'];
$entity = $this->entityManager->getRepository(\App\Entity\GHPerfilCargo::class)->find($idBusqueda);
$event->getForm()->add('empresa', \Symfony\Bridge\Doctrine\Form\Type\EntityType::class, ['class' => \App\Entity\TerEmpresa::class, 'query_builder' => function (\Doctrine\ORM\EntityRepository $er) use ($idBusqueda) {
return $er->createQueryBuilder('se')
->leftJoin('se.perfilCargo', 'pc')
->where('se.nombre is null')
->orWhere('pc.id in (:idPerfil)')
->setParameter('idPerfil', $idBusqueda)
->orderBy('se.nombre', 'ASC');
}, 'label' => 'Empresa',
'label_attr' => ['class' => 'field_required'],
'attr' => ['class' => 'form-control'], 'placeholder' => 'Seleccione una Opción.'])
->add('sede', \Symfony\Bridge\Doctrine\Form\Type\EntityType::class, ['class' => \App\Entity\TerSedeEmpresa::class, 'query_builder' => function (\Doctrine\ORM\EntityRepository $er) use ($idBusqueda) {
return $er->createQueryBuilder('se')
->leftJoin('se.perfilCargos', 'pc')
->where('se.nombre is null')
->orWhere('pc.id in (:idPerfil)')
->setParameter('idPerfil', $idBusqueda)
->orderBy('se.nombre', 'ASC');
}, 'label' => 'Sucursal',
'label_attr' => ['class' => 'field_required'],
'attr' => ['class' => 'form-control'], 'placeholder' => 'Seleccione una Opción.'])
;
}
}
}