make location facet return results

for location nav facet of field coordinate_p does not return results, now using coordinate_p_0_coordinate as alternative to get facet counts. As the actual facet value is not used this should not harm any analysis (even if facet is a incomplete location).
If facet value is used in future likely *_geohash field could be introduced (for facet and other ... as transport value)
pull/1/head
reger 10 years ago
parent b1ec0644e5
commit 1f0f77bb77

@ -93,7 +93,7 @@ public final class QueryParams {
private static final Map<String, CollectionSchema> defaultfacetfields = new HashMap<String, CollectionSchema>(); private static final Map<String, CollectionSchema> defaultfacetfields = new HashMap<String, CollectionSchema>();
static { static {
// the key shall match with configuration property search.navigation // the key shall match with configuration property search.navigation
defaultfacetfields.put("location", CollectionSchema.coordinate_p); defaultfacetfields.put("location", CollectionSchema.coordinate_p_0_coordinate); // coordinate_p can't be used for facet (subfields), as value isn't used subfield can be used
defaultfacetfields.put("hosts", CollectionSchema.host_s); defaultfacetfields.put("hosts", CollectionSchema.host_s);
defaultfacetfields.put("protocol", CollectionSchema.url_protocol_s); defaultfacetfields.put("protocol", CollectionSchema.url_protocol_s);
defaultfacetfields.put("filetype", CollectionSchema.url_file_ext_s); defaultfacetfields.put("filetype", CollectionSchema.url_file_ext_s);
@ -249,7 +249,9 @@ public final class QueryParams {
for (String navkey: search_navigation) { for (String navkey: search_navigation) {
CollectionSchema f = defaultfacetfields.get(navkey); CollectionSchema f = defaultfacetfields.get(navkey);
// handle special field, authors_sxt (add to facet w/o contains check, as authors_sxt is not enabled (is copyfield)) // handle special field, authors_sxt (add to facet w/o contains check, as authors_sxt is not enabled (is copyfield))
if (f != null && (solrSchema.contains(f) || f.name().equals("author_sxt"))) this.facetfields.add(f.getSolrFieldName()); // dto. for coordinate_p_0_coordinate is not enabled but used for location facet (because coordinate_p not valid for facet field)
if (f != null && (solrSchema.contains(f) || f.name().equals("author_sxt") || f.name().equals("coordinate_p_0_coordinate") ))
this.facetfields.add(f.getSolrFieldName());
} }
if (LibraryProvider.autotagging != null) for (Tagging v: LibraryProvider.autotagging.getVocabularies()) { if (LibraryProvider.autotagging != null) for (Tagging v: LibraryProvider.autotagging.getVocabularies()) {
if (v.isFacet()) { if (v.isFacet()) {

@ -795,7 +795,7 @@ public final class SearchEvent {
// collect navigation information // collect navigation information
ReversibleScoreMap<String> fcts; ReversibleScoreMap<String> fcts;
if (this.locationNavigator != null) { if (this.locationNavigator != null) {
fcts = facets.get(CollectionSchema.coordinate_p.getSolrFieldName()); fcts = facets.get(CollectionSchema.coordinate_p_0_coordinate.getSolrFieldName());
if (fcts != null) { if (fcts != null) {
for (String coordinate: fcts) { for (String coordinate: fcts) {
int hc = fcts.get(coordinate); int hc = fcts.get(coordinate);

Loading…
Cancel
Save