首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >表单提交后,Symfony使用查询生成器更改下拉值

表单提交后,Symfony使用查询生成器更改下拉值
EN

Stack Overflow用户
提问于 2017-09-22 14:55:36
回答 1查看 857关注 0票数 0

我想过滤一个下拉列表,这取决于我在之前的4次下拉列表中所做的选择。我的表单类型看起来是这样的:

代码语言:javascript
运行
复制
class DocumentDeactivationType extends AbstractType {

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

    $builder
    ->add('type', 'choice', array('choices' => array(
        'document_types.contract' => 1,
        'document_types.general'=>2,
        'document_types.goodwill_policy'=>3,
        'document_types.pricesheet'=>4,
        'document_types.yq_update'=>5,
        'document_types.contract_addendum'=>6),
        'choices_as_values' => true, 'label' => 'label.types',
        'expanded' => false, 'multiple' => true,
        'label' => 'label.type', 'required' => false,
        'translation_domain' => 'Documents'))

    -> add('status', 'entity', array(
      'class' => 'DocumentBundle:Status', 'property' => 'name',
      'choice_label' => 'translationkey', 'label' => 'Status',
      'expanded' => false, 'multiple' => true, 'required' => false,
      'translation_domain' => 'Documents',
      'choice_translation_domain' => 'Documents',))


    ->add('airlines', 'entity', array(
      'class' => 'AppBundle:Airline', 'property' => 'id',
      'query_builder' => function (EntityRepository $er){
       return $er->createQueryBuilder('a')
       ->addOrderBy('a.id', 'ASC');
       },
      'choice_value' => 'id',
      'choice_label' => 'id', 'label' => 'label.airlines',
      'expanded' => false, 'multiple' => true, 'required' => false,
      'translation_domain' => 'Documents'))

    ->add('markets', 'entity', array(
        'class' => 'AppBundle:Market', 'property' => 'id',
        'query_builder' => function (EntityRepository $er){
         return $er->createQueryBuilder('m')
         ->addOrderBy('m.id', 'ASC');
         },
        'choice_value' => 'id',
        'choice_label' => 'id', 'label' => 'label.markets',
        'expanded' => false, 'multiple' => true, 'required' => false,
        'translation_domain' => 'Documents'))

    ->add('documentlist', EntityType::class, array(
        'class' => 'DocumentBundle:Document',
        'property' => 'name',
        'expanded' => false, 'multiple' => true,
        'label' => 'label.document_list',
        'empty_value' => "Select document",
        'required' => false,
        'mapped' => false,
        'translation_domain' => 'Documents'));

  $builder->addEventListener(FormEvents::PRE_SUBMIT, function (FormEvent $event) use ($builder)
      {
        $form = $event->getForm();
        $data = $event->getData();
        $markets = $data['markets'];
        $status = $data['status'];
        $type = $data['type'];
        $airlines = $data['airlines'];
    $builder
    ->add('documentlist', EntityType::class, array(
        'class' => 'DocumentBundle:Document',
        'property' => 'name',
        'expanded' => false, 'multiple' => true,
        'label' => 'label.document_list',
        'empty_value' => "Select document",
        'required' => false,
        'mapped' => false,
        'translation_domain' => 'Documents',

        'query_builder' => function (EntityRepository $er) use ($markets, $status, $type, $airlines){
        return $er->createQueryBuilder('e')
        ->where('e.markets IN (:markets)')
        ->andWhere('e.status IN (:status)')
        ->andWhere('e.airlines IN (:airlines)')
        ->andWhere('e.products IN (:products)')
        ->setParameter('markets', $markets)
        ->setParameter('status', $status)
        ->setParameter('airlines', $airlines)
        ->setParameter('type', $type);
      },
      ));
  });
}
    public function getName()
    {
        return 'document_deactivation';

    }
  }

我不确定这是否很明显:“documentlist”下拉列表已经存在,其中包含了文档实体中的所有值,而我试图通过PRE_SUBMIT EventListener实现的是根据其他4个下拉列表中的选择更新它的值。对于这4个下拉列表有一个“应用”按钮,所以我不需要ajax请求,但是我想是Post/PreSubmit事件吗?我的问题:

  1. 当从" filter“下拉列表中选择一些值时,例如忽略了‘市场’,我会得到”未定义的市场指数“的错误,这可能是因为行$markets = $data'markets‘->所以我想要的是能够只对某些类型进行筛选,而不是被迫选择所有类型。
  2. 更新文档列表下拉列表根本不起作用。我甚至不认为查询生成器正在做任何事情。但我不确定这是否与我的FormEvent有关,或者可能是我将下拉列表添加到表单中的方式。

如何在我的小枝文件中呈现所有内容:

代码语言:javascript
运行
复制
    {% block filterContent %}
  {{ form_start(form) }}
  {{ form_row(form.type) }}
  {{ form_row(form.status) }}
  {{ form_row(form.markets)}}
  {{ form_row(form.airlines)}}
    <input type="submit" class="btn-primary btn btn-xs" value="Apply Filter" />

  <br clear="all" />
{% endblock %}

{% block content %}

{{ form_label(form.documentlist) }}
{{ form_widget(form.documentlist) }}
{{ form_end(form) }} </br>

<div class="row">
  {% include 'AppBundle::HelpSubmitButton.html.twig' with { 'buttonName': 'label.submit'|trans } %}
</div>
{% endblock content %}
EN

回答 1

Stack Overflow用户

发布于 2017-09-26 21:09:11

1)在$market周围添加一个if语句

代码语言:javascript
运行
复制
if (isset($data['markets'])) {$markets = $data['markets'];}

代码语言:javascript
运行
复制
'query_builder' => function (EntityRepository $er) use ($markets, $status, $type, $airlines) {
    $query =  $er->createQueryBuilder('e')
    ->where('e.status IN (:status)')
    ->andWhere('e.airlines IN (:airlines)')
    ->andWhere('e.products IN (:products)')
    ->setParameter('markets', $markets)
    ->setParameter('status', $status)
    ->setParameter('airlines', $airlines)
    ->setParameter('type', $type);
  };

   if (isset($data['markets'])) {
     $query->andWhere('e.markets IN (:markets)')
   }

2)我相信您需要通过AJAX更新列表,因为PRE_SUBMIT将发生在submit操作之前,因此它将使用documentlist中的所有值。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46367653

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档