带连接的symfony admin过滤器

时间:2011-03-28 15:57:24

标签: symfony1

我有一张表heading,其中有import_profile_idimport_profile有一个bank_id

在我的管理员的标题列表页面上,我想添加按bank_id过滤的功能。但是,由于heading没有bank_id - 它需要通过import_profile才能获得 - 我不能只添加bank_id字段并期望它工作

任何人都可以解释如何做到这一点?我发现最接近的是this post,但我不认为它真的解决了我的问题。

1 个答案:

答案 0 :(得分:16)

这可以通过使用虚拟列(如您找到的帖子)来完成。虚拟列是一种使用symfony提供的自动生成过滤器添加新条件进行过滤的方法。它的工作原理如下:

1 - 转到admin模块的generator.yml并添加将创建并添加的虚拟列的名称

<!-- apps/backend/modules/module_name/config/generator.yml -->
filter:
     [virtual_column_name, and, other, filter, columns]

2 - 在你的lib / filter / {TableName} FormFilter.class.php中(我认为你的情况必须是HeadingFormFilter)你必须在 configure()方法中定义该虚拟列< / p>

  public function configure()
  {
      //Type of widget (could be sfWidgetFormChoice with bank names)
      $this->widgetSchema['virtual_column_name'] =  new sfWidgetFormInputText(array(
          'label' => 'Virtual Column Label'
      ));

      //Type of validator for filter
      $this->validatorSchema['virtual_column_name'] = new sfValidatorPass(array ('required' => false));
  }

3 - 覆盖该类的 getFields()以在过滤器中定义它并设置过滤器功能

public function getFields()
{
  $fields = parent::getFields();
  //the right 'virtual_column_name' is the method to filter
  $fields['virtual_column_name'] = 'virtual_column_name';
  return $fields;
}

4 - 最后你必须定义过滤方法。此方法必须以添加... ColumnQuery 模式命名,在我们的例子中必须是addVirtualColumnNameColumnQuery(不是一个快乐的名字选择:P),所以

public function addVirtualColumnNameColumnQuery($query, $field, $value)
{
     //add your filter query!
     //for example in your case
     $rootAlias = $query->getRootAlias();
     $query->innerJoin($rootAlias . '.ImportProfile ip')
           ->andWhere('ip.BankId = ?', $value);

     //remember to return the $query!
     return $query;
}

完成!您可以通过bank_id了解过滤器。