将“choice”选项添加到“entity”类型表单字段会使表单无效 - Symfony2

时间:2013-10-01 15:40:47

标签: php forms symfony doctrine-orm

我遇到了这个我无法解决的问题。

在我的一个表单中,需要过滤实体。

一些背景知识:

表单是将新任务添加到工作流程步骤。可以选择的任务取决于用户所处工作流程的哪个阶段,分配给工作流的产品以及管理该工作流的公司。

我尝试将过滤查询添加到'query_builder'部分,我尝试将实体存储库中的查询结果放入数组中的'choices'部分。

然而,表格总是回来说我正在处理的领域是无效的。最令人费解的部分是,如果没有“选择”字段,当它为该实体引入所有记录时,选择框完全相同(带有一些额外的记录) - 名称和模式如何书面。这很好。所以我完全不知道发生了什么。

表单元素代码:

->add('instructionAction', 'entity', array(
            'label' => 'Action',
            'empty_value' => 'Select Action',
            'required' => true,
            'class' => 'ApplicationTrackpadCommonBundle:InstructionAction',
            'property' => 'description',
            'choices' => $this->instructionActionRepository->findAllForCaseInstruction( $options['caseInstructionId'] )
            )
)

我不确定我可以发布多少代码来处理客户端工作。我使用的查询正确填充下拉框,就像没有查询一样,即使我选择了没有任何WHERE子句的所有实体,也会出现同样的问题。

感谢您的帮助。

2 个答案:

答案 0 :(得分:3)

这样的事情:

->add('instructionAction', 'entity', array(
    'required' => true,
    'class' => 'ApplicationTrackpadCommonBundle:InstructionAction',
    'query_builder' => function(EntityRepository $er) use ($user) {
        return $er->createQueryBuilder('c')
            ->where('c.user = :user')
            ->setParameter('user', $user)
            ->orderBy('c.name', 'ASC');
 }))

您可以使用use传递变量。

答案 1 :(得分:1)

您是否尝试使用“query_builder”而不是“choices”选项?我认为当您使用实体类型时,“queries_builder”会直接覆盖“choices”选项。如symfony文档here中所述 如果它仍然无效,我建议您查看this