Drupal,视图公开过滤器:包含结果的列表选项

问题描述 投票:2回答:4

我正在建立一个公寓搜索网站,并为“房产类型”公开了一个视图过滤器。属性类型是一个包含16个选项的选择字段,但客户端只希望那些实际包含结果的选项出现在公开过滤器的下拉列表中。

有任何想法吗?

谢谢!

drupal-6 views
4个回答
0
投票

您可以使用form_alter,查看:http://drupal.org/node/463990http://drupal.org/project/better_exposed_filters,了解暴露过滤器的特定用途。


0
投票

这就是你想要的http://drupal.org/project/views_hacks#views_filters_selective

视图选择性公开过滤器在列表和复选框公开过滤器上,您可以指定过滤器选项“将列表限制为结果集”,以仅显示视图结果中实际返回的值。过滤器选项“进一步限制列表到活动过滤器”限制显示的值以查看通过应用公开过滤器值获得的结果。


0
投票

在Drupal 8中,我只能使用以下代码显示带有结果的标签。请注意,我正在使用Better Exposed Filters contrib模块,并将我的过滤器显示为Select。

function mymodule_form_views_exposed_form_alter(&$form, FormStateInterface $form_state, $form_id) {
  if ($form['#id'] == 'views-exposed-form-your-view-name-page') {

    if (array_key_exists('field_activities_target_id', $form)) {
      // Rewrite the default 'All' option
      if (!empty($form['field_activities_target_id']['#options']['All'])) {
        $option_default = ['All' => t('Choose a category')];
      }

      $options = $form['field_activities_target_id']['#options'];

      $connection = Database::getConnection();
      $query = $connection->select('node__field_activities', 'activities');
      $query->join('node_field_data', 'n', 'n.nid = activities.entity_id');
      $query->fields('activities', ['field_activities_target_id']);
      $query->fields('n', ['status']);
      $query->condition('activities.bundle', 'your_node_type_name');
      $query->condition('n.status', 1);
      $data = $query->distinct()->execute();

      $results = array_flip($data->fetchAll(\PDO::FETCH_COLUMN, 'field_activities_target_id'));
      $options = array_intersect_key($options, $results);

      // Rebuild the option select
      $form['field_activities_target_id']['#options'] = $option_default + $options;
    }
  }
}

这篇文章是一个很好的帮助:https://johndevman.com/only-show-options-in-a-views-exposed-filter-that-belong-to-result-set/


0
投票

对于Drupal 8,我发现这个模块非常有用:https://www.drupal.org/project/selective_better_exposed_filters

这适用于基于taxonomy term的字段。

© www.soinside.com 2019 - 2024. All rights reserved.