mirror of
https://github.com/StanGirard/quivr.git
synced 2024-12-19 08:42:08 +03:00
1d7bc8a5bc
* remove duplicate import * 🚧 add new linter configuration * 🧑💻 add and run prettier * 🐛 add babel parser for linter * 🧑💻 add lint-fix command * 🚨 use lint-fix * 🚨 remove 'FC' as a type. Use const and JSX.Element * 🚨 enforce arrow function rule from linter * 🔥 delete unused file * 🚨 adding /* eslint-disable */ in failing files * 💩 add ts-expect-error to Victory components
51 lines
1.2 KiB
TypeScript
51 lines
1.2 KiB
TypeScript
/* eslint-disable */
|
|
"use client";
|
|
import { forwardRef, Ref } from "react";
|
|
import ReactMarkdown from "react-markdown";
|
|
|
|
import { cn } from "@/lib/utils";
|
|
|
|
export const ChatMessage = forwardRef(
|
|
(
|
|
{
|
|
speaker,
|
|
text,
|
|
}: {
|
|
speaker: string;
|
|
text: string;
|
|
},
|
|
ref
|
|
) => {
|
|
return (
|
|
<div
|
|
ref={ref as Ref<HTMLDivElement>}
|
|
className={cn(
|
|
"py-3 px-3 md:px-6 w-full dark:border-white/25 flex flex-col max-w-4xl overflow-hidden scroll-pb-32",
|
|
speaker === "user"
|
|
? ""
|
|
: "bg-gray-200 dark:bg-gray-800 bg-opacity-60 py-8"
|
|
)}
|
|
style={speaker === "user" ? { whiteSpace: "pre-line" } : {}} // Add this line to preserve line breaks
|
|
>
|
|
<span
|
|
className={cn(
|
|
"capitalize text-xs bg-sky-200 rounded-xl p-1 px-2 mb-2 w-fit dark:bg-sky-700"
|
|
)}
|
|
>
|
|
{speaker}
|
|
</span>
|
|
<>
|
|
<ReactMarkdown
|
|
// remarkRehypeOptions={{}}
|
|
className="prose dark:prose-invert ml-[6px] mt-1"
|
|
>
|
|
{text}
|
|
</ReactMarkdown>
|
|
</>
|
|
</div>
|
|
);
|
|
}
|
|
);
|
|
|
|
ChatMessage.displayName = "ChatMessage";
|