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
58714646
authored
May 21, 2024
by
cherishsince
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
【todo】AI Chat 已删除 Message 组件中的复制、删除文字
parent
138cf760
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
9 additions
and
177 deletions
+9
-177
src/views/ai/chat/Message.vue
+9
-21
src/views/ai/chat/components/MessageList.vue
+0
-156
No files found.
src/views/ai/chat/Message.vue
View file @
58714646
...
@@ -17,14 +17,12 @@
...
@@ -17,14 +17,12 @@
<MarkdownView
class=
"left-text"
:content=
"item.content"
/>
<MarkdownView
class=
"left-text"
:content=
"item.content"
/>
</div>
</div>
<div
class=
"left-btns"
>
<div
class=
"left-btns"
>
<
div
class=
"btn-cus"
@
click=
"noCopy(item.content)"
>
<
el-button
class=
"btn-cus"
link
@
click=
"noCopy(item.content)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/copy.svg"
/>
<img
class=
"btn-image"
src=
"@/assets/ai/copy.svg"
/>
<el-text
class=
"btn-cus-text"
>
复制
</el-text>
</el-button>
</div>
<el-button
class=
"btn-cus"
link
@
click=
"onDelete(item.id)"
>
<div
class=
"btn-cus"
style=
"margin-left: 20px"
@
click=
"onDelete(item.id)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/delete.svg"
style=
"height: 17px"
/>
<img
class=
"btn-image"
src=
"@/assets/ai/delete.svg"
style=
"height: 17px"
/>
<el-text
class=
"btn-cus-text"
>
删除
</el-text>
</el-button>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
...
@@ -43,14 +41,12 @@
...
@@ -43,14 +41,12 @@
<div
class=
"right-text"
>
{{
item
.
content
}}
</div>
<div
class=
"right-text"
>
{{
item
.
content
}}
</div>
</div>
</div>
<div
class=
"right-btns"
>
<div
class=
"right-btns"
>
<
div
class=
"btn-cus"
@
click=
"noCopy(item.content)"
>
<
el-button
class=
"btn-cus"
link
@
click=
"noCopy(item.content)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/copy.svg"
/>
<img
class=
"btn-image"
src=
"@/assets/ai/copy.svg"
/>
<el-text
class=
"btn-cus-text"
>
复制
</el-text>
</el-button>
</div>
<el-button
class=
"btn-cus"
link
@
click=
"onDelete(item.id)"
>
<div
class=
"btn-cus"
style=
"margin-left: 20px"
@
click=
"onDelete(item.id)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/delete.svg"
style=
"height: 17px"
/>
<img
class=
"btn-image"
src=
"@/assets/ai/delete.svg"
style=
"height: 17px"
/>
<el-text
class=
"btn-cus-text"
>
删除
</el-text>
</el-button>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
...
@@ -248,20 +244,12 @@ onMounted(async () => {
...
@@ -248,20 +244,12 @@ onMounted(async () => {
.btn-image
{
.btn-image
{
height
:
20px
;
height
:
20px
;
margin-right
:
5px
;
}
.btn-cus-text
{
color
:
#757575
;
}
}
}
}
.btn-cus
:hover
{
.btn-cus
:hover
{
cursor
:
pointer
;
cursor
:
pointer
;
}
background-color
:
#f6f6f6
;
.btn-cus
:focus
{
background-color
:
#8c939d
;
}
}
}
}
</
style
>
</
style
>
src/views/ai/chat/components/MessageList.vue
deleted
100644 → 0
View file @
138cf760
<
template
>
<div
class=
"message-container"
ref=
"messageContainer"
>
<div
class=
"chat-list"
v-for=
"(item, index) in list"
:key=
"index"
>
<!-- 靠左 message -->
<div
class=
"left-message message-item"
v-if=
"item.type === 'system'"
>
<div
class=
"avatar"
>
<el-avatar
src=
"https://cube.elemecdn.com/0/88/03b0d39583f48206768a7534e55bcpng.png"
/>
</div>
<div
class=
"message"
>
<div>
<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>
<div
class=
"left-btns"
>
<div
class=
"btn-cus"
@
click=
"noCopy(item.content)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/copy.svg"
/>
<el-text
class=
"btn-cus-text"
>
复制
</el-text>
</div>
<div
class=
"btn-cus"
style=
"margin-left: 20px;"
@
click=
"onDelete(item.id)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/delete.svg"
style=
"height: 17px;"
/>
<el-text
class=
"btn-cus-text"
>
删除
</el-text>
</div>
</div>
</div>
</div>
<!-- 靠右 message -->
<div
class=
"right-message message-item"
v-if=
"item.type === 'user'"
>
<div
class=
"avatar"
>
<el-avatar
src=
"https://cube.elemecdn.com/0/88/03b0d39583f48206768a7534e55bcpng.png"
/>
</div>
<div
class=
"message"
>
<div>
<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>
<div
class=
"right-btns"
>
<div
class=
"btn-cus"
@
click=
"noCopy(item.content)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/copy.svg"
/>
<el-text
class=
"btn-cus-text"
>
复制
</el-text>
</div>
<div
class=
"btn-cus"
style=
"margin-left: 20px;"
@
click=
"onDelete(item.id)"
>
<img
class=
"btn-image"
src=
"@/assets/ai/delete.svg"
style=
"height: 17px;"
/>
<el-text
class=
"btn-cus-text"
>
删除
</el-text>
</div>
</div>
</div>
</div>
</div>
</div>
</
template
>
<
script
setup
lang=
"ts"
>
import
{
useClipboard
}
from
'@vueuse/core'
import
{
ChatMessageApi
,
ChatMessageVO
,
ChatMessageSendVO
}
from
'@/api/ai/chat/message'
import
{
formatDate
}
from
'@/utils/formatTime'
// 初始化 copy 到粘贴板
const
{
copy
,
isSupported
}
=
useClipboard
();
/** chat message 列表 */
defineOptions
({
name
:
'chatMessageList'
})
const
list
=
ref
<
ChatMessageVO
[]
>
([])
// 列表的数据
// 对话id TODO @范 先写死
const
conversationId
=
'1781604279872581648'
const
content
=
'苹果是什么颜色?'
/** 查询列表 */
const
messageList
=
async
()
=>
{
try
{
// 获取列表数据
const
res
=
await
ChatMessageApi
.
messageList
(
conversationId
)
list
.
value
=
res
;
// 滚动到最下面
scrollToBottom
();
}
finally
{
}
}
// ref
const
messageContainer
:
any
=
ref
(
null
);
const
isScrolling
=
ref
(
false
)
//用于判断用户是否在滚动
function
scrollToBottom
()
{
nextTick
(()
=>
{
//注意要使用nexttick以免获取不到dom
console
.
log
(
'isScrolling.value'
,
isScrolling
.
value
)
if
(
!
isScrolling
.
value
)
{
messageContainer
.
value
.
scrollTop
=
messageContainer
.
value
.
scrollHeight
-
messageContainer
.
value
.
offsetHeight
}
})
}
function
handleScroll
()
{
const
scrollContainer
=
messageContainer
.
value
const
scrollTop
=
scrollContainer
.
scrollTop
const
scrollHeight
=
scrollContainer
.
scrollHeight
const
offsetHeight
=
scrollContainer
.
offsetHeight
if
(
scrollTop
+
offsetHeight
<
scrollHeight
)
{
// 用户开始滚动并在最底部之上,取消保持在最底部的效果
isScrolling
.
value
=
true
}
else
{
// 用户停止滚动并滚动到最底部,开启保持到最底部的效果
isScrolling
.
value
=
false
}
}
function
noCopy
(
content
)
{
copy
(
content
)
ElMessage
({
message
:
'复制成功!'
,
type
:
'success'
,
})
}
const
onDelete
=
async
(
id
)
=>
{
// 删除 message
await
ChatMessageApi
.
delete
(
id
)
ElMessage
({
message
:
'删除成功!'
,
type
:
'success'
,
})
// 重新获取 message 列表
await
messageList
();
}
/** 初始化 **/
onMounted
(
async
()
=>
{
// 获取列表数据
messageList
();
// scrollToBottom();
// await nextTick
// 监听滚动事件,判断用户滚动状态
messageContainer
.
value
.
addEventListener
(
'scroll'
,
handleScroll
)
})
</
script
>
<
style
scoped
lang=
"scss"
>
</
style
>
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