<template>
<div>
<!-- 打印中提示-->
<div class="dyzTip" v-if="DYZshow&&DYZlist">
<div class="curtain"></div>
<div class="content">
<img src="../assets/printing.png" alt="">
<div class="name">正在进行{{ DYZlist[0].printFileType=='PDF'?'文档':'照片' }}打印...</div>
<div class="flex-center">{{ DYZlist.length }}/{{ DYZlistNum }}</div>
</div>
</div>
<!-- 提示-->
<div class="tkTip flex-center" v-if="state.sta">
<div>{{ state.name }}</div>
</div>
<!-- 小程序支付-->
<div class="dyzTip" v-if="zfShow">
<div class="curtain"></div>
<div class="content content2">
<VueQr v-show="src" :auto-color="true" :dot-scale="1" :logo-src="require('@/assets/logo.png')"
:logoMargin="0" :logoScale=".2" :margin="0" :size="300" :text="src"
logoBackgroundColor="white"></VueQr>
<p>
<img @click="onChange('zfShow',false)" class="icon" src="../assets/demo10.png" alt="">
</p>
</div>
</div>
</div>
</template>
<script>
import mqtt from "mqtt/dist/mqtt"
import {getAdvertisement, getDeviceByCode} from "@/api/resultApi";
import VueQr from 'vue-qr'
import { getDeviceCode } from "@/api/bdResultApi";
export default {
name: "global",
components: {
VueQr
},
data() {
return {
client: null,
code: '',
DYZshow: false, // 是否显示打印中
downloadPath: 'D:\\TZDYSHARE\\TEMPFILES\\',
state: '',
src: '',
zfShow: false,
DYZlist: [],
DYZlistNum: 1,
};
},
created() {
this.toLoad()
},
methods: {
onChange(name,val){
this[name] = val
},
toLoad() {
// this.cite.code = 'SNJ-XX-EPSON-X001-00001'
// this.code = 'SNJ-XX-EPSON-X001-00001'
// this.load()
getDeviceCode().then(res =>{
this.cite.code = res.data
this.code = res.data
this.load()
})
},
load() {
if (this.cite.facility === "") {
this.getDeviceByCode();
}
// 判断是否是广告屏
if(this.cite.name != 'advertising') {
this.initMqtt()
setInterval(()=>{
if(!this.state.sta&&this.cite.state.sta) {
setTimeout(()=>{
this.cite.state.sta = false
},3000)
}
this.state = this.cite.state
},1000)
}
},
initMqtt() {
// 连接配置选项
let options = {
connectTimeout: 4000, // 超时时间
// 认证信息
clientId: '', //不填默认随机生成一个ID
username: 'admin', //用户名
password: 'public' //密码
}
this.client = mqtt.connect('wss://mps.xlmalls.com:8084/mqtt', options) //调用连接的api
//连接成功
this.client.on('connect', (e) => {
console.log('连接成功', e)
this.subscribes()
})
//重连提醒
this.client.on('reconnect', (error) => {
console.log('正在重连', error)
})
//连接失败提醒
this.client.on('error', (error) => {
console.log('连接失败', error)
})
//接收消息
this.client.on('message', (topic, message) => {
const data = JSON.parse(message) //接受到控制信号的数据
console.log('接收消息',data)
if(data.cmd=='ORDER_INFO') {
//小程序支付
this.cite.url = data.payCodeUrl
if(this.cite.selectedFile.length<1) {
this.src = data.payCodeUrl
this.zfShow=true
}
}else if(data.cmd=='LOGIN') {
//登录
if(this.cite.memberLoginVo=='') {
this.cite.memberLoginVo = data
// this.cite.state = {
// name: '登录设备成功!',
// sta: true
// }
}
}else if(data.cmd=='LOGOUT'){
//登出
this.cite.memberLoginVo = ''
this.quit()
}else if(data.cmd=='PRINT'){
//打印任务
this.DYZshow = true
this.zfShow = false
this.DYZlist.push(data)
this.DYZlistNum = this.DYZlist.length
}else if(data.cmd=='PRINT_STATUS'){
//打印任务完成
console.log(this.DYZlist)
if(data.taskStatus=='COMPLETE') {
if(this.DYZlist.length>1) {
this.DYZlist.forEach((item,index)=>{
if(item.code == data.taskCode) {
this.DYZlist.splice(index, 1)
}
})
}else{
this.DYZshow = false
this.DYZlist = []
this.DYZlistNum = 1
this.$router.push({
name: 'complete'
})
getDeviceByCode({ code: this.code }).then((res) => {
this.cite.facility = res;
});
}
}
}
})
},
//订阅多个主题
subscribes() {
const arr = ['/tzdy/send/device/'+this.code]
this.client.subscribe(arr, { qos: 0 }, (err) => {
if (!err) {
console.log(`消息订阅成功`)
} else {
console.log('消息订阅失败')
}
})
},
//获取设备信息
getDeviceByCode() {
getDeviceByCode({ code: this.code }).then((res) => {
console.log(res)
this.cite.facility = res;
this.getAdvertisement()
});
},
// 获取广告链接
getAdvertisement() {
let name = 'DeviceScreen'
if(this.cite.name=='advertising') {
name = 'AdvertisingScreen'
}
getAdvertisement({deviceId:this.cite.facility.id,screen: name}).then((res) =>{
// console.log(res)
this.cite.advertisement = res || ''
})
},
}
}
</script>
<style scoped lang="less">
.dyzTip {
position: fixed;
width: 100%;
height: 100%;
top: 0;
left: 0;
z-index: 99;
.curtain {
background: #000;
width: 100%;
height: 100%;
opacity: .3;
}
.content {
position: absolute;
left: 50%;
margin-left: -19rem;
top: 50%;
margin-top: -14.5rem;
width: 38.56rem;
height: 29rem;
background: #FFFFFF;
border-radius: 1.25rem;
overflow: hidden;
img {
width: 100%;
}
div {
font-size: 1.38rem;
font-family: PingFang SC, PingFang SC;
font-weight: bold;
color: #323232;
line-height: 1.88rem;
margin-top: 1.3rem;
}
.name {
font-size: 1rem;
font-family: PingFang SC, PingFang SC;
font-weight: 400;
color: #323232;
line-height: 1.38rem;
text-align: left;
padding: 0 3rem;
}
}
.content2 {
background: transparent;
height: auto;
img {
width: 18rem;
}
.icon {
width: 3rem;
margin-top: 3rem;
}
}
}
.tkTip {
position: fixed;
top: 5%;
width: 100%;
z-index: 99;
div {
background: rgba(51, 51, 51, 0.5);
color: #fff;
padding: 1rem 2rem;
border-radius: 1rem;
}
}
</style>