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

时间:2010-09-02 14:04:04

标签: drupal-6 views

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

有什么想法吗?

谢谢!

4 个答案:

答案 0 :(得分:0)

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

答案 1 :(得分:0)

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

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

答案 2 :(得分:0)

在Drupal 8中,我只能使用以下代码显示带有结果的标签。 请注意,我正在使用“更好的暴露过滤器”贡献模块,并将我的过滤器显示为“选择”。

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/

答案 3 :(得分:0)

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

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