无法以编程方式在视图Drupal 7中为日期设置公开过滤器

时间:2015-01-13 08:00:04

标签: drupal-7 drupal-views

我正在尝试从我创建的视图中获取数据。我已经暴露了nid和另一个名为uid的字段,当我对它们应用过滤器时它们正常工作。然而,还有另一个暴露的过滤器“field_date”,它与drupal的ui一起工作,但在我的客户模块中没有以编程方式工作。这是一个日期戳字段。我的代码示例如下。传递的值采用unix时间戳格式。

    views_include('view');
    $name = Rest::$DAILY_LOGS_VIEW;
    $display = Rest::$DAILY_LOGS_VIEW_PAGE;

    $alter = array('exposed' =>array('field_uid_value' => $uid));
    if(!empty($nid)) $alter['exposed']['nid'] = (int) $nid;

    //if(!empty($from_date)) $alter['exposed']['field_date_value_1']['min'] = (int) $from_date;
    //if(!empty($to_date)) $alter['exposed']['field_date_value_1']['max'] = (int) $to_date;
    //if(!empty($to_date)) $alter['exposed']['field_date_value_1[max]'] = (int) $to_date;

    if(!empty($date)) $alter['exposed']['field_date_value'] = (int) $date;

    $view = views_get_view($name);
    $view->init_display($display);
    $view->preview=TRUE;
    $view->is_cacheable = FALSE;

    if(isset($alter['exposed'])) {
      foreach($alter['exposed'] as $key => $valor) {
         $view->exposed_input[$key] = $valor;
      }
    }

    $view->init_pager();
    $view->pager['items_per_page']               = $count;
    $view->pager['use_pager']                    = true;
    $view->display_handler->options['use_pager'] = true;
    $view->set_items_per_page($count);
    $view->pager['current_page'] = $page;

    $view->pre_execute();
    $output = $view->display_handler->preview();
    $view->post_execute();

    return $view->result;

所以我在这里有两个问题。

为日期格式的过滤器提供正确的格式是什么?

具有日期“介于”值之间的过滤器的格式是什么,即最小值和最大值?

2 个答案:

答案 0 :(得分:1)

我遇到了同样的问题,并设法使用此方法修复它:

$view->exposed_input[$key]["value"]["month"] = $month;
$view->exposed_input[$key]["value"]["year"] = $year;

不确定是否需要" Day"同样,但我选择了"月"关于粒度

答案 1 :(得分:1)

回答第二部分:格式化为过滤器提供日期"在"之间值,即最小值和最大值:

我安装了日期模块,并将过滤器设为

if(!empty($from_date)) $view->exposed_input['field_date_value']['min']['date']= $from_date;
if(!empty($to_date)) $view->exposed_input['field_date_value']['max']['date']= $to_date;