mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 00:40:14 +01:00
* refactor: expand container * chore: bump @codesandbox/sandpack-react to latest * WIP: first pass, show editor * feat: implement ArtifactCodeEditor and ArtifactTabs components for enhanced artifact management * refactor: fileKey * refactor: auto scrolling code editor and add messageId to artifact * feat: first pass, editing artifact * feat: first pass, robust artifact replacement * fix: robust artifact replacement & re-render when expected * feat: Download Artifacts * refactor: improve artifact editing UX * fix: layout shift of new download button * fix: enhance missing output checks and logging in StreamRunManager
60 lines
1.8 KiB
TypeScript
60 lines
1.8 KiB
TypeScript
import { useRef } from 'react';
|
|
import * as Tabs from '@radix-ui/react-tabs';
|
|
import type { SandpackPreviewRef, CodeEditorRef } from '@codesandbox/sandpack-react';
|
|
import type { Artifact } from '~/common';
|
|
import useArtifactProps from '~/hooks/Artifacts/useArtifactProps';
|
|
import { useAutoScroll } from '~/hooks/Artifacts/useAutoScroll';
|
|
import { ArtifactCodeEditor } from './ArtifactCodeEditor';
|
|
import { ArtifactPreview } from './ArtifactPreview';
|
|
import { cn } from '~/utils';
|
|
|
|
export default function ArtifactTabs({
|
|
artifact,
|
|
isMermaid,
|
|
editorRef,
|
|
previewRef,
|
|
isSubmitting,
|
|
}: {
|
|
artifact: Artifact;
|
|
isMermaid: boolean;
|
|
isSubmitting: boolean;
|
|
editorRef: React.MutableRefObject<CodeEditorRef>;
|
|
previewRef: React.MutableRefObject<SandpackPreviewRef>;
|
|
}) {
|
|
const content = artifact.content ?? '';
|
|
const contentRef = useRef<HTMLDivElement>(null);
|
|
useAutoScroll({ ref: contentRef, content, isSubmitting });
|
|
const { files, fileKey, template, sharedProps } = useArtifactProps({ artifact });
|
|
return (
|
|
<>
|
|
<Tabs.Content
|
|
ref={contentRef}
|
|
value="code"
|
|
id="artifacts-code"
|
|
className={cn('flex-grow overflow-auto')}
|
|
>
|
|
<ArtifactCodeEditor
|
|
files={files}
|
|
fileKey={fileKey}
|
|
template={template}
|
|
artifact={artifact}
|
|
editorRef={editorRef}
|
|
sharedProps={sharedProps}
|
|
isSubmitting={isSubmitting}
|
|
/>
|
|
</Tabs.Content>
|
|
<Tabs.Content
|
|
value="preview"
|
|
className={cn('flex-grow overflow-auto', isMermaid ? 'bg-[#282C34]' : 'bg-white')}
|
|
>
|
|
<ArtifactPreview
|
|
files={files}
|
|
fileKey={fileKey}
|
|
template={template}
|
|
previewRef={previewRef}
|
|
sharedProps={sharedProps}
|
|
/>
|
|
</Tabs.Content>
|
|
</>
|
|
);
|
|
}
|