Вопрос

Я проходил через документы и исходный код, ищущего чего-то без удачи.

Есть ли Drupal 6 крюк, который вызывается после Took_Search (), но до того, как результаты $ передаются в систему шаблона?

Мне нужно сделать довольно настраиваемое обрезку и переупорядочение результатов, которые возвращаются. Я мог просто переосмыслить Cook_Search (), но это похоже на излишки.

Спасибо.

Это было полезно?

Решение

Нет; search_view() (который отображает результаты) звонки search_data(), что вызывает hook_search() Затем немедленно темы результаты. Повторное реализация hook_search() Вероятно, самый простой маршрут.

С этим сказанным, вы могли вместо этого реализовать hook_menu_alter() и попросите страницу поиска вызывают вашу пользовательскую функцию вместо звонка search_view() (и впоследствии звонить search_data()). Что-то вроде:

function test_menu_alter(&$items) {
  $items['search']['page callback'] = 'test_search_view';

  foreach (module_implements('search') as $name) {
    $items['search/' . $name . '/%menu_tail']['page callback'] = 'test_search_view';
  }
}

// Note: identical to search_view except for --- CHANGED ---
function test_search_view($type = 'node') {
  // Search form submits with POST but redirects to GET. This way we can keep
  // the search query URL clean as a whistle:
  // search/type/keyword+keyword
  if (!isset($_POST['form_id'])) {
    if ($type == '') {
      // Note: search/node can not be a default tab because it would take on the
      // path of its parent (search). It would prevent remembering keywords when
      // switching tabs. This is why we drupal_goto to it from the parent instead.
      drupal_goto('search/node');
    }

    $keys = search_get_keys();
    // Only perform search if there is non-whitespace search term:
    $results = '';
    if (trim($keys)) {
      // Log the search keys:
      watchdog('search', '%keys (@type).', array('%keys' => $keys, '@type' => module_invoke($type, 'search', 'name')), WATCHDOG_NOTICE, l(t('results'), 'search/'. $type .'/'. $keys));

      // Collect the search results:
      // --- CHANGED --- 
      // $results = search_data($keys, $type);
      // Instead of using search_data, use our own function
      $results = test_search_data($keys, $type);
      // --- END CHANGED ---

      if ($results) {
        $results = theme('box', t('Search results'), $results);
      }
      else {
        $results = theme('box', t('Your search yielded no results'), search_help('search#noresults', drupal_help_arg()));
      }
    }

    // Construct the search form.
    $output = drupal_get_form('search_form', NULL, $keys, $type);
    $output .= $results;

    return $output;
  }

  return drupal_get_form('search_form', NULL, empty($keys) ? '' : $keys, $type);
}

// Note: identical to search_data() except for --- CHANGED ---
function test_search_data($keys = NULL, $type = 'node') {

  if (isset($keys)) {
    if (module_hook($type, 'search')) {
      $results = module_invoke($type, 'search', 'search', $keys);
      if (isset($results) && is_array($results) && count($results)) {
        // --- CHANGED ---
        // This dsm() is called immediately after hook_search() but before
        // the results get themed. Put your code here.
        dsm($results);
        // --- END CHANGED ---

        if (module_hook($type, 'search_page')) {
          return module_invoke($type, 'search_page', $results);
        }
        else {
          return theme('search_results', $results, $type);
        }
      }
    }
  }
}

Другие советы

Ты можешь использовать hook_search_page() Чтобы изменить порядок или отформатировать результат поиска.

Крюк Search_Execute позволяет вам изменить запрос в том, как вам нужно. Вы можете даже выстрелить новые запросы с пользовательским SQL, например:

function mymodule_search_execute($keys = NULL, $conditions = NULL) {

      // Do some query here.
      $result = my_fancy_query();

      // Results in a Drupal themed way for search.
      $results[] = array(
        'link' => (string) $result->U,
        'title' => $title,
        'snippet' => $snippet,
        'keys' => check_plain($keys),
        'extra' => array($extra),
        'date' => NULL,
      );
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top