Pregunta

He estado yendo a través de la documentación y código fuente en busca de algo sin suerte.

¿Hay un gancho Drupal 6 que es llamada después de hook_search (), pero antes de que los resultados $ consigue entregan al sistema de plantillas?

tengo que hacer una poda y la reordenación de los resultados que consiguen devueltos bastante personalizado. Pude hook_search simplemente reimplementar (), pero esto parece un exceso.

Gracias.

¿Fue útil?

Solución

No hay; search_view() (que muestra los resultados) llamadas search_data() , que invoca hook_search() luego inmediatamente temas los resultados. Re-implementando hook_search() es probablemente la ruta más directa.

Con esto dicho, en su lugar podría aplicar hook_menu_alter() y tienen la búsqueda página llame a su función personalizada en lugar de llamar search_view() (y posteriormente llamar search_data()). Algo así como:

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

Otros consejos

Se puede utilizar hook_search_page() Para reordenar o formatear el resultado de búsqueda.

search_execute gancho le permite modificar la consulta en la forma en que sea necesario. Incluso puede disparar nuevas consultas con SQL personalizado, por ejemplo:

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,
      );
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top