Форма Symfony: коллекция фильтров с параметром - PullRequest
0 голосов
/ 19 ноября 2018

Я использую Symfony 3.4.

У меня есть форма для редактирования некоторых ответов для данной страны, и мне нужно будет редактировать эти ответы для каждой категории.

У меня есть настройкафильтр в моей сущности, но я не знаю, как вызвать этот метод получения с параметром из моей формы.

Грязной альтернативой было бы удаление ненужных элементов из моей формы в моем контроллере, но это не идеально...

Вот моя форма:

<?php

namespace cwt\psmdbBundle\Form;

use cwt\psmdbBundle\Entity\CcdbServicesAnswers;
use cwt\psmdbBundle\Entity\countries;

use Doctrine\ORM\EntityRepository;
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Form\Extension\Core\Type\CollectionType;

class countriesCCDBServicesAnswersType extends AbstractType
{

    /**
     * @param FormBuilderInterface $builder
     * @param array $options
     */
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('AnswersOfCategory', CollectionType::class, array(
                'entry_type' => CcdbServicesAnswersType::class,
                'entry_options' => array('label' => false,),
                'label' => false,
            ));    
    }

    /**
     * @param OptionsResolver $resolver
     */
    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults(array(
            'data_class' => 'cwt\psmdbBundle\Entity\countries',
            'categoryID' => 1,
        ));
    }

    /**
     * @return string
     */
    public function getBlockPrefix()
    {
        return 'cwt_psmdbbundle_countries';
    }
}

Вот моя сущность:

<?php

namespace cwt\psmdbBundle\Entity;

use APY\DataGridBundle\Grid\Mapping as GRID;
use Doctrine\ORM\Mapping as ORM;

/**
 * countries
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="cwt\psmdbBundle\Entity\Repository\countriesRepository")
 */
class countries
{
    /**
     * @var integer
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
     * @var string
     *
     * @ORM\Column(name="code", type="string", length=2)
     */
    private $code;

    /**
     * @var string
     *
     * @ORM\Column(name="name", type="string", length=100)
     */
    private $name;    

    /**
     * @ORM\OneToMany(targetEntity="cwt\psmdbBundle\Entity\CcdbServicesAnswers", mappedBy="country", cascade={"persist", "remove"})
     */
    private $ccdbServicesAnswers;


// Specific Functions

    /**
     * Get ccdbServicesAnswers.
     *
     * @return \Doctrine\Common\Collections\Collection
     */
    public function getAnswersOfCategory($categoryID)
    {

        return $this->getCcdbServicesAnswers()->filter(function(CcdbServicesAnswers $answer) use($categoryID) {
            return $answer->getQuestion()->getCategory()->getId() == $categoryID;
        });
    }

А вот моя функция создания формы в моем контроллере:

private function createCountryEditForm(Countries $entity, $categoryID)
{
    $form = $this->createForm(countriesCCDBServicesAnswersType::class, $entity, array(
        'action' => $this->generateUrl('updateCountryCcdbServicesAnswers', array('countryID' => $entity->getId())),
        'method' => 'PUT',
        'categoryID' => $categoryID,
    ));

    $form->add('submit', submitType::class, array('label' => 'Update', 'attr' => array('class' => 'hidden')));

    return $form;
}

[ОБНОВЛЕНИЕ 20/11/2018]

Вот что я сделал до сих пор.Эта работа, но я бы предпочел более чистое решение, которое имеет дело с этим фильтром с предложением where на уровне базы данных и которое было бы более СУХОЙ.Выполнение этого на уровне контроллера означает, что я должен делать это везде, где мне нужен этот фильтр.

private function createCountryEditForm(Countries $entity, $categoryID)
{
    $form = $this->createForm(countriesCCDBServicesAnswersType::class, $entity, array(
        'action' => $this->generateUrl('updateCountryCcdbServicesAnswers', array('countryID' => $entity->getId(), 'categoryID' => $categoryID)),
        'method' => 'PUT',
        'categoryID' => $categoryID,
    ));

    $answers = $form->get('ccdbServicesAnswers')->getData();


    foreach ($answers as $answer) {

        if($answer->getQuestion()->getCategory()->getId() != $categoryID) {
            $answers->removeElement($answer);
        }

    }

    $form->get('ccdbServicesAnswers')->setData($answers);

    $form->add('submit', submitType::class, array('label' => 'Update', 'attr' => array('class' => 'hidden')));

    return $form;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...