带有过滤器列表的symfony easyadmin表单字段类型实体

Joh*_* Rm 5 symfony easyadmin

我使用 symfony 3.4 和 easycorp/easyadmin-bundle 1.17

这是我的“Quotation”类,“artisan”字段是“Person”实体的“注册中”(person.type = 1):

class Quotation
{
/** others fields... */

/**
 *  1 => 'artisan', 2 => 'customer'
 */
private $type;

/**
 * @ORM\ManyToOne(targetEntity="Person", inversedBy="artisanQuotations", cascade= { "persist" })
 * @ORM\JoinColumn(name="artisan_id", referencedColumnName="id")
 */
private $artisan;

    /** getters and setters ... */
Run Code Online (Sandbox Code Playgroud)

我在使用自定义字段类型的表单字段时遇到问题

form:
    fields:
        ...
        - { property: 'artisan', label: '', type: 'AppBundle\Form\Field\ArtisanType' }
Run Code Online (Sandbox Code Playgroud)

我创建了这个表单字段类型,以便能够通过 query_builder 过滤列表:

public function buildForm(FormBuilderInterface $builder, array $options)
{
    $builder->add('artisan', EntityType::class, array(
        'class' => 'AppBundle:Person',
        'label' => false,
        'query_builder' => function(EntityRepository $er) {
            return $er->createQueryBuilder('person')
                ->where('person.type = 1');
        },
        'attr' => array('data-widget' => 'select2'),
        'multiple' => false,
        'expanded'=> false
    ));
}
Run Code Online (Sandbox Code Playgroud)

我的表单显示得很好,但是当我提交此表单时出现错误:

预期参数类型为“AppBundle\Entity\Person”,给定“array”

预先感谢您的帮助

kcm*_*kcm 4

您应该在此处使用configureOptions,而不是使用buildForm 方法。这样您的表单就不会被另一个产生数组的子表单扩展。

use Doctrine\ORM\EntityRepository;

use Symfony\Component\Form\AbstractType;
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
use Symfony\Component\OptionsResolver\OptionsResolver;

class ArtisanType extends AbstractType
{

    /**
    * @param \Symfony\Component\OptionsResolver\OptionsResolver $resolver
    */
    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults([
            'class' => 'AppBundle:Person',
            'label' => false,
            'query_builder' => function(EntityRepository $er) {
                return $er->createQueryBuilder('person')
                    ->where('person.type = 1');
            },
            'attr' => array('data-widget' => 'select2'),
            'multiple' => false,
            'expanded'=> false,
        ]);
    }

    /**
    * @return string|null
    */
    public function getParent()
    {
        return EntityType::class;
    }
}
Run Code Online (Sandbox Code Playgroud)