2

我想在表单类型类中调用函数。函数生成数组并写在实体存储库类中。使用该数组我将生成动态表单字段。这是实体存储库类功能。

public static $roleNameMap = array(
            self::ROLE_SUPER_ADMIN => 'superAdmin',
            self::ROLE_MANAGEMEN => 'management',
            self::ROLE_MANAGERS => 'manager',
            self::ROLE_IT_STAFF => 'itStaff',
            self::ROLE_CS_CUSTOMER => 'csCustomer',
            self::ROLE_CS => 'cs',
            self::ROLE_DEALER => 'dealer',
            self::ROLE_ACCOUNT_STAFF => 'accountStaff',
            self::ROLE_BROKER_USER => 'staff',
    );

    public function getGroupListArray()
        {
            $qb = $this->createQueryBuilder('g')
                ->orderBy('g.hierarchy','ASC');
            $query = $qb->getQuery();
            $groupList = $query->execute();
            $roleNameMap = array();
            foreach ($groupList as $role){
                $roleNameMap[$role->getId()] = $role->getRole();
            }

            return $roleNameMap;
        }

下面是我的表单构建器类,我想在其中调用实体存储库函数。

public function buildForm(FormBuilderInterface $builder, array $options) {

        $builder->add('routeId', 'hidden');

        foreach (GroupListRepository::$roleNameMap as $key=>$value){
            $builder->add($value, 'checkbox',array('label' => '', 'required' => false,));
        }       
    }

我能够获得如上面代码所示的静态变量,但是我很困惑我应该如何访问 symfony2 的表单构建器类中的存储库函数。

提前致谢。

4

2 回答 2

5

它在表单构建器中不可用,通常也没有必要。Symfony 表单也不是真正的工作方式。对于您想要做的事情,您可以尝试这样的事情。它将创建一个对应于角色列表的复选框列表。

$builder->add(
  'roles',
  'entity',
  array(
    'class' => 'Acme\DefaultBundle\Entity\Group',
    'expanded' => true,
    'multiple' => true,
    'property' => 'role', // Or use __toString()
    'query_builder' => function ($repository) {
      return $repository->createQueryBuilder('g')
        ->orderBy('g.hierarchy', 'ASC');
    }            
  )
);

请参阅http://symfony.com/doc/master/reference/forms/types/entity.html

如果您确实需要表单构建器中的存储库,则将表单类型创建为服务并将 DIC 注入实体管理器。或者在创建时直接将其传递给表单类型。

于 2013-05-21T08:16:34.903 回答
1

您不需要创建查询构建器函数,并且可以使用来自存储库的查询,如下所示:

在表格中:

'query_builder' => function(MyCustomEntityRepository $ttr) {
    return $ttr->queryForCustomResultsWithQueryBuilder();
}

在存储库中:

public function queryForCustomResultsWithQueryBuilder($published=true) {
    $queryBuilder =  $this->getEntityManager()->createQueryBuilder();

    return $queryBuilder->select('tt')
            ->from('ifm\CustomBundle\Entity\CustomEntity','tt')
            ->where('tt.published = ?1')
            ->orderBy('tt.code', 'ASC')
            ->setParameters(array(1=>$published))
    ;
}

请注意,queryForCustomResultsWithQueryBuilder 返回的是 QueryBuilder 而不是结果。如果您还需要结果,则需要在存储库中编写一个查找函数。

于 2016-09-21T12:01:09.103 回答