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.
 
 
 
 
 

235 lines
7.5 KiB

<script setup lang="ts">
import FtDialog from 'components/common/FTDialog/index.vue'
import { ElMessageBox } from 'element-plus'
import { FtMessage } from 'libs/message'
import { sendControl } from 'libs/utils'
import { useSystemStore } from 'stores/useSystemStore'
import { ref } from 'vue'
const emits = defineEmits(['ok', 'cancel'])
const systemStore = useSystemStore() // 使用 systemStore
const humidity = ref(systemStore.targetHumidity)
const slideTemperature = ref(systemStore.targetSlideTemperature)
const nozzleTemperature = ref(systemStore.targetNozzleTemperature)
const slideStartRef = ref()
const nozzleStartRef = ref()
const dehumidifierStartRef = ref()
const slideStart = () => {
if (!systemStore.systemSensor.slideTemperature) {
FtMessage.error('未检测到当前温度')
return
}
if (!slideTemperature.value) {
FtMessage.error('请输入目标温度')
return
}
if (slideTemperature.value > 100 || slideTemperature.value < 0) {
FtMessage.error('温度参数有误')
return
}
if (slideTemperature.value <= systemStore.systemSensor.slideTemperature) {
FtMessage.info('当前不需要加热')
return
}
ElMessageBox.confirm('载玻台即将开始加热', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
showCancelButton: true,
showClose: false,
})
.then(async () => {
slideStartRef.value.setLoading(true)
const params = {
cmdCode: 'slide_plat_heat_start',
cmdId: '',
params: {
temperature: slideTemperature.value,
},
}
await sendControl(params)
systemStore.updateSlideTemperature(slideTemperature.value)
slideStartRef.value.setLoading(false)
})
.catch(() => {
FtMessage.error('取消加热')
})
}
const nozzleStart = () => {
if (!systemStore.systemSensor.nozzleTemperature) {
FtMessage.error('未检测到当前温度')
return
}
if (!nozzleTemperature.value) {
FtMessage.error('请输入目标温度')
return
}
if (nozzleTemperature.value > 100 || nozzleTemperature.value < 0) {
FtMessage.error('温度参数有误')
return
}
if (nozzleTemperature.value <= systemStore.systemSensor.nozzleTemperature) {
FtMessage.info('当前不需要加热')
return
}
ElMessageBox.confirm('即将开始加热', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
showCancelButton: true,
showClose: false,
})
.then(async () => {
nozzleStartRef.value.setLoading(true)
const params = {
cmdCode: 'nozzle_heat_start',
cmdId: '',
params: {
temperature: nozzleTemperature.value,
},
}
await sendControl(params)
systemStore.updateTargetNozzleTemperature(nozzleTemperature.value)
nozzleStartRef.value.setLoading(false)
})
.catch(() => {
FtMessage.error('取消加热')
})
}
const dehumidifierStart = () => {
if (!systemStore.systemSensor.humidity) {
FtMessage.error('未检测到当前湿度')
return
}
if (!humidity.value) {
FtMessage.error('请输入目标湿度')
return
}
if (humidity.value > 100 || humidity.value < 0) {
FtMessage.error('湿度参数有误')
return
}
if (humidity.value >= systemStore.systemSensor.humidity) {
FtMessage.info('当前不需要除湿')
return
}
ElMessageBox.confirm('即将开始除湿,请确认关闭注射泵门和玻片托盘出口门', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
showCancelButton: true,
showClose: false,
})
.then(async () => {
dehumidifierStartRef.value.setLoading(true)
const params = {
cmdCode: 'dehumidifier_start',
cmdId: '',
params: {
humidity: humidity.value,
},
}
await sendControl(params)
systemStore.updateTargetHumidity(humidity.value)
dehumidifierStartRef.value.setLoading(false)
})
.catch(() => {
FtMessage.error('取消除湿')
})
}
const dehumidifierStop = async () => {
const params = {
cmdCode: 'dehumidifier_stop',
cmdId: '',
}
await sendControl(params)
}
const slideStop = async () => {
const params = {
cmdCode: 'slide_plat_heat_stop',
cmdId: '',
}
await sendControl(params)
}
const nozzleStop = async () => {
const params = {
cmdCode: 'nozzle_heat_stop',
cmdId: '',
}
await sendControl(params)
}
const onClose = async () => {
emits('cancel')
}
</script>
<template>
<FtDialog visible title="喷涂环境设置" width="70%">
<div style="padding: 10px;">
<div style="display: flex; align-items: center; margin: 10px 0;font-size: 15px;justify-content: center;">
<div style="display: flex; align-items: center; width: 20%; margin-right: 30px">
<span>当前湿度</span>
<span class="num-text">{{ systemStore.systemSensor.humidity }}</span>
<span>%RH</span>
</div>
<div style="display: flex; align-items: center; width: 30%; margin-right: 30px">
<span>目标湿度</span>
<el-input v-model="humidity" type="number" style="width: 100px; margin: 0 10px" />
<span>%RH</span>
</div>
<ft-button ref="dehumidifierStartRef" type="primary" :click-handle="dehumidifierStart">
开始除湿
</ft-button>
<ft-button :click-handle="dehumidifierStop" :disabled="!systemStore.systemStatus.dehumidifierRunning">
停止除湿
</ft-button>
</div>
<div style="display: flex; align-items: center; margin-top: 10px;font-size: 15px;justify-content: center;">
<div style="display: flex; align-items: center; width:20%; margin-right: 30px">
<span>载玻台温度</span>
<span class="num-text">{{ systemStore.systemSensor.slideTemperature }}</span>
<span>℃</span>
</div>
<div style="display: flex; align-items: center; width: 30%; margin-right: 30px">
<span>目标温度</span>
<el-input v-model="slideTemperature" type="number" style="width: 100px; margin: 0 10px" />
<span>℃</span>
</div>
<ft-button ref="slideStartRef" type="primary" :click-handle="slideStart">
开始加热
</ft-button>
<ft-button :click-handle="slideStop" :disabled="!systemStore.systemStatus.slidePlatHeating">
停止加热
</ft-button>
</div>
<div style="display: flex; align-items: center; margin-top: 10px;font-size: 15px;justify-content: center;">
<div style="display: flex; align-items: center; width: 20%; margin-right: 30px">
<span>喷头温度</span>
<span class="num-text">{{ systemStore.systemSensor.nozzleTemperature }}</span>
<span>℃</span>
</div>
<div style="display: flex; align-items: center; width: 30%; margin-right: 30px">
<span>目标温度</span>
<el-input v-model="nozzleTemperature" type="number" style="width: 100px; margin: 0 10px" />
<span>℃</span>
</div>
<ft-button ref="nozzleStartRef" type="primary" :click-handle="nozzleStart">
开始加热
</ft-button>
<ft-button :click-handle="nozzleStop" :disabled="!systemStore.systemStatus.nozzleHeating">
停止加热
</ft-button>
</div>
</div>
<template #footer>
<FtButton type="default" :click-handle="onClose">
关闭
</FtButton>
</template>
</FtDialog>
</template>
<style scoped lang="scss">
.num-text {
color: var(--el-color-primary);
font-weight: 900;
font-size: 70px;
}
</style>