From 515f9f1986545a86d6ff4f9377451198c2923c5b Mon Sep 17 00:00:00 2001 From: Xander Vertegaal Date: Fri, 23 Aug 2024 18:12:45 +0200 Subject: [PATCH] Various small improvements --- backend/aethel_db/views/sample_data.py | 25 ++++++++++++------------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/backend/aethel_db/views/sample_data.py b/backend/aethel_db/views/sample_data.py index a4fb842..f3c38b4 100644 --- a/backend/aethel_db/views/sample_data.py +++ b/backend/aethel_db/views/sample_data.py @@ -25,6 +25,9 @@ class AethelSampleDataResult: name: str phrases: list[AethelSampleDataPhrase] = field(default_factory=list) + def highlight_phrase_at_index(self, index: int) -> None: + self.phrases[index].highlight = True + def serialize(self): return asdict(self) @@ -34,7 +37,7 @@ class AethelSampleDataResponse: results: list[AethelSampleDataResult] = field(default_factory=list) error: str | None = None - def get_or_create_sample(self, sample: Sample) -> AethelSampleDataResult: + def get_or_create_result(self, sample: Sample) -> AethelSampleDataResult: """ Return an existing result with the same sample.name if it exists. Else create a new one. """ @@ -51,11 +54,6 @@ def get_or_create_sample(self, sample: Sample) -> AethelSampleDataResult: self.results.append(new_result) return new_result - def highlight_phrase( - self, sample: AethelSampleDataResult, highlighted_phrase_index: int - ) -> None: - sample.phrases[highlighted_phrase_index].highlight = True - def json_response(self) -> JsonResponse: return JsonResponse( { @@ -71,11 +69,14 @@ def get(self, request: HttpRequest) -> JsonResponse: type_input = self.request.query_params.get("type", None) word_input = self.request.query_params.get("word", None) - if word_input: - word_input = json.loads(word_input) - response_object = AethelSampleDataResponse() + # Not expected. + if not type_input or not word_input: + return response_object.json_response() + + word_input = json.loads(word_input) + for sample in dataset.samples: for phrase_index, phrase in enumerate(sample.lexical_phrases): word_match = word_input and match_word_with_phrase_exact( @@ -86,10 +87,8 @@ def get(self, request: HttpRequest) -> JsonResponse: if not (word_match and type_match): continue - aethel_sample = response_object.get_or_create_sample(sample=sample) + aethel_sample = response_object.get_or_create_result(sample=sample) - response_object.highlight_phrase( - sample=aethel_sample, highlighted_phrase_index=phrase_index - ) + aethel_sample.highlight_phrase_at_index(index=phrase_index) return response_object.json_response()