mirror of
https://github.com/StanGirard/quivr.git
synced 2025-01-07 03:27:39 +03:00
feat(chatMessage): update attributes display (#1067)
This commit is contained in:
parent
ba123fe716
commit
23b21026c2
@ -18,6 +18,8 @@ const useChatContextMock = vi.fn(() => ({
|
|||||||
assistant: "Test assistant message",
|
assistant: "Test assistant message",
|
||||||
message_id: "123",
|
message_id: "123",
|
||||||
user_message: "Test user message",
|
user_message: "Test user message",
|
||||||
|
prompt_title: "Test prompt name",
|
||||||
|
brain_name: "Test brain name",
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
}));
|
}));
|
||||||
@ -37,7 +39,8 @@ describe("ChatMessages", () => {
|
|||||||
it("should render chat messages correctly", () => {
|
it("should render chat messages correctly", () => {
|
||||||
const { getAllByTestId } = render(<ChatMessages />);
|
const { getAllByTestId } = render(<ChatMessages />);
|
||||||
|
|
||||||
expect(getAllByTestId("brain-prompt-tags")).toBeDefined();
|
expect(getAllByTestId("brain-tags")).toBeDefined();
|
||||||
|
expect(getAllByTestId("prompt-tags")).toBeDefined();
|
||||||
|
|
||||||
expect(getAllByTestId("chat-message-text")).toBeDefined();
|
expect(getAllByTestId("chat-message-text")).toBeDefined();
|
||||||
});
|
});
|
||||||
|
@ -3,11 +3,14 @@ import ReactMarkdown from "react-markdown";
|
|||||||
|
|
||||||
import { cn } from "@/lib/utils";
|
import { cn } from "@/lib/utils";
|
||||||
|
|
||||||
|
import { QuestionBrain } from "./components/QuestionBrain";
|
||||||
|
import { QuestionPrompt } from "./components/QuestionPrompt";
|
||||||
|
|
||||||
type ChatMessageProps = {
|
type ChatMessageProps = {
|
||||||
speaker: string;
|
speaker: string;
|
||||||
text: string;
|
text: string;
|
||||||
brainName?: string;
|
brainName?: string | null;
|
||||||
promptName?: string;
|
promptName?: string | null;
|
||||||
};
|
};
|
||||||
|
|
||||||
export const ChatMessage = React.forwardRef(
|
export const ChatMessage = React.forwardRef(
|
||||||
@ -36,13 +39,9 @@ export const ChatMessage = React.forwardRef(
|
|||||||
<div className={containerWrapperClasses}>
|
<div className={containerWrapperClasses}>
|
||||||
{" "}
|
{" "}
|
||||||
<div ref={ref} className={containerClasses}>
|
<div ref={ref} className={containerClasses}>
|
||||||
<div className="w-full">
|
<div className="w-full gap-1 flex">
|
||||||
<span
|
<QuestionBrain brainName={brainName} />
|
||||||
data-testid="brain-prompt-tags"
|
<QuestionPrompt promptName={promptName} />
|
||||||
className="text-gray-400 mb-1 text-xs"
|
|
||||||
>
|
|
||||||
@{brainName ?? "-"} #{promptName ?? "-"}
|
|
||||||
</span>
|
|
||||||
</div>
|
</div>
|
||||||
<div data-testid="chat-message-text">
|
<div data-testid="chat-message-text">
|
||||||
<ReactMarkdown className={markdownClasses}>{text}</ReactMarkdown>
|
<ReactMarkdown className={markdownClasses}>{text}</ReactMarkdown>
|
@ -0,0 +1,18 @@
|
|||||||
|
import { Fragment } from "react";
|
||||||
|
|
||||||
|
type QuestionBrainProps = {
|
||||||
|
brainName?: string | null;
|
||||||
|
};
|
||||||
|
export const QuestionBrain = ({
|
||||||
|
brainName,
|
||||||
|
}: QuestionBrainProps): JSX.Element => {
|
||||||
|
if (brainName === undefined || brainName === null) {
|
||||||
|
return <Fragment />;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<span data-testid="brain-tags" className="text-gray-400 mb-1 text-xs">
|
||||||
|
@{brainName}
|
||||||
|
</span>
|
||||||
|
);
|
||||||
|
};
|
@ -0,0 +1,18 @@
|
|||||||
|
import { Fragment } from "react";
|
||||||
|
|
||||||
|
type QuestionProptProps = {
|
||||||
|
promptName?: string | null;
|
||||||
|
};
|
||||||
|
export const QuestionPrompt = ({
|
||||||
|
promptName,
|
||||||
|
}: QuestionProptProps): JSX.Element => {
|
||||||
|
if (promptName === undefined || promptName === null) {
|
||||||
|
return <Fragment />;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<span data-testid="prompt-tags" className="text-gray-400 mb-1 text-xs">
|
||||||
|
#{promptName}
|
||||||
|
</span>
|
||||||
|
);
|
||||||
|
};
|
@ -0,0 +1 @@
|
|||||||
|
export * from "./ChatMessage";
|
@ -0,0 +1 @@
|
|||||||
|
export * from "./ChatMessage";
|
@ -1 +1 @@
|
|||||||
export * from "./components/ChatMessage";
|
export * from "./components/ChatMessage/ChatMessage";
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
export * from './ChatMessage'
|
@ -3,7 +3,7 @@ import { useTranslation } from "react-i18next";
|
|||||||
|
|
||||||
import { useChatContext } from "@/lib/context";
|
import { useChatContext } from "@/lib/context";
|
||||||
|
|
||||||
import { ChatMessage } from "./components/ChatMessage/components/ChatMessage";
|
import { ChatMessage } from "./components";
|
||||||
import { useChatMessages } from "./hooks/useChatMessages";
|
import { useChatMessages } from "./hooks/useChatMessages";
|
||||||
|
|
||||||
export const ChatMessages = (): JSX.Element => {
|
export const ChatMessages = (): JSX.Element => {
|
||||||
|
Loading…
Reference in New Issue
Block a user