我目前正在开发一个带有两个主要捆绑包的Symfony应用程序(v2.8):EasyAdmin和FOSUserBundle。
我有一个具有特定角色的用户,我使用带有数组的"findBy"来检索这些用户。
我想覆盖我的管理控制器的表单,用这些用户填写选择的表单选项。我知道用数组可以做到这一点,但如果我添加或删除一些用户,我想要一些动态的东西。
我不知道如何从我的一个控制器调用一个函数(或者我必须将其声明为服务吗?)来添加从查询中选择表单的选项。
下面是我想要的一个例子:
$formBuilder->add('field_to_override', 'choice', array(
'choices' => **my_function**,
'multiple' => true,
'expanded' => true,
));
我希望我的解释清楚。
提前谢谢!
考虑使用EntityType字段,这是一种特殊形式的Choice字段,使用Doctrine实体进行选择。
也可以为选项指定自定义查询,例如
$builder->add('users', EntityType::class, array(
'class' => 'AppBundle:User',
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('u')
->orderBy('u.username', 'ASC');
},
));