Метод запиту не запускається у користувальницькій обробці фільтрів?


9

Я використовую перегляди 3 .

Мені потрібно було створити спеціальний фільтр переглядів, який обробляє діапазон дат. Тому я переглянув приклад і намагався імітувати поведінку, і у мене виникли певні проблеми.

Здається, що коли я розширюю власний клас з views_handler_filter, метод запиту ніколи не викликається, АЛЕ якщо я розширюю свій клас, скажімо, views_handler_filter_stringвін працює.

Я повинен щось забути, але я застряг тут.

Ось мій код, якщо хтось може поглянути і порадити мене, що сталося, я був би дуже вдячний.

Ось мій .views.incфайл:

<?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);
   }

 }
?>

І мій .moduleфайл

<?php
  function custom_filters_views_api() {
    return array(
      'api'=>3,
      'path' => drupal_get_path('module','custom_filters') . '/views',
    );
  }
?>

І частина моєї, views_dataяка використовує мій спеціальний фільтр:

<?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')
  );

  return $data;
}

На яке поле відображає спеціальний фільтр (поле api або спеціальна таблиця).
Матханкумар

1
це погляд sql (v_tp_voice), узятий із зовнішньої бази даних, що називається рівним. тож я картографую на власну таблицю.
d4rkfl4sh

1
Не знаю, як це може спровокувати описаний ефект, але я завжди вважав, що клас фільтра повинен міститись в окремому файлі і на нього посилатися і у вашому .info-файлі. З питання не зрозуміло, чи це так.
Берлінер

так, ви повинні продовжити! (aka у чому ваша проблема?)
rémy

Чому б не використовувати модуль поля дати? Він має інтеграцію підмодуля з видами. Я не впевнений, що він зробить все, що завгодно, але, можливо, варто спробувати.
Тодінов

Відповіді:


1

Як запропонував todinov , ви можете використовувати модулі вкладення Drupal Date разом із підмодулем Date Views, який, швидше за все, обробляє будь-який фільтр у Views. Якщо це не допомагає, ви можете досягти цього за допомогою коду, застосувавши крюк_все_query_alter .

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.