Skip to content

Commit

Permalink
feat: better stream output
Browse files Browse the repository at this point in the history
  • Loading branch information
JoeSlain committed Dec 24, 2024
1 parent 94d5c72 commit 4197491
Showing 1 changed file with 50 additions and 4 deletions.
54 changes: 50 additions & 4 deletions src/components/Meeting/MeetingStream.tsx
Original file line number Diff line number Diff line change
@@ -1,22 +1,68 @@
import { useEffect, useState, useRef } from 'react'
import type { RootState } from '@types'
import { useSelector } from 'react-redux'
import { TextWithSources } from 'components/Sources/TextWithSources'
import { GlobalParagraph } from 'components/Global/GlobalParagraph'
import Separator from 'components/Global/Separator'
import { TextWithSources } from 'components/Sources/TextWithSources'
import { useSelector } from 'react-redux'
import { Feedback } from '../Feedbacks/Feedback'

export function MeetingStream() {
const stream = useSelector((state: RootState) => state.stream)
const agentResponse = stream.historyStream[0]

// For letter-by-letter text
const [displayedText, setDisplayedText] = useState('')
const lastIndexRef = useRef(0)

// We'll detect a new question/stream by checking user.lastStreamId
const user = useSelector((state: RootState) => state.user)
const [prevStreamId, setPrevStreamId] = useState<number | null>(null)

// 1) Reset on new question
useEffect(() => {
// If lastStreamId changed => a brand-new question is being asked
if (user.lastStreamId && user.lastStreamId !== prevStreamId) {
setDisplayedText('')
lastIndexRef.current = 0
setPrevStreamId(user.lastStreamId)
}
}, [user.lastStreamId, prevStreamId])

// 2) Append text while streaming
useEffect(() => {
if (!stream.isStreaming) return

const intervalId = setInterval(() => {
if (lastIndexRef.current < stream.response.length) {
setDisplayedText((prev) => {
const nextChar = stream.response[lastIndexRef.current]
lastIndexRef.current += 1
return prev + nextChar
})
}
}, 0) // speed as desired

return () => clearInterval(intervalId)
}, [stream.isStreaming, stream.response])

// 3) Once streaming is done, ensure full text is displayed
useEffect(() => {
if (!stream.isStreaming && stream.response) {
setDisplayedText(stream.response)
lastIndexRef.current = stream.response.length
}
}, [stream.isStreaming, stream.response])

return (
<div className="h">
<div>
<h3>Réponse proposée par Albert</h3>

{stream.isStreaming ? (
<TextWithSources text={stream.response} />
<TextWithSources text={displayedText} />
) : (
<GlobalParagraph>{agentResponse}</GlobalParagraph>
)}

{!stream.isStreaming && stream.historyStream.length !== 0 && (
<div className="fr-mt-5w">
<Feedback />
Expand Down

0 comments on commit 4197491

Please sign in to comment.