Skip to content
Snippets Groups Projects
Commit b8afaaee authored by Valentin Rigal's avatar Valentin Rigal Committed by Valentin Rigal
Browse files

Use terms field to find elements by reference

parent dbd2f6f7
No related branches found
No related tags found
No related merge requests found
......@@ -31,7 +31,6 @@ class ElementSearch(SearchAPIView):
query=None,
element_type=None,
transcription_type=None,
reference=None,
date_lt=None,
date_gte=None,
min_score=0.0):
......@@ -53,22 +52,16 @@ class ElementSearch(SearchAPIView):
search = search.filter('range', date_range=date_range)
if reference:
search = search.filter(
'wildcard',
references='*{}*'.format(reference.lower())
)
if element_type:
search = search.filter('match', type=element_type)
nested_query = Q('range', transcriptions__score={'gte': min_score})
if query:
nested_query &= Q('simple_query_string', query=query, fields=['transcriptions.text'])
if transcription_type:
nested_query &= Q('match', transcriptions__type=transcription_type.value)
if query:
nested_query &= Q('simple_query_string', query=query, fields=['transcriptions.text'])
search = search.query(Nested(
elastic_query = Nested(
path='transcriptions',
inner_hits={'size': settings.ES_INNER_RESULTS_LIMIT},
score_mode='sum',
......@@ -76,8 +69,11 @@ class ElementSearch(SearchAPIView):
query=nested_query,
functions=[FieldValueFactor(field='transcriptions.score')],
),
))
)
if query:
elastic_query |= Q('wildcard', references='*{}*'.format(query.lower()))
search = search.query(elastic_query)
return search
def post_process(self, *args, **kwargs):
......
......@@ -20,7 +20,6 @@ class SearchQuerySerializer(serializers.Serializer):
score = serializers.FloatField(source='min_score', min_value=0.0, max_value=1.0, default=0.0)
date_gte = serializers.CharField(default=None)
date_lte = serializers.CharField(source='date_lt', default=None)
reference = serializers.CharField(default=None)
element_type = serializers.SlugField(default=None)
transcription_type = EnumField(enum=TranscriptionType, default=None)
corpus = serializers.UUIDField(source='corpus_id', default=None)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment