You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

142 lines
3.3 KiB

<template>
<div class="container">
<div id="pwpg" class="pwpg" ref="pwpg"></div>
8 months ago
<QgePgd id="pwpgd" ref="pwpgd" @initPgd="initPgd" :worker="getWorker" />
</div>
</template>
<script>
import container from "./comps/container";
import drawTitle from './comps/title'
import workers from "./comps/person";
import drawDw from './comps/dw'
import drawPgd from './comps/pgd'
8 months ago
import {getBzryList} from "@/api/sjzx/bzzGL";
import {getYcldw} from "@/api/zyjh";
import QgePgd from "@/views/zyjhzx/qgepgong/comps/QgePgd.vue";
export default {
name:'PWanPGong',
components: {QgePgd},
data(){
return {
title:'切 割 作 业 派 工',
width:0,
height:0,
stage:null,
layer:null,
pgdGroup:null,
drawGd:null,
8 months ago
getCurrentWorker:null,
}
},
mounted() {
this.$socket.open()
this.wsSubscribe()
this.initKonvaStage();
},
created(){
window.addEventListener('resize', this.initKonvaStage)
},
sockets:{},
methods:{
wsSubscribe(){
this.sockets.subscribe('zyjhzx', data => {
const currentWorker=this.getCurrentWorker()
if (!currentWorker){
this.$message.error(`未选择指派人员`)
return;
}
if (this.zt===data.zt){
const tmpArr=[{
id:data.zyjh.id,
pwry:currentWorker.userCode
}]
this.$refs.pwpgd.paigong0(tmpArr)
}else{
this.$message.error(`工单号错误:${data.gdh}`)
}
})
},
initPgd(pgd={}){
const group=this.drawGd(pgd)
this.pgdGroup.add(group)
},
initDw(){
getYcldw({type:'llj'}).then(res=>{
8 months ago
const {container,dw}=drawDw(this.width,this.height)
const {bgGroup,group}=container()
this.layer.add(bgGroup)
8 months ago
for (let i=0;i<res.data.length;i++){
const item=res.data[i]
const dwGroup=dw(i,item)
group.add(dwGroup)
}
})
},
8 months ago
getWorker(){
return this.getCurrentWorker()
},
initWorkers(){
getBzryList({resourcesCode:'4KB002'}).then(res=> {
const {container, person, getCurrentWorker} = workers(this.width, this.height)
this.getCurrentWorker = getCurrentWorker
const {layer, group} = container()
8 months ago
this.stage.add(layer)
for (let i = 0; i < res.data.length; i++) {
const item = res.data[i]
const worker = person(i, item)
group.add(worker)
}
})
},
initKonvaStage() {
this.width = this.$refs.pwpg.clientWidth
this.height = this.$refs.pwpg.clientHeight
const {stage, layer} = container(this.width, this.height, 'pwpg')
this.stage = stage
this.layer = layer
const titel = drawTitle(this.width, this.height, this.title)
this.layer.add(titel)
this.initWorkers()
this.initDw()
const {container: pgdContainer, drawGd} = drawPgd(this.width, this.height)
this.drawGd = drawGd
this.pgdGroup = pgdContainer()
this.layer.add(this.pgdGroup)
},
}
}
</script>
<style>
#pwpgd {
width: 50.3%;
height: auto;
position: absolute;
top: 195px;
left: 20px;
border: none;
margin: 0;
}
#pwpg {
overflow: hidden;
width: 100%;
height: 100vh;
aspect-ratio: 16/9;
}
.container {
background: #ddd;
}
</style>