render markdown by default

This commit is contained in:
2023-07-14 15:44:13 +08:00
parent 08c087468b
commit 9e520d9b64
3 changed files with 35 additions and 3 deletions

View File

@@ -1,6 +1,7 @@
import { useState } from "preact/hooks";
import { ChatStore } from "./app";
import { calculate_token_length } from "./chatgpt";
import Markdown from "preact-markdown";
interface Props {
messageIndex: number;
@@ -13,6 +14,7 @@ export default function Message(props: Props) {
const chat = chatStore.history[messageIndex];
const [showEdit, setShowEdit] = useState(false);
const [showCopiedHint, setShowCopiedHint] = useState(false);
const [renderMarkdown, setRenderWorkdown] = useState(false);
const DeleteIcon = () => (
<button
onClick={() => {
@@ -87,9 +89,14 @@ export default function Message(props: Props) {
} ${chat.hide ? "opacity-50" : ""}`}
>
<p className="message-content">
{chat.hide
? chat.content.split("\n")[0].slice(0, 16) + "... (deleted)"
: chat.content}
{chat.hide ? (
chat.content.split("\n")[0].slice(0, 16) + "... (deleted)"
) : renderMarkdown ? (
// @ts-ignore
<Markdown markdown={chat.content} />
) : (
chat.content
)}
</p>
<div className="w-full flex justify-between">
<DeleteIcon />
@@ -166,6 +173,12 @@ export default function Message(props: Props) {
<label className="dark:text-white">example</label>
<input type="checkbox" checked={chat.example} />
</span>
<span
onClick={(event: any) => setRenderWorkdown(!renderMarkdown)}
>
<label className="dark:text-white">render</label>
<input type="checkbox" checked={renderMarkdown} />
</span>
</div>
)}
</div>