diff --git a/clients/search-component/src/utils/hooks/useFollowupQuestions.ts b/clients/search-component/src/utils/hooks/useFollowupQuestions.ts index 2488104e0..69727db69 100644 --- a/clients/search-component/src/utils/hooks/useFollowupQuestions.ts +++ b/clients/search-component/src/utils/hooks/useFollowupQuestions.ts @@ -6,7 +6,7 @@ import { useChatState } from "./chat-context"; export const useFollowupQuestions = () => { const { trieveSDK, currentGroup, props } = useModalState(); - const { currentQuestion } = useChatState(); + const { messages } = useChatState(); const [isLoading, setIsLoading] = useState(false); const [suggestedQuestions, setSuggestedQuestions] = useState< SuggestedQueriesResponse["queries"] @@ -14,9 +14,16 @@ export const useFollowupQuestions = () => { const getQuestions = async () => { setIsLoading(true); + console.log(messages); + const prevMessage = messages.filter((msg) => { + return msg.type == "user" + }).slice(-1)[0]; + + console.log(prevMessage); + const queries = await getSuggestedQuestions({ trieve: trieveSDK, - query: currentQuestion, + query: prevMessage.text, count: props.numberOfSuggestions ?? 3, group: currentGroup }); diff --git a/clients/search-component/src/utils/trieve.ts b/clients/search-component/src/utils/trieve.ts index 8316cd168..6a75de27f 100644 --- a/clients/search-component/src/utils/trieve.ts +++ b/clients/search-component/src/utils/trieve.ts @@ -294,8 +294,9 @@ export const getSuggestedQuestions = async ({ { ...(query && { query }), suggestion_type: "question", - search_type: "semantic", + search_type: "hybrid", suggestions_to_create: count, + context: `.The users previous query was ${query}, all responses should look like that.`, ...(group && group?.tracking_id && { filters: { diff --git a/server/src/handlers/message_handler.rs b/server/src/handlers/message_handler.rs index 9d37a403b..d6e04ef4f 100644 --- a/server/src/handlers/message_handler.rs +++ b/server/src/handlers/message_handler.rs @@ -930,12 +930,6 @@ pub async fn get_suggested_queries( }; let context_sentence = match data.context.clone() { Some(context) => { - if context.split_whitespace().count() > 15 || context.len() > 200 { - return Err(ServiceError::BadRequest( - "Context must be under 15 words and 200 characters".to_string(), - )); - } - format!( "\n\nSuggest things with the following context in mind: {}.\n\n", context diff --git a/server/src/public/product.html b/server/src/public/product.html index 135a964e9..b769a6e05 100644 --- a/server/src/public/product.html +++ b/server/src/public/product.html @@ -88,7 +88,7 @@