Files
rd_mes_uniapp/pages/basic/searchJobs.vue

244 lines
5.7 KiB
Vue
Raw Permalink Normal View History

2025-12-18 14:11:48 +08:00
<template>
<view class="container">
<view class="status-bar"></view>
<t-emp />
<view class="jobInfo">
<uni-card class="jobs" v-for="(item, index) in searchJobWithEqp" :key="index">
<uni-row>
<uni-col :span="8">作业编码</uni-col>
<uni-col :span="12" :offset="3">{{ item.code }}</uni-col>
</uni-row>
<uni-row>
<uni-col :span="8">目标产品编码</uni-col>
<uni-col :span="12" :offset="3">{{ item.ptNoTar }}</uni-col>
</uni-row>
<uni-row>
<uni-col :span="8">目标产品名称</uni-col>
<uni-col :span="12" :offset="3">{{ item.ptTitleTar }}</uni-col>
</uni-row>
<uni-row>
<uni-col :span="8">设备编码</uni-col>
<uni-col :span="12" :offset="3">{{ item.eqpCode }}</uni-col>
</uni-row>
<uni-row>
<uni-col :span="8">计划数量</uni-col>
<uni-col :span="12" :offset="3">{{ item.targetNum }}</uni-col>
</uni-row>
<uni-row>
<uni-col :span="8">未完成数量</uni-col>
<uni-col :span="12" :offset="3">{{ item.unFinishQty }}</uni-col>
</uni-row>
</uni-card>
</view>
<button type="primary" class="searchBtn" @click="fetchJobList">查询</button>
</view>
</template>
<script>
import { listPwoJobLike } from '@/api/mes/pwoIn';
export default {
data() {
return {
loading: false,
empName: this.$store.state.employee.empName,
empCode: this.$store.state.employee.empCode,
eqpCode: null,
eqpId: null,
eqpName: null,
startedEqp: [],
searchJobWithEqp: []
}
},
methods: {
async fetchJobList() {
this.searchJobWithEqp.length = 0;
this.$modal.loading('获取作业中');
try {
const { rows } = await listPwoJobLike({
employeeCode: this.empCode
});
this.searchJobWithEqp = rows;
} catch(err) {
this.$modal.msg('获取作业失败,请稍后重试');
} finally {
this.$modal.closeLoading();
}
},
// 根据员工信息查询上机设备
searchStartedEqp() {
return new Promise((resolve, reject) => {
this.startedEqp = [];
listEmpEqpHistory({
empName: this.empName,
empCode: this.empCode
}).then(res => {
if (res.rows.length > 0) {
for (let i in res.rows) {
if (!res.rows[i].endTime) {
this.startedEqp.push({
eqpCode: res.rows[i].equipmentCode,
eqpId: ''
});
}
}
if (this.startedEqp.length === 0) {
this.$modal.closeLoading()
uni.showToast({
title: '未查询到已上机设备',
icon: 'none'
});
reject(new Error('无设备'));
} else {
resolve(); // 成功时调用 resolve
}
}
}).catch(error => {
this.$modal.closeLoading()
reject(error);
});
});
},
// 根据设备编码查询设备id
searchEqp() {
return new Promise((resolve, reject) => {
if (this.startedEqp.length === 0) {
this.$modal.closeLoading()
resolve();
return;
}
const promises = this.startedEqp.map((eqp, index) => {
return listEquipment({
equipmentCode: eqp.eqpCode
}).then(res => {
this.startedEqp[index].eqpId = res.rows[0].id;
}).catch(error => {
this.$modal.closeLoading()
this.$modal.showToast("查询设备id失败");
throw error;
});
});
Promise.all(promises)
.then(() => resolve())
.catch(error => reject(error));
});
},
// 根据设备查找关联的作业信息
searchJob() {
return new Promise((resolve, reject) => {
this.searchJobWithEqp = [];
if (this.startedEqp.length === 0) {
this.$modal.closeLoading()
resolve();
return;
}
const promises = this.startedEqp.map((eqp, index) => {
return listPwoJob({
eqpId: eqp.eqpId
}).then(res => {
res.rows.forEach(row => {
this.searchJobWithEqp.push({
jobCode: row.code,
tarProCode: row.ptNoTar,
tarProName: row.ptTitleTar,
eqpCode: eqp.eqpCode,
planNum: row.targetNum,
unfinishedNum: row.unFinishQty
});
});
this.$modal.closeLoading()
}).catch(error => {
this.$modal.closeLoading()
this.$modal.showToast("查询作业信息失败");
throw error;
});
});
Promise.all(promises)
.then(() => resolve())
.catch(error => reject(error));
});
},
async searchJobWithEmp() {
try {
this.$modal.loading("查询中")
await this.searchStartedEqp()
await this.searchEqp()
await this.searchJob()
} catch (error) {
uni.showToast({
title: '查询失败',
icon: 'none'
});
this.$modal.closeLoading()
}
}
},
// 根据账号获取员工姓名和账号ID
// onLoad() {
// getInfo().then(res => {
// this.empName = res.user.nickName
// }).catch(() => {
// uni.showToast({
// title: '当前账号无对应人员资料',
// icon: 'none'
// })
// })
// //根据昵称获取对应员工编号
// listEmployee({
// name: this.empName
// }).then(res => {
// this.empCode = res.rows[0].empCode
// }).catch(() => {
// uni.showToast({
// title: '当前账号无对应人员资料',
// icon: 'none'
// })
// })
// }
}
</script>
<style scoped lang="scss">
.status-bar {
height: var(--status-bar-height);
width: 100%;
}
.container {
width: 100%;
padding: 6px 12px;
box-sizing: border-box;
display: flex;
flex-direction: column;
overflow: hidden;
/* #ifdef H5 */
height: calc(100vh - 44px);
/* #endif */
/* #ifndef H5 */
height: 100vh;
/* #endif */
}
.jobInfo {
flex: 1;
width: 100%;
overflow: scroll;
padding: 10px 0;
.jobs {
margin: 6px 0 0 !important;
border-radius: 10px;
}
}
.searchBtn {
width: 100%;
margin-top: 1vh;
line-height: 6vh;
font-size: 2.5rem;
}
</style>