583 lines
12 KiB
Vue
583 lines
12 KiB
Vue
<template>
|
|
<view class="app">
|
|
<!-- 家医 -->
|
|
<view class="" v-if="status==1">
|
|
<u-tabs :list="tabslist" :is-scroll="false" :current="tabscurrent" @change="tabschange"
|
|
inactive-color='#fff' active-color='#fff'></u-tabs>
|
|
<view class="inputs">
|
|
<i class="icon"></i>
|
|
<input type="text" name="" id="" class="input" placeholder="搜索" v-model="formdata.name">
|
|
</view>
|
|
<view class="lists" v-if="listinfo">
|
|
<view class="item" v-for="item in listinfo" @tap='goseekadvicefrom(item)'>
|
|
<view class="time">
|
|
{{item.createTime?item.createTime:''}}
|
|
</view>
|
|
<image src="../../static/headsculpture.png" mode=""></image>
|
|
<view class="name">
|
|
{{item.patientName?item.patientName+' ':' '}}
|
|
( {{item.problemDescription?item.problemDescription:''}} )
|
|
</view>
|
|
<view class="text">
|
|
{{Number(item.messageType)==2?'[图片]':item.content}}
|
|
</view>
|
|
<view class="count" v-if="item.messageCount>0">
|
|
{{item.messageCount}}
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="" v-if="status==2">
|
|
<protocol :Refresh="Refresh" :down='down'>
|
|
</protocol>
|
|
</view>
|
|
<u-toast ref="uToast" />
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import {
|
|
getList,
|
|
updateStatus,
|
|
closeHealthConsultationOrder,
|
|
consultationInfolist,
|
|
getUserSig,
|
|
consultation,
|
|
} from '@/api/homepage/index.js'
|
|
import {
|
|
getSex
|
|
} from '@/utils/conversion.js'
|
|
import protocol from '@/pages/workorder/workorder.vue'
|
|
import socketurl from '@/api/socketurl.js'
|
|
export default {
|
|
components: {
|
|
protocol,
|
|
},
|
|
data() {
|
|
return {
|
|
Refresh: 1,
|
|
down: 1,
|
|
tabslist: [{
|
|
name: '全部',
|
|
value: '',
|
|
}, {
|
|
name: '已解决',
|
|
value: '2',
|
|
}, {
|
|
name: '未解决',
|
|
value: '1',
|
|
}],
|
|
tabscurrent: 0,
|
|
optionindex: 0,
|
|
optionname: '全部',
|
|
missionlist: [],
|
|
missiontotal: 0,
|
|
remark: '',
|
|
formdata: {
|
|
pageNum: 1,
|
|
pageSize: 1000,
|
|
doctorId: uni.getStorageSync("id"),
|
|
consultationType: 'IMAGE_TEXT_CONSULTATION',
|
|
status: '',
|
|
},
|
|
listinfo: [],
|
|
listtotal: 0,
|
|
status: '',
|
|
SOCKETURL: '',
|
|
socketOpen: false,
|
|
timeoutObj: null,
|
|
status: '',
|
|
title: '',
|
|
}
|
|
},
|
|
onReady() { //更改导航栏文字
|
|
uni.setNavigationBarTitle({
|
|
title: this.title,
|
|
});
|
|
},
|
|
onLoad() {
|
|
this.status = uni.getStorageSync("status")
|
|
if (this.status == 2) {
|
|
this.title = '工单'
|
|
} else {
|
|
this.title = '消息列表'
|
|
this.SOCKETURL = socketurl + uni.getStorageSync("id")
|
|
this.connectSocket();
|
|
}
|
|
},
|
|
onShow() {
|
|
this.down = 1
|
|
this.Refresh = 1
|
|
if (this.status == 1) {
|
|
this.info()
|
|
this.socket();
|
|
}
|
|
},
|
|
methods: {
|
|
connectSocket() {
|
|
let that = this
|
|
console.log(that.SOCKETURL)
|
|
try {
|
|
uni.connectSocket({
|
|
url: that.SOCKETURL
|
|
})
|
|
uni.onSocketOpen(res => {
|
|
console.log('webScoket连接已打开', res);
|
|
that.socketOpen = true
|
|
that.reset()
|
|
})
|
|
uni.onSocketError(err => {
|
|
console.log('webScoket连接打开失败', err);
|
|
if (err && err.code != 1000) {
|
|
setTimeout(() => {
|
|
that.socketOpen = true
|
|
uni.connectSocket({
|
|
url: that.SOCKETURL
|
|
})
|
|
}, 3 * 1000)
|
|
}
|
|
})
|
|
uni.onSocketClose(err => {
|
|
console.log('webScoket连接关闭', err);
|
|
if (err && err.code !== 1000) {
|
|
setTimeout(() => {
|
|
that.socketOpen = true
|
|
uni.connectSocket({
|
|
url: that.SOCKETURL
|
|
})
|
|
}, 3 * 1000)
|
|
}
|
|
})
|
|
} catch (e) {
|
|
console.log(e);
|
|
}
|
|
},
|
|
socket() {
|
|
let that = this
|
|
uni.onSocketMessage(res => {
|
|
console.log("webScoket监听收到的信息", res);
|
|
that.info();
|
|
})
|
|
},
|
|
reset() {
|
|
let that = this
|
|
clearInterval(that.timeoutObj);
|
|
that.timeoutObj = setInterval(() => {
|
|
uni.sendSocketMessage({
|
|
data: 'ping',
|
|
success(res) {
|
|
console.log('正在发送心跳');
|
|
},
|
|
fail(err) {
|
|
console.log('心跳发送失败,重新连接...');
|
|
that.socketOpen = true
|
|
uni.connectSocket({
|
|
url: that.SOCKETURL
|
|
})
|
|
}
|
|
})
|
|
}, 180000)
|
|
},
|
|
//前往聊天
|
|
goseekadvicefrom(item) {
|
|
uni.navigateTo({
|
|
url: `/pages/seekadvicefrom/seekadvicefrom?item=${JSON.stringify(item)}`
|
|
// url: '/pages/seekadvicefrom/seekadvicefrom'
|
|
})
|
|
},
|
|
//详情
|
|
gotaskDetails(item) {
|
|
uni.navigateTo({
|
|
url: `/pages/taskDetails/taskDetails?id=${item.consultationInfoId}&title=${item.orderStatus}`
|
|
})
|
|
},
|
|
//完成
|
|
goconfirmCompletion(item) {
|
|
var obj = {
|
|
"goodsOrderId": item.goodsOrderId,
|
|
"orderStatus": "COMPLETED",
|
|
}
|
|
updateStatus(obj).then(res => {
|
|
if (res.code == 200) {
|
|
this.$refs.uToast.show({
|
|
title: '工单已成功',
|
|
type: 'success',
|
|
duration: '1500'
|
|
})
|
|
this.info();
|
|
}
|
|
})
|
|
},
|
|
//任务退回
|
|
gotaskReturn(item) {
|
|
uni.navigateTo({
|
|
url: `/pages/taskReturn/taskReturn?item=${JSON.stringify(item)}`
|
|
})
|
|
},
|
|
//接单
|
|
Receivingorders(item) {
|
|
var obj = {
|
|
"goodsOrderId": item.goodsOrderId,
|
|
"orderStatus": "RECEIVED_GOODS",
|
|
}
|
|
updateStatus(obj).then(res => {
|
|
if (res.code == 200) {
|
|
this.$refs.uToast.show({
|
|
title: '接单成功',
|
|
type: 'success',
|
|
duration: '1500'
|
|
})
|
|
this.info();
|
|
}
|
|
})
|
|
},
|
|
// 视频通话
|
|
govideo(item) {
|
|
uni.navigateTo({
|
|
url: `/pages/Industrialbutler/Industrialbutler?item=${JSON.stringify(item)}`
|
|
})
|
|
},
|
|
info() {
|
|
this.formdata.pageNum = 1
|
|
consultationInfolist(this.formdata).then(res => {
|
|
this.listinfo = res.rows
|
|
this.listtotal = res.total
|
|
})
|
|
},
|
|
tabschange(index) {
|
|
this.tabscurrent = index;
|
|
this.formdata.status = this.tabslist[index].value
|
|
// this.optionname = '全部'
|
|
this.optionindex = 0
|
|
this.info();
|
|
},
|
|
// dropitemchange(e) {
|
|
// this.optionname = this.options.find(m => m.value === e).label
|
|
// this.query.orderStatus = this.options.find(m => m.value === e).value
|
|
// this.info();
|
|
// },
|
|
},
|
|
onReachBottom() { //下滑加载
|
|
if (this.status == 1) {
|
|
if (this.listinfo.length >= this.listtotal) {} else {
|
|
this.formdata.pageNum++
|
|
consultationInfolist(this.formdata).then(res => {
|
|
res.rows.forEach(e => {
|
|
this.listinfo.push(e)
|
|
})
|
|
})
|
|
}
|
|
} else {
|
|
this.down++
|
|
}
|
|
},
|
|
onPullDownRefresh() { //下拉刷新
|
|
if (this.status == 1) {
|
|
this.info();
|
|
} else {
|
|
this.Refresh++
|
|
this.down = 1
|
|
}
|
|
setTimeout(function() {
|
|
uni.stopPullDownRefresh();
|
|
}, 1000);
|
|
},
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
page {
|
|
background-color: #fff;
|
|
}
|
|
|
|
.app {
|
|
width: 100%;
|
|
// margin: 20rpx auto;
|
|
padding: 0 0 100rpx 0;
|
|
background-color: #fff;
|
|
font-size: 24rpx;
|
|
|
|
.lists {
|
|
width: 96%;
|
|
margin: 0 auto;
|
|
|
|
.item {
|
|
position: relative;
|
|
height: 240rpx;
|
|
margin: 10rpx auto;
|
|
background: #F6F6F6;
|
|
border-radius: 10rpx;
|
|
|
|
.time {
|
|
width: 100%;
|
|
padding-left: 20rpx;
|
|
height: 80rpx;
|
|
line-height: 80rpx;
|
|
border-bottom: 2rpx solid #DADADA;
|
|
font-size: 26rpx;
|
|
font-weight: 400;
|
|
color: #5F5F5F;
|
|
}
|
|
|
|
.count {
|
|
position: absolute;
|
|
right: 10rpx;
|
|
bottom: 50rpx;
|
|
width: 28rpx;
|
|
height: 28rpx;
|
|
background: #FF0000;
|
|
border-radius: 50%;
|
|
text-align: center;
|
|
line-height: 28rpx;
|
|
color: #fff;
|
|
font-weight: 400;
|
|
color: #FFFFFF;
|
|
}
|
|
|
|
.text {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #999999;
|
|
position: absolute;
|
|
left: 160rpx;
|
|
top: 160rpx;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
width: calc(100% - 220rpx);
|
|
}
|
|
|
|
.name {
|
|
position: absolute;
|
|
left: 160rpx;
|
|
top: 100rpx;
|
|
font-size: 28rpx;
|
|
font-weight: 400;
|
|
color: #333333;
|
|
}
|
|
|
|
image {
|
|
position: absolute;
|
|
top: 90rpx;
|
|
left: 20rpx;
|
|
width: 110rpx;
|
|
height: 110rpx;
|
|
border-radius: 50%;
|
|
}
|
|
}
|
|
}
|
|
|
|
.inputs {
|
|
background-color: #fff;
|
|
border-radius: 5rpx;
|
|
background-color: #ffffff;
|
|
z-index: 999;
|
|
position: relative;
|
|
top: 50%;
|
|
background: #F6F6F6;
|
|
border-radius: 10rpx;
|
|
width: 96%;
|
|
height: 60rpx;
|
|
transform: none;
|
|
margin: 20rpx auto;
|
|
|
|
.input {
|
|
margin: 0 auto;
|
|
position: absolute;
|
|
height: 60rpx;
|
|
// top: 8%;
|
|
left: 13%;
|
|
width: 80%;
|
|
font-size: 26rpx;
|
|
color: #000000;
|
|
}
|
|
|
|
.icon {
|
|
background: url(@/static/sousuo.png) no-repeat;
|
|
width: 30rpx;
|
|
height: 28rpx;
|
|
background-size: cover;
|
|
position: absolute;
|
|
top: 50%;
|
|
transform: translateY(-50%);
|
|
left: 3%;
|
|
}
|
|
}
|
|
|
|
.btnss {
|
|
display: flex;
|
|
text-align: center;
|
|
border-top: 1rpx solid #f6f6f6;
|
|
font-size: 32rpx;
|
|
line-height: 100rpx;
|
|
width: 100%;
|
|
position: absolute;
|
|
bottom: 0;
|
|
|
|
.cancel {
|
|
width: 50%;
|
|
height: 100rpx;
|
|
border-right: 0.5rpx solid #f6f6f6;
|
|
}
|
|
|
|
.Rescind {
|
|
width: 50%;
|
|
height: 100rpx;
|
|
color: #18CBB3;
|
|
border-left: 0.5rpx solid #f6f6f6;
|
|
}
|
|
}
|
|
|
|
.items {
|
|
width: 96%;
|
|
margin: 0 auto;
|
|
|
|
.item {
|
|
margin: 15rpx auto;
|
|
background-color: #fff;
|
|
box-shadow: 0rpx 9rpx 31rpx 9rpx rgba(0, 0, 0, 0.03);
|
|
border-radius: 5rpx;
|
|
padding: 3%;
|
|
width: 100%;
|
|
position: relative;
|
|
color: #333333;
|
|
font-size: 30rpx;
|
|
padding-bottom: 60rpx;
|
|
|
|
.tabscurrent {
|
|
width: 100%;
|
|
padding: 30rpx;
|
|
margin: 0 auto;
|
|
background: #F7F9F8;
|
|
border-radius: 14rpx;
|
|
}
|
|
|
|
.btns {
|
|
margin-top: 60rpx;
|
|
display: flex;
|
|
position: relative;
|
|
height: 30rpx;
|
|
|
|
.text {
|
|
// width: 82rpx;
|
|
height: 27rpx;
|
|
font-size: 28rpx;
|
|
font-weight: 500;
|
|
color: #E57726;
|
|
line-height: 55rpx;
|
|
}
|
|
|
|
.btnaccept,
|
|
.btnreturn {
|
|
width: 170rpx;
|
|
height: 60rpx;
|
|
text-align: center;
|
|
line-height: 55rpx;
|
|
border-radius: 50rpx;
|
|
border: 1px solid #18CBB3;
|
|
position: absolute;
|
|
}
|
|
|
|
.btnaccept {
|
|
right: 24rpx;
|
|
color: #fff;
|
|
background-color: #18CBB3;
|
|
}
|
|
|
|
.btnreturn {
|
|
right: 220rpx;
|
|
color: #18CBB3;
|
|
background: #FFFFFF;
|
|
}
|
|
}
|
|
|
|
.itemimg {
|
|
position: absolute;
|
|
right: 15rpx;
|
|
top: 18rpx;
|
|
width: 140rpx;
|
|
height: 120rpx;
|
|
}
|
|
|
|
.title {
|
|
font-size: 32rpx;
|
|
line-height: 100rpx;
|
|
border-bottom: 1rpx solid #E6E6E6;
|
|
color: #333333;
|
|
position: relative;
|
|
height: 100rpx;
|
|
|
|
.text {
|
|
height: 100%;
|
|
overflow: hidden; //超出的文本隐藏
|
|
display: -webkit-box;
|
|
-webkit-line-clamp: 1; // 超出多少行
|
|
-webkit-box-orient: vertical;
|
|
width: 50%;
|
|
}
|
|
|
|
.image {
|
|
position: absolute;
|
|
right: 0%;
|
|
top: 50%;
|
|
transform: translateY(-50%);
|
|
display: inline-block;
|
|
font-size: 30rpx;
|
|
color: #EA706A;
|
|
|
|
image {
|
|
// vertical-align: middle;
|
|
transform: translateY(20%);
|
|
width: 40rpx;
|
|
height: 40rpx;
|
|
padding-right: 10rpx;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
::v-deep .u-tabs {
|
|
background-color: #18CBB3 !important;
|
|
}
|
|
|
|
.top {
|
|
width: 82%;
|
|
margin: 0 auto;
|
|
display: flex;
|
|
height: 84rpx;
|
|
justify-content: space-around;
|
|
|
|
::v-deep .u-flex {
|
|
width: 100% !important;
|
|
}
|
|
|
|
::v-deep .u-dropdown__content {
|
|
overflow-y: scroll !important;
|
|
height: 500rpx;
|
|
|
|
.u-flex {
|
|
width: 0 !important;
|
|
}
|
|
}
|
|
|
|
::v-deep .u-dropdown__content__mask {
|
|
background: none !important;
|
|
}
|
|
|
|
::v-deep .u-dropdown__menu__item {
|
|
width: 100% !important;
|
|
}
|
|
|
|
::v-deep .u-cell__value {
|
|
flex: 0;
|
|
}
|
|
|
|
::v-deep .u-dropdown {
|
|
:v-deep .u-dropdown__menu {}
|
|
}
|
|
|
|
::v-deep .u-cell-box {}
|
|
}
|
|
}
|
|
</style> |