Filter drupal自定义视图过滤器
第一次在stackoverflow上,所以,我会尽可能地说清楚 我正在使用Drupal7和Views3。 我需要创建一个自定义视图过滤器来处理日期范围。所以我看了这个例子,试着模仿这个行为,我遇到了一些麻烦。 似乎当我从views\u handler\u filter扩展我自己的类时,查询方法永远不会被调用,但是如果我从views\u handler\u filter\u string扩展我的类,它就可以正常工作 我必须忘记一些事情,但我被困在这里。。。 这是我的代码,如果有人能看一看并告诉我发生了什么,我将非常感激 谢谢大家 这是my.views.inc文件:Filter drupal自定义视图过滤器,filter,drupal-7,views,Filter,Drupal 7,Views,第一次在stackoverflow上,所以,我会尽可能地说清楚 我正在使用Drupal7和Views3。 我需要创建一个自定义视图过滤器来处理日期范围。所以我看了这个例子,试着模仿这个行为,我遇到了一些麻烦。 似乎当我从views\u handler\u filter扩展我自己的类时,查询方法永远不会被调用,但是如果我从views\u handler\u filter\u string扩展我的类,它就可以正常工作 我必须忘记一些事情,但我被困在这里。。。 这是我的代码,如果有人能看一看并告诉我发
<?php
class v3d_date_custom_filter extends views_handler_filter {
var $always_multiple = TRUE;
function value_form(&$form, &$form_state) {
//parent::value_form($form, $form_state);
$form['value']['v3d_date']['period'] = array(
'#type' => 'select',
'#title' => 'Period',
'#options' => array(
'7_days' => 'Last 7 days',
'yesterday' => 'Yesterday',
'today' => 'Today',
'custom' => 'Custom dates'),
'#default_value' => 'custom',
'#attributes' => array("onclick" => "period_click(this);"),
);
$form['value']['v3d_date']['start_date'] = array(
'#type' => 'date_popup',
'#date_format' => 'Y-m-d',
'#title' => 'Start date',
'#size' => 30);
$form['value']['v3d_date']['end_date'] = array(
'#type' => date_popup',
'#title' => 'End date',
'#date_format' => 'Y-m-d',
'#size' => 30);
}
function exposed_validate(&$form, &$form_state) {
if(is_null($form_state['values']['start_date']) &&
is_null($form_state['values']['start_date'])) {
return TRUE;
}
/*
* If we get array for start_date or end_date
* errors occured, but the date module will handle it.
*/
if(!is_string($form_state['values']['start_date']) ||
!is_string($form_state['values']['end_date'])) {
return TRUE;
}
/* Get day, month and year from start_date string */
if(!preg_match('/(\d+)-(\d+)-(\d+)/',
$form_state['values']['start_date'],
$start_date
)) {
return TRUE; }
/* Get day, month and year from end_date string */
if(!preg_match('/(\d+)-(\d+)-(\d+)/',
$form_state['values']['end_date'],
$end_date
)) {
return TRUE; }
/* Create timestamps and compare */
$start_date = mktime(0,0,0,$start_date[1],$start_date[2],$start_date[3]);
$end_date = mktime(0,0,0,$end_date[1],$end_date[2],$end_date[3]);
if($start_date >= $end_date) {
form_set_error('start_date','Start date must be anterior to end date.');
}
}
function query() {
die('fdsfds');
$this->ensure_my_table();
$field = "$this->table_alias.$this->real_field";
dsm($this);
}
}
?>
我正在处理同一个问题。我的设置与您的设置非常相似,尽管我确实在我的value\u表单
函数中调用了parent::value\u表单($form,$form\u state)
我发现在value_form函数中,我必须有
$form['value'] = array(
'#type' => 'checkbox',
'#title' => "Filter by Date",
'#default_value' => $this->value,
);
以便调用我的query()
函数。执行类似于数组(…
没用
<?php
function voice_views_data() {
$data['v_tp_voice']['date_utc_agent'] = array(
'title' => t('date_utc_agent'),
'help' => 'date_utc_agent',
'field' => array('handler' => 'views_handler_field'),
'filter' => array('handler' => 'v3d_date_custom_filter'),
'sort' => array('handler' => 'views_handler_sort')
);
$form['value'] = array(
'#type' => 'checkbox',
'#title' => "Filter by Date",
'#default_value' => $this->value,
);