mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Expose a sortFacetValuesBy parameter to the user
This commit is contained in:
		
				
					committed by
					
						 Clément Renault
						Clément Renault
					
				
			
			
				
	
			
			
			
						parent
						
							80bbd4b6f3
						
					
				
				
					commit
					34b2e98fe9
				
			| @@ -16,9 +16,9 @@ use crate::extractors::authentication::policies::*; | ||||
| use crate::extractors::authentication::GuardedData; | ||||
| use crate::extractors::sequential_extractor::SeqHandler; | ||||
| use crate::search::{ | ||||
|     add_search_rules, perform_search, MatchingStrategy, SearchQuery, DEFAULT_CROP_LENGTH, | ||||
|     DEFAULT_CROP_MARKER, DEFAULT_HIGHLIGHT_POST_TAG, DEFAULT_HIGHLIGHT_PRE_TAG, | ||||
|     DEFAULT_SEARCH_LIMIT, DEFAULT_SEARCH_OFFSET, | ||||
|     add_search_rules, perform_search, FacetValuesSort, MatchingStrategy, SearchQuery, | ||||
|     DEFAULT_CROP_LENGTH, DEFAULT_CROP_MARKER, DEFAULT_HIGHLIGHT_POST_TAG, | ||||
|     DEFAULT_HIGHLIGHT_PRE_TAG, DEFAULT_SEARCH_LIMIT, DEFAULT_SEARCH_OFFSET, | ||||
| }; | ||||
|  | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
| @@ -64,6 +64,8 @@ pub struct SearchQueryGet { | ||||
|     show_ranking_score_details: Param<bool>, | ||||
|     #[deserr(default, error = DeserrQueryParamError<InvalidSearchFacets>)] | ||||
|     facets: Option<CS<String>>, | ||||
|     #[deserr(default, error = DeserrQueryParamError<InvalidSearchFacets>)] | ||||
|     sort_facet_values_by: Option<FacetValuesSort>, | ||||
|     #[deserr( default = DEFAULT_HIGHLIGHT_PRE_TAG(), error = DeserrQueryParamError<InvalidSearchHighlightPreTag>)] | ||||
|     highlight_pre_tag: String, | ||||
|     #[deserr( default = DEFAULT_HIGHLIGHT_POST_TAG(), error = DeserrQueryParamError<InvalidSearchHighlightPostTag>)] | ||||
| @@ -103,6 +105,7 @@ impl From<SearchQueryGet> for SearchQuery { | ||||
|             show_ranking_score: other.show_ranking_score.0, | ||||
|             show_ranking_score_details: other.show_ranking_score_details.0, | ||||
|             facets: other.facets.map(|o| o.into_iter().collect()), | ||||
|             sort_facet_values_by: other.sort_facet_values_by, | ||||
|             highlight_pre_tag: other.highlight_pre_tag, | ||||
|             highlight_post_tag: other.highlight_post_tag, | ||||
|             crop_marker: other.crop_marker, | ||||
|   | ||||
| @@ -14,7 +14,7 @@ use meilisearch_types::heed::RoTxn; | ||||
| use meilisearch_types::index_uid::IndexUid; | ||||
| use meilisearch_types::milli::score_details::{ScoreDetails, ScoringStrategy}; | ||||
| use meilisearch_types::milli::{ | ||||
|     dot_product_similarity, FacetValueHit, InternalError, SearchForFacetValues, | ||||
|     dot_product_similarity, FacetValueHit, OrderBy, InternalError, SearchForFacetValues, | ||||
| }; | ||||
| use meilisearch_types::settings::DEFAULT_PAGINATION_MAX_TOTAL_HITS; | ||||
| use meilisearch_types::{milli, Document}; | ||||
| @@ -74,6 +74,8 @@ pub struct SearchQuery { | ||||
|     pub sort: Option<Vec<String>>, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchFacets>)] | ||||
|     pub facets: Option<Vec<String>>, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchFacets>)] // TODO | ||||
|     pub sort_facet_values_by: Option<FacetValuesSort>, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchHighlightPreTag>, default = DEFAULT_HIGHLIGHT_PRE_TAG())] | ||||
|     pub highlight_pre_tag: String, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchHighlightPostTag>, default = DEFAULT_HIGHLIGHT_POST_TAG())] | ||||
| @@ -133,6 +135,8 @@ pub struct SearchQueryWithIndex { | ||||
|     pub sort: Option<Vec<String>>, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchFacets>)] | ||||
|     pub facets: Option<Vec<String>>, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchFacets>)] // TODO | ||||
|     pub sort_facet_values_by: Option<FacetValuesSort>, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchHighlightPreTag>, default = DEFAULT_HIGHLIGHT_PRE_TAG())] | ||||
|     pub highlight_pre_tag: String, | ||||
|     #[deserr(default, error = DeserrJsonError<InvalidSearchHighlightPostTag>, default = DEFAULT_HIGHLIGHT_POST_TAG())] | ||||
| @@ -165,6 +169,7 @@ impl SearchQueryWithIndex { | ||||
|             filter, | ||||
|             sort, | ||||
|             facets, | ||||
|             sort_facet_values_by, | ||||
|             highlight_pre_tag, | ||||
|             highlight_post_tag, | ||||
|             crop_marker, | ||||
| @@ -190,6 +195,7 @@ impl SearchQueryWithIndex { | ||||
|                 filter, | ||||
|                 sort, | ||||
|                 facets, | ||||
|                 sort_facet_values_by, | ||||
|                 highlight_pre_tag, | ||||
|                 highlight_post_tag, | ||||
|                 crop_marker, | ||||
| @@ -226,6 +232,26 @@ impl From<MatchingStrategy> for TermsMatchingStrategy { | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Default, Clone, PartialEq, Eq, Deserr)] | ||||
| #[deserr(rename_all = camelCase)] | ||||
| pub enum FacetValuesSort { | ||||
|     /// Facet values are sorted by decreasing count. | ||||
|     /// The count is the number of records containing this facet value in the results of the query. | ||||
|     #[default] | ||||
|     Alpha, | ||||
|     /// Facet values are sorted in alphabetical order, ascending from A to Z. | ||||
|     Count, | ||||
| } | ||||
|  | ||||
| impl Into<OrderBy> for FacetValuesSort { | ||||
|     fn into(self) -> OrderBy { | ||||
|         match self { | ||||
|             FacetValuesSort::Alpha => OrderBy::Lexicographic, | ||||
|             FacetValuesSort::Count => OrderBy::Count, | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Clone, Serialize, PartialEq)] | ||||
| pub struct SearchHit { | ||||
|     #[serde(flatten)] | ||||
| @@ -557,7 +583,10 @@ pub fn perform_search( | ||||
|             if fields.iter().all(|f| f != "*") { | ||||
|                 facet_distribution.facets(fields); | ||||
|             } | ||||
|             let distribution = facet_distribution.candidates(candidates).execute()?; | ||||
|             let distribution = facet_distribution | ||||
|                 .candidates(candidates) | ||||
|                 .order_by(query.sort_facet_values_by.map_or_else(Default::default, Into::into)) | ||||
|                 .execute()?; | ||||
|             let stats = facet_distribution.compute_stats()?; | ||||
|             (Some(distribution), Some(stats)) | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user