docs: allow stop answer generation in AI assistant (#14387)
This commit is contained in:
@@ -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>
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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(
|
||||
|
||||
@@ -32,6 +32,7 @@ export type AiAssistantThreadItem = {
|
||||
content: string
|
||||
question_id?: string | null
|
||||
sources?: Source[]
|
||||
isGenerationAborted?: boolean
|
||||
}
|
||||
|
||||
const AiAssistantContext = createContext<AiAssistantContextType | null>(null)
|
||||
|
||||
Reference in New Issue
Block a user