我有一张表heading
,其中有import_profile_id
。 import_profile
有一个bank_id
。
在我的管理员的标题列表页面上,我想添加按bank_id
过滤的功能。但是,由于heading
没有bank_id
- 它需要通过import_profile
才能获得 - 我不能只添加bank_id
字段并期望它工作
任何人都可以解释如何做到这一点?我发现最接近的是this post,但我不认为它真的解决了我的问题。
答案 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了解过滤器。