私は運がないものを探してドキュメントとソースコードを調べてきました。
hook_search() の後、$results がテンプレート システムに渡される前に呼び出される Drupal 6 フックはありますか?
返される結果のかなりカスタムなプルーニングと並べ替えを行う必要があります。hook_search() を再実装することもできますが、これはやり過ぎのようです。
ありがとう。
私は運がないものを探してドキュメントとソースコードを調べてきました。
hook_search() の後、$results がテンプレート システムに渡される前に呼び出される Drupal 6 フックはありますか?
返される結果のかなりカスタムなプルーニングと並べ替えを行う必要があります。hook_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,
);