Index: apachesolr_search.module =================================================================== RCS file: /cvs/drupal-contrib/contributions/modules/apachesolr/apachesolr_search.module,v retrieving revision 1.1.2.6.2.78 diff -u -p -r1.1.2.6.2.78 apachesolr_search.module --- apachesolr_search.module 23 Feb 2009 03:40:37 -0000 1.1.2.6.2.78 +++ apachesolr_search.module 19 Mar 2009 18:24:03 -0000 @@ -372,46 +372,75 @@ function apachesolr_search_block($op = ' if ((strpos($delta, 'im_vid_') === 0) && module_exists('taxonomy')) { if (is_object($response->facet_counts->facet_fields->$delta)) { - $contains_active = FALSE; - $terms = array(); + $vid = substr($delta, 7); + if (is_numeric($vid)) { + $vocab = taxonomy_vocabulary_load($vid); + $terms = array(); + + $reflect_hierarchy = variable_get('apachesolr_facet_reflect_hierarchy', array()); + $reflect_hierarchy = $reflect_hierarchy['apachesolr_search'][$delta]; + + foreach ($response->facet_counts->facet_fields->$delta as $tid => $count) { + $unclick_link = ''; + unset($active); + + $parents = array(); + if ($reflect_hierarchy) { + $parents = taxonomy_get_parents_all($tid); + if (!empty($parents[1]) && !$query->has_field('tid', $parents[1]->tid)) { + continue; + } + } + else { + $parents[] = taxonomy_get_term($tid); + } - foreach ($response->facet_counts->facet_fields->$delta as $tid => $count) { - $unclick_link = ''; - unset($active); - $term = taxonomy_get_term($tid); - $new_query = clone $query; - if ($active = $query->has_field('tid', $tid)) { - $contains_active = TRUE; - $new_query->remove_field('tid', $term->tid); - $path = 'search/' . arg(1) . '/' . $new_query->get_query_basic(); - $querystring = $new_query->get_url_querystring(); - $unclick_link = theme('apachesolr_unclick_link', $path, $querystring); - } - else { - $new_query->add_field('tid', $term->tid); - $path = 'search/' . arg(1) . '/' . $new_query->get_query_basic(); - $querystring = $new_query->get_url_querystring(); - } - $countsort = $count == 0 ? '' : 1 / $count; - // if numdocs == 1 and !active, don't add. - if ($response->numFound == 1 && !$active) { - // skip + $new_query = clone $query; + + if ($active = $query->has_field('tid', $tid)) { + $new_query->remove_field('tid', $tid); + if ($reflect_hierarchy) { + $childs = taxonomy_get_tree($vid, $tid); + foreach ($childs as $child) { + $new_query->remove_field('tid', $child->tid); + } + } + $path = 'search/' . arg(1) . '/' . $new_query->get_query_basic(); + $querystring = $new_query->get_url_querystring(); + $unclick_link = theme('apachesolr_unclick_link', $path, $querystring); + } + else { + $new_query->add_field('tid', $tid); + $path = 'search/' . arg(1) . '/' . $new_query->get_query_basic(); + $querystring = $new_query->get_url_querystring(); + } + // if numdocs == 1 and !active, don't add. + if ($response->numFound == 1 && !$active) { + // skip + } + else { + $sort_key = ''; + $term = NULL; + foreach (array_reverse($parents) as $term) { + $count = $response->facet_counts->facet_fields->$delta->{$term->tid}; + $countsort = $count == 0 ? '' : 1 / $count; + $countsort = $active ? $countsort : 1 + $countsort; + $sort_key .= $countsort.$term->name; + } + $terms[$term->vid][$sort_key] = theme('apachesolr_facet_item', $term->name, $count, $path, $querystring, $active, $unclick_link, $response->numFound, count($parents) - 1); + } } - else { - $terms[$term->vid][$active ? $countsort . $term->name : 1 + $countsort . $term->name] = theme('apachesolr_facet_item', $term->name, $count, $path, $querystring, $active, $unclick_link, $response->numFound); + + if (is_array($terms) && isset($terms[$vid]) && is_array($terms[$vid])) { + ksort($terms[$vid]); + $limit = isset($initial_limits['apachesolr_search'][$delta]) ? $initial_limits['apachesolr_search'][$delta] : $limit_default; + return array( + 'subject' => t('Filter by @name', array('@name' => $vocab->name)), + 'content' => theme('apachesolr_facet_list', $terms[$vid], $limit), + ); } } } - $vid = substr($delta, 7); - $vocab = taxonomy_vocabulary_load($vid); - if (is_numeric($vid) && is_array($terms) && isset($terms[$vid]) && is_array($terms[$vid])) { - ksort($terms[$vid]); - $limit = isset($initial_limits['apachesolr_search'][$delta]) ? $initial_limits['apachesolr_search'][$delta] : $limit_default; - return array( - 'subject' => t('Filter by @name', array('@name' => $vocab->name)), - 'content' => theme('apachesolr_facet_list', $terms[$vid], $limit), - ); - } return; } Index: apachesolr.module =================================================================== RCS file: /cvs/drupal-contrib/contributions/modules/apachesolr/apachesolr.module,v retrieving revision 1.1.2.12.2.116 diff -u -p -r1.1.2.12.2.116 apachesolr.module --- apachesolr.module 18 Mar 2009 22:52:38 -0000 1.1.2.12.2.116 +++ apachesolr.module 19 Mar 2009 18:24:03 -0000 @@ -735,6 +735,14 @@ function apachesolr_facetcount_form($mod '#default_value' => isset($limits[$module][$delta]) ? $limits[$module][$delta] : variable_get('apachesolr_facet_query_limit_default', 20), ); + $reflect_hierarchy = variable_get('apachesolr_facet_reflect_hierarchy', array()); + $form['apachesolr_facet_reflect_hierarchy'] = array( + '#type' => 'checkbox', + '#title' => t('Links reflect hierarchy'), + '#description' => t('Facet will be sorted hierarchically if it bases on a hierarchical taxonomy vocabulary.'), + '#default_value' => !empty($reflect_hierarchy[$module][$delta]), + ); + return $form; } @@ -752,6 +760,9 @@ function apachesolr_facetcount_save($edi $initial = variable_get('apachesolr_facet_query_initial_limits', array()); $initial[$module][$delta] = (int)$edit['apachesolr_facet_query_initial_limit']; variable_set('apachesolr_facet_query_initial_limits', $initial); + $reflect_hierarchy = variable_get('apachesolr_facet_reflect_hierarchy', array()); + $reflect_hierarchy[$module][$delta] = $edit['apachesolr_facet_reflect_hierarchy']; + variable_set('apachesolr_facet_reflect_hierarchy', $reflect_hierarchy); } /** @@ -969,6 +980,9 @@ function apachesolr_theme() { 'apachesolr_facet_item' => array( 'arguments' => array('name' => NULL, 'count' => NULL, 'path' => NULL, 'querystring' => '', 'active' => FALSE, 'unclick_link' => NULL, 'num_found' => NULL), ), + 'apachesolr_facet_item_indent' => array( + 'arguments' => array('indent' => 0), + ), 'apachesolr_unclick_link' => array( 'arguments' => array('url' => NULL, 'querystring' => ''), ), @@ -984,16 +998,24 @@ function apachesolr_theme() { ); } -function theme_apachesolr_facet_item($name, $count, $path, $querystring = '', $active = FALSE, $unclick_link = NULL, $num_found = NULL) { +function theme_apachesolr_facet_item($name, $count, $path, $querystring = '', $active = FALSE, $unclick_link = NULL, $num_found = NULL, $indent = 0) { $attributes = array(); if ($active) { $attributes['class'] = 'active'; } + $link = ''; if ($unclick_link) { - return $unclick_link . ' '. check_plain($name); + $link = $unclick_link . ' '. check_plain($name); } else { - return apachesolr_l($name ." ($count)", $path, array('attributes' => $attributes, 'query' => $querystring)); + $link = apachesolr_l($name ." ($count)", $path, array('attributes' => $attributes, 'query' => $querystring)); + } + return theme('apachesolr_facet_item_indent', $indent).$link; +} + +function theme_apachesolr_facet_item_indent($indent = 0) { + if ($indent > 0) { + return str_repeat('  ', $indent) .' > '; } }