docs: allow stop answer generation in AI assistant (#14387)

This commit is contained in:
Shahed Nasser
2025-12-23 08:58:16 +02:00
committed by GitHub
parent 662ec7430b
commit 10dab3a47a
4 changed files with 25 additions and 4 deletions

View File

@@ -1,6 +1,11 @@
import React, { useEffect, useMemo, useRef } from "react"
import clsx from "clsx"
import { ArrowUpCircleSolid, LightBulb, LightBulbSolid } from "@medusajs/icons"
import {
ArrowUpCircleSolid,
LightBulb,
LightBulbSolid,
StopCircleSolid,
} from "@medusajs/icons"
import {
useAiAssistant,
useAnalytics,
@@ -20,7 +25,7 @@ export const AiAssistantChatWindowInput = ({
}: AiAssistantChatWindowInputProps) => {
const { chatOpened, inputRef, loading, setChatOpened, isCaptchaLoaded } =
useAiAssistant()
const { submitQuery, conversation } = useChat()
const { submitQuery, conversation, stopGeneration } = useChat()
const { track } = useAnalytics()
const { active, toggle } = useDeepThinking()
const { isBrowser } = useIsBrowser()
@@ -43,6 +48,12 @@ export const AiAssistantChatWindowInput = ({
overrideQuestion?: string
) => {
e?.preventDefault()
if (loading) {
// stop the generation
stopGeneration()
return
}
submitQuery(overrideQuestion || question)
if (!conversation.length) {
track({
@@ -206,10 +217,10 @@ export const AiAssistantChatWindowInput = ({
"appearance-none p-0 text-medusa-fg-base disabled:text-medusa-fg-disabled",
"transition-colors"
)}
disabled={!question || loading || !isCaptchaLoaded}
disabled={!isCaptchaLoaded || (!question && !loading)}
type="submit"
>
<ArrowUpCircleSolid />
{loading ? <StopCircleSolid /> : <ArrowUpCircleSolid />}
</button>
</div>
</form>

View File

@@ -53,6 +53,7 @@ export const AiAssistantChatWindow = () => {
content: item.question,
sources: item.sources,
question_id: item.id,
isGenerationAborted: item.isGenerationAborted,
}}
/>
<AiAssistantThreadItem
@@ -61,6 +62,7 @@ export const AiAssistantChatWindow = () => {
content: item.answer,
sources: item.sources,
question_id: item.id,
isGenerationAborted: item.isGenerationAborted,
}}
/>
</Fragment>

View File

@@ -25,6 +25,13 @@ export const AiAssistantThreadItem = ({ item }: AiAssistantThreadItemProps) => {
return !item.question_id && item.content.length === 0
}, [item, error])
if (
item.isGenerationAborted &&
item.type === "answer" &&
!item.content.length
) {
return null
}
return (
<div
className={clsx(

View File

@@ -32,6 +32,7 @@ export type AiAssistantThreadItem = {
content: string
question_id?: string | null
sources?: Source[]
isGenerationAborted?: boolean
}
const AiAssistantContext = createContext<AiAssistantContextType | null>(null)