Skip to content
Toggle navigation
P
Projects
G
Groups
S
Snippets
Help
phsl
/
admin
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Snippets
Members
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit
10beee84
authored
May 13, 2024
by
cherishsince
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
【增加】消息增加 marked 渲染 markdown
parent
7f25419c
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
19 additions
and
8 deletions
+19
-8
package.json
+1
-0
src/views/ai/chat/index.vue
+18
-8
No files found.
package.json
View file @
10beee84
...
...
@@ -52,6 +52,7 @@
"
highlight.js
"
:
"^11.9.0"
,
"
jsencrypt
"
:
"^3.3.2"
,
"
lodash-es
"
:
"^4.17.21"
,
"
marked
"
:
"^12.0.2"
,
"
min-dash
"
:
"^4.1.1"
,
"
mitt
"
:
"^3.0.1"
,
"
nprogress
"
:
"^0.2.0"
,
...
...
src/views/ai/chat/index.vue
View file @
10beee84
...
...
@@ -98,9 +98,7 @@
<el-text
class=
"time"
>
{{formatDate(item.createTime)}}
</el-text>
</div>
<div
class=
"left-text-container"
>
<el-text
class=
"left-text"
>
{{item.content}}
</el-text>
<div
class=
"left-text"
v-html=
"item.content"
></div>
</div>
<div
class=
"left-btns"
>
<div
class=
"btn-cus"
@
click=
"noCopy(item.content)"
>
...
...
@@ -126,9 +124,7 @@
<el-text
class=
"time"
>
{{formatDate(item.createTime)}}
</el-text>
</div>
<div
class=
"right-text-container"
>
<el-text
class=
"right-text"
>
{{item.content}}
</el-text>
<div
class=
"right-text"
v-html=
"item.content"
></div>
</div>
<div
class=
"right-btns"
>
<div
class=
"btn-cus"
@
click=
"noCopy(item.content)"
>
...
...
@@ -165,9 +161,12 @@
</template>
<
script
setup
lang=
"ts"
>
import
{
ChatMessageApi
,
ChatMessageSendVO
,
ChatMessageVO
}
from
"@/api/ai/chat/message"
;
import
{
formatDate
}
from
"@/utils/formatTime"
;
import
'highlight.js/styles/idea.css'
import
{
ChatMessageApi
,
ChatMessageSendVO
,
ChatMessageVO
}
from
"@/api/ai/chat/message"
import
{
formatDate
}
from
"@/utils/formatTime"
import
{
useClipboard
}
from
'@vueuse/core'
import
{
marked
}
from
'marked'
// 初始化 copy 到粘贴板
const
{
copy
}
=
useClipboard
();
...
...
@@ -257,6 +256,8 @@ const doSendStream = async (userMessage: ChatMessageVO) => {
}
else
{
const
lastMessage
=
list
.
value
[
list
.
value
.
length
-
1
];
lastMessage
.
content
=
lastMessage
.
content
+
data
.
content
// markdown
lastMessage
.
content
=
marked
(
lastMessage
.
content
)
list
.
value
[
list
.
value
-
1
]
=
lastMessage
}
// 滚动到最下面
...
...
@@ -285,7 +286,15 @@ const messageList = async () => {
try
{
// 获取列表数据
const
res
=
await
ChatMessageApi
.
messageList
(
conversationId
.
value
)
// 处理 markdown
// marked(this.markdownText)
res
.
map
(
item
=>
{
item
.
content
=
marked
(
item
.
content
)
})
list
.
value
=
res
;
// 滚动到最下面
scrollToBottom
();
}
finally
{
...
...
@@ -558,6 +567,7 @@ onMounted(async () => {
.left-text
{
color
:
#393939
;
//
font-size
:
14px
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment