- Fix timeframe parameter handling in enhanced-screenshot API route - Support both 'timeframe' (singular) and 'timeframes' (array) parameters - Add proper sessionId propagation for real-time progress tracking - Enhance MACD analysis prompt with detailed crossover definitions - Add progress tracker service with Server-Sent Events support - Fix Next.js build errors in chart components (module variable conflicts) - Change dev environment port from 9000:3000 to 9001:3000 - Improve AI analysis layout detection logic - Add comprehensive progress tracking through all service layers
53 lines
1.7 KiB
TypeScript
53 lines
1.7 KiB
TypeScript
import { progressTracker } from '../../../lib/progress-tracker'
|
|
|
|
export async function GET(request: Request) {
|
|
const { searchParams } = new URL(request.url)
|
|
const sessionId = searchParams.get('sessionId')
|
|
|
|
if (!sessionId) {
|
|
return new Response('Session ID required', { status: 400 })
|
|
}
|
|
|
|
const stream = new ReadableStream({
|
|
start(controller) {
|
|
// Send initial progress if session exists
|
|
const currentProgress = progressTracker.getProgress(sessionId)
|
|
if (currentProgress) {
|
|
const data = `data: ${JSON.stringify(currentProgress)}\n\n`
|
|
controller.enqueue(new TextEncoder().encode(data))
|
|
}
|
|
|
|
// Listen for progress updates
|
|
const progressHandler = (progress: any) => {
|
|
const data = `data: ${JSON.stringify(progress)}\n\n`
|
|
controller.enqueue(new TextEncoder().encode(data))
|
|
}
|
|
|
|
const completeHandler = () => {
|
|
const data = `data: ${JSON.stringify({ type: 'complete' })}\n\n`
|
|
controller.enqueue(new TextEncoder().encode(data))
|
|
controller.close()
|
|
}
|
|
|
|
progressTracker.on(`progress:${sessionId}`, progressHandler)
|
|
progressTracker.on(`progress:${sessionId}:complete`, completeHandler)
|
|
|
|
// Cleanup on close
|
|
return () => {
|
|
progressTracker.off(`progress:${sessionId}`, progressHandler)
|
|
progressTracker.off(`progress:${sessionId}:complete`, completeHandler)
|
|
}
|
|
}
|
|
})
|
|
|
|
return new Response(stream, {
|
|
headers: {
|
|
'Content-Type': 'text/event-stream',
|
|
'Cache-Control': 'no-cache',
|
|
'Connection': 'keep-alive',
|
|
'Access-Control-Allow-Origin': '*',
|
|
'Access-Control-Allow-Headers': 'Cache-Control'
|
|
}
|
|
})
|
|
}
|