Browse Source

客服

fix_bug_pro20231227
马远东 1 year ago
parent
commit
f5fc27587f
  1. 2
      src/api/aftersales/aftersalesWorkOrder.js
  2. 12
      src/router/views/index.js
  3. 22
      src/views/aftersales/aftersalesWorkOrder.vue
  4. 26
      src/views/aftersales/aftersalesWorkOrderend.vue
  5. 279
      src/views/aftersales/customerService.vue

2
src/api/aftersales/aftersalesWorkOrder.js

@ -79,7 +79,7 @@ export const update = (row) => {
// 表格初始化
export const $_getList = (params) => {
return request({
url: '/api/logpm-aftersales/aftersalesWorkOrder/list', //listOwn
url: '/api/logpm-aftersales/aftersalesWorkOrder/listOwn', //listOwn
method: 'get',
params
})

12
src/router/views/index.js

@ -1240,6 +1240,18 @@ export default [
},
],
},
{
path: '/aftersales/customerService',
component: Layout,
redirect: '/aftersales/customerService',
children: [
{
path: '/aftersales/customerService',
name: '客服回复',
component: () => import('@/views/aftersales/customerService.vue'),
},
],
},
// {
// path: '/distribution/turndelivery/devtmp',
// component: Layout,

22
src/views/aftersales/aftersalesWorkOrder.vue

@ -1066,8 +1066,7 @@ const CompensationParty = ref([
{ name: '', state: 0, num: null, reason: '', cld: 1 }, //
{ name: '', state: 1, num: null, reason: '', cld: 1 }, //
]); ///
//
const ChatHistory = ref([]);
const details = reactive({
/** 是否开启搜索 */
search: false,
@ -1507,6 +1506,7 @@ const CompletionButton = val => {
};
//
const addingRecord = val => {
console.log(val);
$router.push({
path: '/aftersales/aftersalesWorkOrderend',
query: {
@ -1899,6 +1899,12 @@ const FKList = () => {
};
//
const reply = val => {
$router.push({
path:'/aftersales/customerService',
query:{
row:JSON.stringify(val.row),
}
});
console.log(val, 'ID++++++++');
console.log(val.row);
dialogcustomerService.value = true; //
@ -2734,6 +2740,9 @@ const CompletedSubmission = () => {
display: flex;
align-items: center;
}
:deep(.el-tab-pane){
padding: 10px;
}
}
.paySum {
margin-top: 36px;
@ -2773,4 +2782,13 @@ const CompletedSubmission = () => {
:deep(.avue-crud__pagination){
padding-top: 2px !important;
}
.arbitrate{
margin-top: 36px;
.el_btn{
margin-top: 10px;
}
:deep(.el-tabs__content){
padding: 0 !important;
}
}
</style>

26
src/views/aftersales/aftersalesWorkOrderend.vue

@ -305,7 +305,10 @@
>{{ item.state == 0 ? '赔款方' : '收款方' }}{{ item.cld }}</span
>
<div class="sk_input">
<el-input v-model="item.name" :placeholder="item.state == 0 ? '请填写赔款方' : '请填写收款方'"/>
<el-input
v-model="item.name"
:placeholder="item.state == 0 ? '请填写赔款方' : '请填写收款方'"
/>
</div>
<div class="sk_input">
<el-input v-model="item.reason" placeholder="请填写原因" />
@ -387,11 +390,12 @@ import { getDetailWarehouse, getDeptWarehouse } from '@/api/basicdata/basicdataW
import { $_getInfo, $_addSubmit, $_addCompletionEnd } from '@/api/aftersales/aftersalesWorkOrder';
import { columnList, recordList } from '@/option/aftersales/vueTvemp.js';
import { getToken } from '@/utils/auth';
import { useRoute } from 'vue-router';
import { useRoute, useRouter } from 'vue-router';
import { getDictionaryBiz } from '@/api/system/dict';
import { computeNumber, isNumer } from '@/utils/util';
const ZFdialog = ref(false); //
const $route = useRoute();
const $router = useRouter();
const Paymentmethod = ref([]); //
const ZFname = ref(''); //
const routeData = ref(false); //
@ -880,9 +884,16 @@ const submit = () => {
console.log(data, '处理好的值');
$_addCompletionEnd(data).then(res => {
$router.push('/aftersales/aftersalesWorkOrder');
console.log(res, '完结成功返回值');
if (res.data.code == 200) {
ElMessage({
showClose: true,
message: res.data.msg,
type: 'success',
});
}
});
} else {
//
console.log(ProcessingList.value, 'ProcessingList12312');
@ -948,6 +959,15 @@ const submit = () => {
delete data['packageImage']; //
$_addSubmit(data).then(res => {
console.log(res, '提交后的参数');
$router.push('/aftersales/aftersalesWorkOrder');
console.log(res, '完结成功返回值');
if (res.code == 200) {
ElMessage({
showClose: true,
message: res.data.msg,
type: 'success',
});
}
});
}
};

279
src/views/aftersales/customerService.vue

@ -0,0 +1,279 @@
<template>
<div >
1231
</div>
<div class="content" ref="scrollContainer">
<!-- 用户 -->
<div
:class="{ YH: item.businessId != currentUser, KF: item.businessId == currentUser }"
v-for="item in ChatHistory"
:key="item.input"
>
<div class="box">
<div class="TX"></div>
<div class="name">
<span>{{ item.businessName }}</span>
<div class="input">
{{ item.content }}
</div>
<div class="time">{{ item.createTime }}</div>
</div>
</div>
</div>
</div>
<div class="inputTextarea" v-loading="iconState" element-loading-text="正在发送中...">
<div class="fell">
<el-upload
ref="uploadRef"
class="upload-demo"
:action="doubledCount"
:headers="headers"
:on-success="fellSuccess"
>
<template #trigger>
<el-button type="primary">上传附件</el-button>
<div class="felltis" v-if="KFfeel">上传成功</div>
</template>
</el-upload>
<el-input
@keydown.enter="inputEnter"
v-model="KFinput"
:rows="4"
type="textarea"
placeholder="请输入内容"
/>
</div>
<el-button class="btn_fs" type="primary" @click="messagesend">发送</el-button>
</div>
</template>
<script setup>
import { $_AddReply, $_getExchangeList } from '@/api/aftersales/aftersalesWorkOrder';
import { useRoute } from 'vue-router';
const ChatHistory = ref([]); //
const scrollContainer = ref(null); //
const KFfeel = ref(''); //
const iconState = ref(false); //
const KFinput = ref(''); //
const ListRow = ref(); //
const $route = useRoute();
const Mydata = ref(null); //
import { ElMessage } from 'element-plus';
import { ElMessageBox } from 'element-plus';
import { getToken } from '@/utils/auth';
//
const FKList = () => {
iconState.value = true;
let data = { workOrderId: ListRow.value.id };
$_getExchangeList(data).then(res => {
iconState.value = false;
console.log(res, '查询的值');
ChatHistory.value = res.data.data;
setTimeout(() => {
const container = scrollContainer.value;
if (container) {
container.scrollTop = container.scrollHeight;
}
}, 0);
});
};
//
const onLoad = () => {
ListRow.value =$route.query;
Mydata.value = JSON.parse(localStorage.getItem('my_data')); //
console.log( ListRow.value, '路由参数');
FKList();
};
onLoad();
//
const messagesendFn = () => {
iconState.value = true;
let data = {
workOrderId: ListRow.value.id,
businessName: Mydata.value.departmentName,
businessId: Mydata.value.id,
content: KFinput.value,
warehouseId: ListRow.value.warehouseId,
annex: KFfeel.value,
};
console.log(data, '处理好的数据');
$_AddReply(data).then(res => {
//
const currentTime = new Date();
//
const year = String(currentTime.getFullYear());
const month = String(currentTime.getMonth() + 1).padStart(2, '0');
const day = String(currentTime.getDate()).padStart(2, '0');
const hours = String(currentTime.getHours()).padStart(2, '0');
const minutes = String(currentTime.getMinutes()).padStart(2, '0');
const seconds = String(currentTime.getSeconds()).padStart(2, '0');
//
const formattedTime = `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
console.log(res, '添加成功');
if (res.data.code == 200) {
//
iconState.value = false;
ChatHistory.value.push({
businessId: Mydata.value.id,
businessName: Mydata.value.departmentName,
content: KFinput.value,
createTime: formattedTime,
});
//
setTimeout(() => {
const container = scrollContainer.value;
if (container) {
container.scrollTop = container.scrollHeight;
}
}, 0);
KFinput.value = ''; //
KFfeel.value = null; //
}
});
console.log(Mydata.value, '参数');
};
//
const inputEnter = () => {
messagesendFn();
};
//
const KFRefresh = () => {
FKList();
};
//
const messagesend = () => {
messagesendFn();
};
//
const doubledCount = computed(() => {
return '/api/blade-resource/oss/endpoint/put-file';
});
// TOKEN
const headers = computed(() => {
return { 'Blade-Auth': 'Bearer ' + getToken() };
});
//
const fellSuccess = (response, uploadFile) => {
console.log('上船成功');
console.log(response, uploadFile);
if (response.data.link) {
KFfeel.value = response.data.link;
}
};
</script>
<style scoped lang="scss">
.content {
width: 100%;
height: 300px;
overflow-y: scroll;
scroll-behavior: smooth;
/* 添加平滑滚动效果 */
border-radius: 5px;
.YH {
width: 100%;
min-height: 50px;
margin: 4px 0;
display: flex;
flex-direction: row;
.box {
width: 386px;
height: 100%;
display: flex;
flex-direction: row;
justify-content: space-between;
.name {
display: flex;
flex-direction: column;
span {
display: flex;
justify-content: flex-start;
padding-left: 10px;
margin-bottom: 10px;
}
.time {
display: flex;
justify-content: flex-end;
padding: 0 10px;
margin-top: 4px;
}
}
}
.input {
border: 1px solid;
width: 300px;
min-height: 30px;
box-sizing: border-box;
border-radius: 8px;
padding: 8px;
margin: 0 6px;
text-indent: 2em;
position: relative;
.ico {
position: absolute;
right: -6%;
bottom: 0;
}
}
}
.KF {
width: 100%;
min-height: 50px;
margin: 4px 0;
display: flex;
justify-content: flex-end;
.box {
width: 386px;
height: 100%;
display: flex;
flex-direction: row-reverse;
justify-content: space-between;
.name {
display: flex;
flex-direction: column;
span {
display: flex;
justify-content: flex-end;
padding-right: 10px;
margin-bottom: 10px;
}
.time {
display: flex;
justify-content: flex-start;
padding: 0 10px;
margin-top: 4px;
}
}
}
.input {
border: 1px solid;
width: 300px;
min-height: 30px;
box-sizing: border-box;
border-radius: 8px;
padding: 8px;
margin: 0 6px;
text-indent: 2em;
position: relative;
.ico {
position: absolute;
left: -16%;
bottom: 0;
}
}
}
.TX {
height: 50px;
width: 50px;
border-radius: 50%;
border: 1px solid #ccc;
background: url('../../../public/img/tx.png') no-repeat;
background-size: cover;
}
}
</style>
Loading…
Cancel
Save