添加quickcommand.markdownParse接口,可视化编排支持解析markdown

This commit is contained in:
fofolee
2025-02-20 20:38:51 +08:00
parent 196d54a993
commit 60ac9fbc81
10 changed files with 60 additions and 38 deletions

View File

@@ -83,8 +83,6 @@
import { defineComponent } from "vue";
import AISelector from "components/ai/AISelector.vue";
import AIChatHistory from "components/ai/AIChatHistory.vue";
import { marked } from "marked";
import DOMPurify from "dompurify";
const quickcommandApi =
require(`!raw-loader!plugins/monaco/types/quickcommand.api.d.ts`)
@@ -229,19 +227,6 @@ export default defineComponent({
this.autoUpdateCode = !this.autoUpdateCode;
localStorage.setItem("ai_auto_update", this.autoUpdateCode);
},
getTrimContent(content) {
const markedContent = marked(content.trim());
// 解决think标签被错误地包裹在<p>标签中
const processedContent = markedContent
.replace("<p><think>", "<think><p>")
.replace("</think></p>", "</p></think>")
// 去除空的think标签
.replace("<think>\n\n</think>", "");
const purifiedContent = DOMPurify.sanitize(processedContent, {
ADD_TAGS: ["think"],
});
return purifiedContent;
},
getRolePrompt(language) {
const languageMap = {
quickcommand: "NodeJS",

View File

@@ -36,7 +36,6 @@
<script>
import { defineComponent } from "vue";
import { marked } from "marked";
import DOMPurify from "dompurify";
export default defineComponent({
@@ -74,7 +73,7 @@ export default defineComponent({
},
getAssistantMsg(content) {
const markedContent = marked(content.trim());
const markedContent = quickcommand.markdownParse(content.trim());
const processedContent = markedContent
.replace("<p><think>", "<think><p>")
.replace("</think></p>", "</p></think>")