多选外键过滤器

时间:2011-05-23 01:43:21

标签: symfony1 filter admin generator

我正在尝试在symfony admin中的外键上设置多选过滤器。我认为我已经正确设置了所有内容但由于某种原因它无法正常工作:

public function configure()
{
    parent::configure();

    $s = Doctrine_Query::create()->
      from('Status s')->
      execute();

    $status_choices = array();
    foreach ($s as $key => $value) {
        $status_choices[$value->getId()] = $value->getName();
    }

    $this->widgetSchema['status_id'] = new sfWidgetFormChoice(array('choices' => $status_choices, 'multiple' => true, 'expanded' => true));

    $this->validatorSchema['status_id'] = new sfValidatorChoice(array('required' => false, 'choices' => $status_choices, 'multiple' => true));



}

public function getFields()
{

    $fields = parent::getFields();
    $fields['status_id'] = 'StatusId';
    return $fields;

}

public function addStatusIdQuery(Doctrine_Query $query, $field, $values)
{
    $fieldName = $this->getFieldName($field);

  if (!empty($values))
  {
        $query->addWhereIn(sprintf('%s.%s', $query->getRootAlias(), $fieldName), $values);
  }
}

非常感谢任何帮助......

1 个答案:

答案 0 :(得分:2)

在validatorSchema中,要验证发布的数据,必须使用array_keys($ status_choices) 因为发布表单后发送的值是键而不是标签。

并且addWhereIn不是Doctrine_Query方法,使用andWhereIn或whereIn

希望能帮到你