Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
company_app
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
毛细亚
company_app
Commits
aa37eebc
提交
aa37eebc
authored
9月 16, 2025
作者:
毛细亚
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
🐞
fix: 优化客服对话框样式和交互
上级
3bad689a
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
42 行增加
和
43 行删除
+42
-43
ServiceMessageDialog.vue
src/views/components/quickSendGame/ServiceMessageDialog.vue
+40
-34
sendGame.vue
src/views/components/quickSendGame/sendGame.vue
+0
-4
vipTools.vue
src/views/components/quickSendGame/vipTools.vue
+1
-1
quickSendGame.vue
src/views/quickSendGame.vue
+1
-4
没有找到文件。
src/views/components/quickSendGame/ServiceMessageDialog.vue
浏览文件 @
aa37eebc
<
template
>
<
template
>
<div
class=
"service-message-dialog"
>
<div
class=
"service-message-dialog"
>
<el-popover
placement=
"top"
trigger=
"hover"
content=
"发送客服二维码"
>
<svg-icon
slot=
"reference"
icon-class=
"kfworks"
class=
"service-message-dialog__icon"
@
click=
"show"
/>
</el-popover>
<el-dialog
title=
"客服号添加二维码"
:visible
.
sync=
"visible"
width=
"500px"
@
close=
"handleClose"
>
<div
v-if=
"taskStatus.is_band"
>
<div
v-if=
"taskStatus.is_band"
>
<div
class=
"service-message-dialog__title"
>
<div
class=
"service-message-dialog__title"
>
VIP客服:
VIP客服:
...
@@ -12,20 +8,22 @@
...
@@ -12,20 +8,22 @@
</span>
</span>
</div>
</div>
<div
class=
"service-message-dialog__info"
>
<div
class=
"service-message-dialog__info"
>
<i
class=
"el-icon-info"
></i>
当前有转VIP/SVIP任务,请推送指定客服的客服号
当前有转VIP/SVIP任务,请推送指定客服的客服号
</div>
</div>
</div>
</div>
<div
v-else
class=
"service-message-dialog__info"
>
<div
v-else
class=
"service-message-dialog__info"
>
<i
class=
"el-icon-info"
></i>
当前无分配转VIP/SVIP任务
当前无分配转VIP/SVIP任务
</div>
</div>
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"100px
"
>
<el-form
ref=
"form"
:model=
"form"
label-position=
"top"
:rules=
"rules"
label-width=
"100px"
style=
"margin-top: 10px;
"
>
<el-form-item
label=
"客服类型"
prop=
"service_type"
>
<el-form-item
label=
"客服类型
:
"
prop=
"service_type"
>
<el-select
v-model=
"form.service_type"
:clearable=
"false"
placeholder=
"请选择客服类型"
style=
"width:100%;"
<el-select
v-model=
"form.service_type"
:clearable=
"false"
placeholder=
"请选择客服类型"
style=
"width:100%;"
@
change=
"handleServiceTypeChange"
>
@
change=
"handleServiceTypeChange"
>
<el-option
v-for=
"item in serviceTypeOptions"
:key=
"item.value"
:label=
"item.label"
:value=
"item.value"
/>
<el-option
v-for=
"item in serviceTypeOptions"
:key=
"item.value"
:label=
"item.label"
:value=
"item.value"
/>
</el-select>
</el-select>
</el-form-item>
</el-form-item>
<el-form-item
label=
"客服号"
prop=
"service_id"
>
<el-form-item
label=
"客服号
:
"
prop=
"service_id"
>
<el-select
v-model=
"form.service_id"
style=
"width:100%;"
:clearable=
"false"
:loading=
"loading"
<el-select
v-model=
"form.service_id"
style=
"width:100%;"
:clearable=
"false"
:loading=
"loading"
placeholder=
"请选择客服号"
>
placeholder=
"请选择客服号"
>
<el-option
v-for=
"item in serviceList"
:key=
"item.id"
:label=
"item.service_wechat_number_name"
<el-option
v-for=
"item in serviceList"
:key=
"item.id"
:label=
"item.service_wechat_number_name"
...
@@ -33,23 +31,21 @@
...
@@ -33,23 +31,21 @@
</el-select>
</el-select>
</el-form-item>
</el-form-item>
</el-form>
</el-form>
<div
slot=
"footer
"
>
<div
class=
"rowFlex rowEnd"
style=
"margin-top: 20px;
"
>
<el-button
@
click=
"handleClose"
>
取 消
</el-button>
<el-button
size=
"mini"
@
click=
"handleClose"
>
取 消
</el-button>
<el-button
type=
"primary"
:loading=
"submitting"
@
click=
"handleSubmit"
>
确 定
</el-button>
<el-button
size=
"mini"
type=
"primary"
:loading=
"submitting"
@
click=
"handleSubmit"
>
确 定
</el-button>
</div>
</div>
</el-dialog>
</div>
</div>
</
template
>
</
template
>
<
script
>
<
script
>
import
{
searchcondition
,
getTaskTracer
,
memberTaskStatus
,
getTaskTracerTouch
,
getTaskTracerTouchAdd
}
from
'@/api/game'
import
{
searchcondition
,
getTaskTracer
,
memberTaskStatus
,
getTaskTracerTouch
,
getTaskTracerTouchAdd
}
from
'@/api/game'
import
{
mapState
,
mapMutations
}
from
'vuex'
import
{
mapState
}
from
'vuex'
import
{
sendChatMessage
}
from
'@/utils/index'
export
default
{
export
default
{
name
:
'ServiceMessageDialog'
,
name
:
'ServiceMessageDialog'
,
data
()
{
data
()
{
return
{
return
{
visible
:
false
,
loading
:
false
,
loading
:
false
,
submitting
:
false
,
submitting
:
false
,
form
:
{
form
:
{
...
@@ -73,7 +69,7 @@ export default {
...
@@ -73,7 +69,7 @@ export default {
},
},
computed
:
{
computed
:
{
...
mapState
(
'game'
,
[
'accountSelect'
]),
...
mapState
(
'game'
,
[
'accountSelect'
]),
...
mapState
(
'user'
,
[
'
userInfo
'
])
...
mapState
(
'user'
,
[
'
cser_name
'
])
},
},
watch
:
{
watch
:
{
accountSelect
:
{
accountSelect
:
{
...
@@ -81,26 +77,21 @@ export default {
...
@@ -81,26 +77,21 @@ export default {
immediate
:
true
immediate
:
true
}
}
},
},
mounted
()
{
if
(
this
.
accountSelect
)
{
this
.
initData
()
}
else
{
this
.
$message
.
error
(
'请关联W账号'
)
}
},
methods
:
{
methods
:
{
...
mapMutations
(
'common'
,
[
'set_sendSkillMessage'
]),
// 初始化数据
// 初始化数据
async
initData
()
{
async
initData
()
{
if
(
!
this
.
accountSelect
)
return
await
Promise
.
all
([
await
Promise
.
all
([
this
.
getTaskTracer
(),
this
.
getTaskTracer
(),
this
.
memberTaskStatus
()
this
.
memberTaskStatus
()
])
])
},
},
show
()
{
if
(
this
.
accountSelect
&&
this
.
accountSelect
!==
''
)
{
this
.
visible
=
true
this
.
initData
()
}
else
{
this
.
$message
.
error
(
'请关联W账号'
)
}
},
// 获取任务状态
// 获取任务状态
async
memberTaskStatus
()
{
async
memberTaskStatus
()
{
try
{
try
{
...
@@ -133,7 +124,6 @@ export default {
...
@@ -133,7 +124,6 @@ export default {
handleClose
()
{
handleClose
()
{
this
.
$refs
.
form
.
resetFields
()
this
.
$refs
.
form
.
resetFields
()
this
.
visible
=
false
this
.
loading
=
false
this
.
loading
=
false
this
.
submitting
=
false
this
.
submitting
=
false
},
},
...
@@ -169,24 +159,20 @@ export default {
...
@@ -169,24 +159,20 @@ export default {
// 发送消息
// 发送消息
async
sendMessage
(
image_url
)
{
async
sendMessage
(
image_url
)
{
const
list
=
[{
msgtype
:
'image'
,
image
:
{
picurl
:
image_url
}
}]
await
this
.
getTaskTracerTouch
()
await
this
.
getTaskTracerTouch
()
if
(
this
.
taskStatus
.
is_band
)
{
if
(
this
.
taskStatus
.
is_band
)
{
await
this
.
getTaskTracerTouchAdd
()
await
this
.
getTaskTracerTouchAdd
()
}
}
await
sendChatMessage
(
image_url
,
'image'
)
// 生成二维码有延迟 立即发送会导致二维码加载失败 加个小延迟解决问题
// 生成二维码有延迟 立即发送会导致二维码加载失败 加个小延迟解决问题
setTimeout
(()
=>
{
setTimeout
(()
=>
{
this
.
submitting
=
false
this
.
submitting
=
false
this
.
set_sendSkillMessage
(
list
)
this
.
handleClose
()
this
.
handleClose
()
},
2000
)
},
2000
)
},
},
// 发送的时候如果当前W 账号如果有 转 vip/svip的任务 记录一条发送日志
// 发送的时候如果当前W 账号如果有 转 vip/svip的任务 记录一条发送日志
async
getTaskTracerTouchAdd
()
{
async
getTaskTracerTouchAdd
()
{
const
res
=
await
getTaskTracerTouchAdd
({
member_id
:
this
.
accountSelect
,
zw_user_name
:
this
.
userInfo
.
user
name
})
const
res
=
await
getTaskTracerTouchAdd
({
member_id
:
this
.
accountSelect
,
zw_user_name
:
this
.
cser_
name
})
},
},
// 获取任务追踪者接触信息记录日志
// 获取任务追踪者接触信息记录日志
async
getTaskTracerTouch
()
{
async
getTaskTracerTouch
()
{
...
@@ -230,6 +216,11 @@ export default {
...
@@ -230,6 +216,11 @@ export default {
<
style
lang=
"scss"
scoped
>
<
style
lang=
"scss"
scoped
>
.service-message-dialog
{
.service-message-dialog
{
padding-top
:
30px
;
position
:
relative
;
::v-deep
.el-form-item__label{
line-height
:
35px
;
}
&
__icon
{
&
__icon
{
font-size
:
23px
;
font-size
:
23px
;
margin-left
:
20px
;
margin-left
:
20px
;
...
@@ -258,6 +249,21 @@ export default {
...
@@ -258,6 +249,21 @@ export default {
text-align
:
justify
;
text-align
:
justify
;
font-style
:
normal
;
font-style
:
normal
;
margin-bottom
:
10px
;
margin-bottom
:
10px
;
position
:
absolute
;
left
:
0
;
top
:
0px
;
width
:
100%
;
height
:
28px
;
background
:
#F4F4F5
;
border-radius
:
0px
0px
0px
0px
;
display
:
flex
;
align-items
:
center
;
padding
:
0
20px
;
border-radius
:
5px
;
i{
font-size
:
18px
;
margin-right
:
5px
;
}
}
}
}
}
...
...
src/views/components/quickSendGame/sendGame.vue
浏览文件 @
aa37eebc
...
@@ -1121,13 +1121,9 @@ export default {
...
@@ -1121,13 +1121,9 @@ export default {
width
:
100%
;
width
:
100%
;
height
:
100%
;
height
:
100%
;
overflow
:
auto
;
overflow
:
auto
;
margin-top
:
-10px
;
.createChannel
{
.createChannel
{
font-size
:
14px
;
font-size
:
14px
;
margin-top
:
16px
;
padding
:
0
16px
;
padding
:
0
16px
;
.label
{
.label
{
color
:
#878787
;
color
:
#878787
;
font-size
:
12px
;
font-size
:
12px
;
...
...
src/views/components/quickSendGame/vipTools.vue
浏览文件 @
aa37eebc
...
@@ -324,7 +324,7 @@ export default {
...
@@ -324,7 +324,7 @@ export default {
width
:
100%
;
width
:
100%
;
height
:
100%
;
height
:
100%
;
overflow
:
auto
;
overflow
:
auto
;
padding-top
:
15px
;
.sendLink
{
.sendLink
{
width
:
150px
;
width
:
150px
;
height
:
25px
;
height
:
25px
;
...
...
src/views/quickSendGame.vue
浏览文件 @
aa37eebc
...
@@ -29,7 +29,7 @@
...
@@ -29,7 +29,7 @@
import
vipTools
from
'./components/quickSendGame/vipTools.vue'
import
vipTools
from
'./components/quickSendGame/vipTools.vue'
import
sendGame
from
'./components/quickSendGame/sendGame.vue'
import
sendGame
from
'./components/quickSendGame/sendGame.vue'
import
{
mapActions
}
from
'vuex'
import
{
mapActions
}
from
'vuex'
import
sendQrCode
from
'./components/quickSendGame/
/
ServiceMessageDialog.vue'
import
sendQrCode
from
'./components/quickSendGame/ServiceMessageDialog.vue'
export
default
{
export
default
{
name
:
'quickSendGame'
,
name
:
'quickSendGame'
,
components
:
{
components
:
{
...
@@ -89,9 +89,6 @@ export default {
...
@@ -89,9 +89,6 @@ export default {
.content
{
.content
{
width
:
100%
;
width
:
100%
;
height
:
calc
(
100%
-
10px
);
height
:
calc
(
100%
-
10px
);
::v-deep
.el-tabs__header
{
margin
:
0
0
20px
;
}
}
}
::v-deep
.el-tabs--border-card
.is-active
{
::v-deep
.el-tabs--border-card
.is-active
{
border
:
none
!important
;
border
:
none
!important
;
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论