我正在尝试从我创建的视图中获取数据。我已经暴露了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;
所以我在这里有两个问题。
为日期格式的过滤器提供正确的格式是什么?
具有日期“介于”值之间的过滤器的格式是什么,即最小值和最大值?
答案 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;