feat(chatMessage): update attributes display (#1067)

This commit is contained in:
Mamadou DICKO 2023-08-30 16:28:10 +02:00 committed by GitHub
parent ba123fe716
commit 23b21026c2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 53 additions and 12 deletions

View File

@ -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();
}); });

View File

@ -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>

View File

@ -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>
);
};

View File

@ -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>
);
};

View File

@ -0,0 +1 @@
export * from "./ChatMessage";

View File

@ -0,0 +1 @@
export * from "./ChatMessage";

View File

@ -1 +1 @@
export * from "./components/ChatMessage"; export * from "./components/ChatMessage/ChatMessage";

View File

@ -0,0 +1 @@
export * from './ChatMessage'

View File

@ -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 => {