From 8b7bdf7d07c7af594464d3cf366974c09fda9f7c Mon Sep 17 00:00:00 2001 From: Gabriel Mechali Date: Tue, 12 Nov 2024 16:20:53 -0500 Subject: [PATCH] Trigger autocomplete for 2 letter query if that is "US" (#4730) Autocomplete queries only trigger on 3+ letter words. With this change, we add one exception, to trigger on a two letter word if that is "US" US Triggers: https://screenshot.googleplex.com/AzqxmiqBBr2ocVn Other 2 letter words do not: https://screenshot.googleplex.com/7tXxN8p34MT4SUU Life expectancy in us: https://screenshot.googleplex.com/6k7WK2oiJqWedxK --- server/routes/shared_api/autocomplete/helpers.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/server/routes/shared_api/autocomplete/helpers.py b/server/routes/shared_api/autocomplete/helpers.py index 4a87ff5372..204b2ca084 100644 --- a/server/routes/shared_api/autocomplete/helpers.py +++ b/server/routes/shared_api/autocomplete/helpers.py @@ -57,6 +57,9 @@ 'place_dcid': 'asia' }] + TWO_WORD_CUSTOM_PLACES +# Exceptions for the 3 letter trigger rule. These queries can trigger on only two letters. +TWO_LETTER_TRIGGERS = {"us"} + def find_queries(user_query: str) -> List[str]: """Extracts subqueries to send to the Google Maps Predictions API from the entire user input. @@ -78,8 +81,9 @@ def find_queries(user_query: str) -> List[str]: else: cumulative = word - # Only send queries 3 characters or longer. - if (len(cumulative) >= MIN_CHARACTERS_PER_QUERY): + # Only send queries 3 characters or longer, except for the exceptions in TWO_LETTER_TRIGGERS. + if (len(cumulative) >= MIN_CHARACTERS_PER_QUERY or + (len(cumulative) == 2 and cumulative.lower() in TWO_LETTER_TRIGGERS)): queries.append(cumulative) # Start by running the longer queries.