import React from 'react'; import { ChunkBody, CodeResult, formatStreamLogs } from '@/lib/utils/content'; import { CodeBlock } from './ui/CodeBlock'; import { Dialog, DialogTrigger, DialogContent, DialogHeader, DialogTitle, } from './ui/Dialog'; import { Button } from './ui/Button'; import { IconLog, IconTerminalWindow } from './ui/Icons'; import { Separator } from './ui/Separator'; import { ResultPayload } from '@/lib/types'; import Img from './ui/Img'; import { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious, } from './ui/carousel'; export interface CodeResultDisplayProps {} const CodeResultDisplay: React.FC<{ codeResult: CodeResult; }> = ({ codeResult }) => { const { code, test, result } = codeResult; const getDetail = () => { if (!result) return {}; try { const detail = JSON.parse(result) as ResultPayload; return { results: detail.results, stderr: detail.logs.stderr, stdout: detail.logs.stdout, error: detail.error, }; } catch { return {}; } }; const { results = [], stderr, stdout, error } = getDetail(); const imageResults = results?.filter(_ => !!_.png).map(_ => _.png); const videoResults = results?.filter(_ => !!_.mp4).map(_ => _.mp4); const finalResult = results?.find(_ => _.is_main_result)?.text; return (
Test code {Array.isArray(stderr) && !!stderr.join('').trim() && ( )}
{Array.isArray(stdout) && !!stdout.join('').trim() && ( <> )} {!!error && ( <> )} {!!imageResults.length && (

image output

{imageResults.map((png, index) => ( result-image ))}
{imageResults.map((png, index) => ( result-image ))}
)} {!!videoResults.length && (

video output

{videoResults.map((mp4, index) => ( ))}
)} {!!finalResult && }
); }; export default CodeResultDisplay;