From 5270308151082506e0e6df2c72d278d2976ec860 Mon Sep 17 00:00:00 2001
From: liulijun <liulijun@hnkhzn.com>
Date: 星期三, 29 四月 2026 10:28:58 +0800
Subject: [PATCH] WCS设备监控
---
项目代码/WCS/WCSClient/src/views/Home.vue | 1630 +++++++++++++++++++++++++++++++++++++++++++--------------
1 files changed, 1,221 insertions(+), 409 deletions(-)
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WCSClient/src/views/Home.vue" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WCSClient/src/views/Home.vue"
index f834133..54a5978 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WCSClient/src/views/Home.vue"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WCSClient/src/views/Home.vue"
@@ -1,67 +1,12 @@
<template>
<div class="title">
- <el-row :gutter="20" style="height:85%">
- <el-col :span="8">
- <span style="position: relative; top: 100px;left: 30px;">
- <h4>涓�妤艰澶囩洃鎺�</h4>
+ <el-row :gutter="0" style="height:100%; width:400px;">
+ <el-col :span="16">
+ <span style="position: absolute; top: 10px; left: 30px;">
+ <h2>涓�妤煎師鏂欏簱璁惧鐩戞帶</h2>
</span>
- <el-row :gutter="20" style="height:1000px">
- <el-col :span="8">
- <div>
- <div v-for="(group, index) in groupedLines(linescopy7)" :key="index">
- <div class="positionY-group">
- <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
- :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
- :positionY="line.positionY" :condition="line.condition"
- url="api/Equipment/GetLineInfoByNo" />
- </div>
- </div>
- <div style="margin-top: 118px;"></div>
- <div v-for="(group, index) in groupedLines(linescopy8)" :key="index">
- <div class="positionY-group">
- <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
- :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
- :positionY="line.positionY" :condition="line.condition"
- url="api/Equipment/GetLineInfoByNo" />
- </div>
- </div>
- <div style="margin-top: 115px;"></div>
- <div v-for="(group, index) in groupedLines(linescopy9)" :key="index">
- <div class="positionY-group">
- <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
- :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
- :positionY="line.positionY" :condition="line.condition"
- url="api/Equipment/GetLineInfoByNo" />
- </div>
- </div>
- <div style="margin-top: 112px;"></div>
- <div v-for="(group, index) in groupedLines(linescopy10)" :key="index">
- <div class="positionY-group">
- <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
- :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
- :positionY="line.positionY" :condition="line.condition" />
- </div>
- </div>
- <div style="margin-top: 109px;"></div>
- <div v-for="(group, index) in groupedLines(linescopy11)" :key="index">
- <div class="positionY-group">
- <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
- :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
- :positionY="line.positionY" :condition="line.condition" />
- </div>
- </div>
- <div style="margin-top: 107px;"></div>
- <div v-for="(group, index) in groupedLines(linescopy12)" :key="index">
- <div class="positionY-group">
- <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
- :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
- :positionY="line.positionY" :condition="line.condition" />
- </div>
- </div>
- </div>
- </el-col>
-
- <el-col :span="8">
+ <el-row :gutter="20" style="height:1000px; width:100%;">
+ <el-col :span="24">
<div>
<div v-for="(group, index) in groupedLines(linescopy1)" :key="index">
<div class="positionY-group">
@@ -71,7 +16,7 @@
url="api/Equipment/GetLineInfoByNo" />
</div>
</div>
- <div style="margin-top: 108px;"></div>
+ <div style="margin-top: 30px;"></div>
<div v-for="(group, index) in groupedLines(linescopy2)" :key="index">
<div class="positionY-group">
<LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
@@ -80,7 +25,7 @@
url="api/Equipment/GetLineInfoByNo" />
</div>
</div>
- <div style="margin-top: 58px;"></div>
+ <div style="margin-top:50px;"></div>
<div v-for="(group, index) in groupedLines(linescopy3)" :key="index">
<div class="positionY-group">
<LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
@@ -89,7 +34,7 @@
url="api/Equipment/GetLineInfoByNo" />
</div>
</div>
- <div style="margin-top: 58px;"></div>
+ <div style="margin-top: 20px;"></div>
<div v-for="(group, index) in groupedLines(linescopy4)" :key="index">
<div class="positionY-group">
<LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
@@ -97,7 +42,7 @@
:positionY="line.positionY" :condition="line.condition" />
</div>
</div>
- <div style="margin-top: 115px;"></div>
+ <div style="margin-top: 40px;"></div>
<div v-for="(group, index) in groupedLines(linescopy5)" :key="index">
<div class="positionY-group">
<LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
@@ -105,8 +50,56 @@
:positionY="line.positionY" :condition="line.condition" />
</div>
</div>
- <div style="margin-top: 115px;"></div>
+ <div style="margin-top: 30px;"></div>
<div v-for="(group, index) in groupedLines(linescopy6)" :key="index">
+ <div class="positionY-group">
+ <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 40px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopy7)" :key="index">
+ <div class="positionY-group">
+ <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 30px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopy8)" :key="index">
+ <div class="positionY-group">
+ <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 30px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopy9)" :key="index">
+ <div class="positionY-group">
+ <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 50px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopy10)" :key="index">
+ <div class="positionY-group">
+ <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 0px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopy11)" :key="index">
+ <div class="positionY-group">
+ <LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 30px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopy12)" :key="index">
<div class="positionY-group">
<LineInfoCopy v-for="(line, lineIndex) in group.lines" :key="lineIndex"
:equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
@@ -121,374 +114,814 @@
<el-col :span="8">
<!-- 鍫嗗灈鏈� -->
<div style="position: relative; top: 50px;">
+ <!-- <div style="margin-top: 33px;"></div> -->
<div class="stackerDiv">
- <div class="stackDivName">涓�鍙峰爢鍨涙満</div>
- <LineComponent :x="xValue1" ref="stacker1" :equipNo="SC01"></LineComponent>
+ <div class="stackDivName" style="text-align: left;">浜斿彿鍫嗗灈鏈�</div>
+ <LineComponent :x="xValue1" ref="stacker5" :equipNo="SC05"></LineComponent>
</div>
<el-divider></el-divider>
<div class="stackerDiv">
- <div class="stackDivName">浜屽彿鍫嗗灈鏈�</div>
- <LineComponent :x="xValue2" ref="stacker2" :equipNo="SC02"></LineComponent>
+ <div class="stackDivName" style="text-align: left;">鍥涘彿鍫嗗灈鏈�</div>
+ <LineComponent :x="xValue2" ref="stacker4" :equipNo="SC04"></LineComponent>
</div>
<el-divider></el-divider>
+ <!-- <div style="margin-top: 85px;"></div> -->
<div class="stackerDiv">
- <div class="stackDivName">涓夊彿鍫嗗灈鏈�</div>
+ <div class="stackDivName" style="text-align: left;">涓夊彿鍫嗗灈鏈�</div>
<LineComponent :x="xValue3" ref="stacker3" :equipNo="SC03"></LineComponent>
</div>
<el-divider></el-divider>
+ <!-- <div style="margin-top: 55px;"></div> -->
<div class="stackerDiv">
- <div class="stackDivName">鍥涘彿鍫嗗灈鏈�</div>
- <LineComponent :x="xValue4" ref="stacker4" :equipNo="SC04"></LineComponent>
+ <div class="stackDivName" style="text-align: left;">浜屽彿鍫嗗灈鏈�</div>
+ <LineComponent :x="xValue4" ref="stacker2" :equipNo="SC02"></LineComponent>
</div>
<el-divider></el-divider>
+ <!-- <div style="margin-top: 35px;"></div> -->
<div class="stackerDiv">
- <div class="stackDivName">浜斿彿鍫嗗灈鏈�</div>
- <LineComponent :x="xValue5" ref="stacker5" :equipNo="SC05"></LineComponent>
+ <div class="stackDivName" style="text-align: left;">涓�鍙峰爢鍨涙満</div>
+ <LineComponent :x="xValue5" ref="stacker1" :equipNo="SC01"></LineComponent>
</div>
<el-divider></el-divider>
- <div class="stackerDiv">
- <div class="stackDivName">鍏彿鍫嗗灈鏈�</div>
- <LineComponent :x="xValue6" ref="stacker6" :equipNo="SC06"></LineComponent>
- </div>
</div>
</el-col>
</el-row>
-
</div>
+ <el-row :gutter="0" style="width:400px;">
+ <el-col :span="16">
+ <span style="position: absolute; top: 10px; left: 30px;">
+ <h2>涓�妤兼垚鍝佸簱璁惧鐩戞帶</h2>
+ </span>
+ <el-row :gutter="20" style="height:1000px; width:100%;">
+ <el-col :span="24">
+ <div>
+ <div v-for="(group, index) in groupedLines(linescopyCP1)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition"
+ url="api/Equipment/GetLineInfoByNo" />
+ </div>
+ </div>
+ <div style="margin-top: 20px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP2)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition"
+ url="api/Equipment/GetLineInfoByNo" />
+ </div>
+ </div>
+ <div style="margin-top:40px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP3)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition"
+ url="api/Equipment/GetLineInfoByNo" />
+ </div>
+ </div>
+ <div style="margin-top: 20px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP4)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 50px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP5)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 30px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP6)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 50px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP7)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 30px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP8)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 50px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP9)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ <div style="margin-top: 30px;"></div>
+ <div v-for="(group, index) in groupedLines(linescopyCP10)" :key="index">
+ <div class="positionY-group">
+ <LineInfo v-for="(line, lineIndex) in group.lines" :key="lineIndex"
+ :equipNo="line.equipNo" :imgType="line.imgType" :positionX="line.positionX"
+ :positionY="line.positionY" :condition="line.condition" />
+ </div>
+ </div>
+ </div>
+ </el-col>
+ </el-row>
+
+ </el-col>
+ <el-col :span="8">
+ <!-- 鍫嗗灈鏈� -->
+ <div style="position: relative; top: 50px;">
+ <!-- <div style="margin-top: 33px;"></div> -->
+ <div class="stackerDivCP">
+ <div class="stackDivName" style="text-align: left;">浜斿彿鍫嗗灈鏈�</div>
+ <LineComponentCP :x="xValue1" ref="stackerCP5" :equipNo="SC05CP"></LineComponentCP>
+ </div>
+ <el-divider></el-divider>
+ <div class="stackerDivCP">
+ <div class="stackDivName" style="text-align: left;">鍥涘彿鍫嗗灈鏈�</div>
+ <LineComponentCP :x="xValue2" ref="stackerCP4" :equipNo="SC04CP"></LineComponentCP>
+ </div>
+ <el-divider></el-divider>
+ <!-- <div style="margin-top: 85px;"></div> -->
+ <div class="stackerDivCP">
+ <div class="stackDivName" style="text-align: left;">涓夊彿鍫嗗灈鏈�</div>
+ <LineComponentCP :x="xValue3" ref="stackerCP3" :equipNo="SC03CP"></LineComponentCP>
+ </div>
+ <el-divider></el-divider>
+ <!-- <div style="margin-top: 55px;"></div> -->
+ <div class="stackerDivCP">
+ <div class="stackDivName" style="text-align: left;">浜屽彿鍫嗗灈鏈�</div>
+ <LineComponentCP :x="xValue4" ref="stackerCP2" :equipNo="SC02CP"></LineComponentCP>
+ </div>
+ <el-divider></el-divider>
+ <!-- <div style="margin-top: 35px;"></div> -->
+ <div class="stackerDivCP">
+ <div class="stackDivName" style="text-align: left;">涓�鍙峰爢鍨涙満</div>
+ <LineComponentCP :x="xValue5" ref="stackerCP1" :equipNo="SC01CP"></LineComponentCP>
+ </div>
+ <el-divider></el-divider>
+ </div>
+ </el-col>
+ </el-row>
</template>
+
+
<script>
import { onMounted, ref, reactive } from "vue";
import LineInfo from "./LineInfo.vue";
import LineInfoCopy from "./LineInfocopy.vue";
import LineComponent from './LineComponent.vue';
+import LineComponentCP from './LineComponentCP.vue';
import JElDescription from "./JElDescription";
import { useWebSocket } from '@/uitils/websocket';
+
export default {
+ setup() {
+ // 浣跨敤淇鍚庣殑WebSocket閽╁瓙鍑芥暟
+ const { ws, messages, status, send, reconnect } = useWebSocket();
+
+ return {
+ ws,
+ messages,
+ status,
+ send,
+ reconnect
+ };
+ },
data() {
return {
- ws: null, // WebSocket瀹炰緥
- messages: [], // 娑堟伅鍒楄〃
- status: { // 杩炴帴鐘舵��
- isConnected: false,
- error: null
- },
+ // 鍫嗗灈鏈鸿澶囩紪鍙烽厤缃�
+ SC01: "SC01_YL",
+ SC02: "SC02_YL",
+ SC03: "SC03_YLDual",
+ SC04: "SC04_YLDual",
+ SC05: "SC05_YLDual",
+ SC01CP: "SC01_CP",
+ SC02CP: "SC02_CP",
+ SC03CP: "SC03_CP",
+ SC04CP: "SC04_CP",
+ SC05CP: "SC05_CP",
linescopy1: [
+ // {
+ // equipNo: "101",
+ // imgType: "1",
+ // positionX: 0,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "102",
+ // imgType: "1",
+ // positionX: 0,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "103",
+ // imgType: "1",
+ // positionX: 0,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "109",
+ // imgType: "1",
+ // positionX: 0.5,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "200",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "202",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "204",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "206",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "208",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "210",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "212",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "302",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "304",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "306",
+ // imgType: "1",
+ // positionX: 1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "309",
+ // imgType: "1",
+ // positionX: 1.5,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "310",
+ // imgType: "1",
+ // positionX: 2,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "313",
+ // imgType: "1",
+ // positionX: 2.5,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "314",
+ // imgType: "1",
+ // positionX: 3,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1005",
+ equipNo: "320",
imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1006",
- imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
-
- {
- equipNo: "1007",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
- condition: false,
- },
- {
- equipNo: "1008",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
+ //positionX: 3,
+ positionX: 0,
+ positionY: 16,
condition: false,
}
],
linescopy2: [
+ // {
+ // equipNo: "104",
+ // imgType: "1",
+ // positionX: 0,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "106",
+ // imgType: "1",
+ // positionX: 0,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "108",
+ // imgType: "1",
+ // positionX: 0,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "200.1",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "201",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "203",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "205",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "207",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "209",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "211",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "301",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "303",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "305",
+ // imgType: "1",
+ // positionX: 2.325,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "311",
+ // imgType: "1",
+ // positionX: 4.65,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "315",
+ // imgType: "1",
+ // positionX: 6.975,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1009",
+ equipNo: "321",
imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1010",
- imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
-
- {
- equipNo: "1011",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
- condition: false,
- },
- {
- equipNo: "1025",
- imgType: "1",
- positionX: 0.6,
- positionY: 21,
- condition: false,
- },
- {
- equipNo: "1012",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
+ //positionX: 6.975,
+ positionX: 0,
+ positionY: 16,
condition: false,
}
],
linescopy3: [
+ // {
+ // equipNo: "309.1",
+ // imgType: "1",
+ // positionX: 20.175,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "312",
+ // imgType: "1",
+ // positionX: 20.65,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "316",
+ // imgType: "1",
+ // positionX: 25.65,
+ // positionY: 0,
+ // condition: false,
+ // },
{
- equipNo: "1017",
+ equipNo: "322",
imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1018",
- imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
-
- {
- equipNo: "1019",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
- condition: false,
- },
- {
- equipNo: "1026",
- imgType: "1",
- positionX: 0.6,
- positionY: 21,
- condition: false,
- },
- {
- equipNo: "1020",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
+ //positionX: 25.65,
+ positionX: 0,
+ positionY: 0,
condition: false,
}
],
linescopy4: [
+ // {
+ // equipNo: "413",
+ // imgType: "1",
+ // positionX: 22,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "317",
+ // imgType: "1",
+ // positionX: 25.65,
+ // positionY: 0,
+ // condition: false,
+ // },
{
- equipNo: "1021",
+ equipNo: "323",
imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1022",
- imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
-
- {
- equipNo: "1023",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
- condition: false,
- },
- {
- equipNo: "1024",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
+ //positionX: 25.65,
+ positionX: 0,
+ positionY: 0,
condition: false,
}
],
linescopy5: [
+ // {
+ // equipNo: "410",
+ // imgType: "1",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "411",
+ // imgType: "1",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "412",
+ // imgType: "1",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "318",
+ // imgType: "1",
+ // positionX: 21.65,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1031",
+ equipNo: "324",
imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1032",
- imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
-
- {
- equipNo: "1033",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
- condition: false,
- },
- {
- equipNo: "1034",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
+ //positionX: 21.65,
+ positionX: 0,
+ positionY: 16,
condition: false,
}
],
linescopy6: [
+ // {
+ // equipNo: "414",
+ // imgType: "1",
+ // positionX: 22,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "319",
+ // imgType: "1",
+ // positionX: 24.3,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1035",
+ equipNo: "325",
imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1036",
- imgType: "1",
- positionX: 0.6,
- positionY: 8,
- condition: false,
- },
-
- {
- equipNo: "1037",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
- condition: false,
- },
- {
- equipNo: "1038",
- imgType: "1",
- positionX: 0.6,
- positionY: 20,
+ //positionX: 24.3,
+ positionX: 0,
+ positionY: 16,
condition: false,
}
],
linescopy7: [
+ //{
+ // equipNo: "409",
+ // imgType: "2",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "415",
+ // imgType: "2",
+ // positionX: 18.9,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1001",
- imgType: "1",
- positionX: 5,
- positionY: 8,
+ equipNo: "424",
+ imgType: "2",
+ //positionX: 19.3,
+ positionX: 0,
+ positionY: 16,
condition: false,
},
- {
- equipNo: "1002",
- imgType: "1",
- positionX: 5,
- positionY: 8,
- condition: false,
- },
-
- {
- equipNo: "1003",
- imgType: "1",
- positionX: 5,
- positionY: 20,
- condition: false,
- },
- {
- equipNo: "1004",
- imgType: "1",
- positionX: 5,
- positionY: 20,
- condition: false,
- },
+ // {
+ // equipNo: "424.1",
+ // imgType: "2",
+ // positionX: 21.7,
+ // positionY: 16,
+ // condition: false,
+ // },
],
linescopy8: [
- {
- equipNo: "1039",
- imgType: "1",
- positionX: 6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1040",
- imgType: "1",
- positionX: 6,
- positionY: 16,
- condition: false,
- },
+ // {
+ // equipNo: "408",
+ // imgType: "2",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "416",
+ // imgType: "2",
+ // positionX: 18.9,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "423",
+ // imgType: "2",
+ // positionX: 19.3,
+ // positionX: 0,
+ // positionY: 16,
+ // condition: false,
+ // },
],
linescopy9: [
+ // {
+ // equipNo: "407",
+ // imgType: "2",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1013",
- imgType: "1",
- positionX: 6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1014",
- imgType: "1",
- positionX: 6,
+ equipNo: "422",
+ imgType: "2",
+ //positionX: 20.65,
+ positionX: 0,
positionY: 16,
condition: false,
},
+ // {
+ // equipNo: "422.1",
+ // imgType: "2",
+ // positionX: 23.05,
+ // positionY: 16,
+ // condition: false,
+ // },
],
linescopy10: [
+ // {
+ // equipNo: "406",
+ // imgType: "2",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1015",
- imgType: "1",
- positionX: 6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1016",
- imgType: "1",
- positionX: 6,
+ equipNo: "425",
+ imgType: "2",
+ //positionX: 24.4,
+ positionX: 0,
positionY: 16,
condition: false,
},
],
linescopy11: [
- {
- equipNo: "1027",
- imgType: "1",
- positionX: 6,
- positionY: 8,
- condition: false,
- },
- {
- equipNo: "1028",
- imgType: "1",
- positionX: 6,
- positionY: 16,
- condition: false,
- },
+ // {
+ // equipNo: "404",
+ // imgType: "2",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "418",
+ // imgType: "2",
+ // positionX: 18.9,
+ // positionY: 16,
+ // condition: false,
+ // },
+ // {
+ // equipNo: "421",
+ // imgType: "2",
+ // positionX: 19.3,
+ // positionY: 16,
+ // condition: false,
+ // },
],
linescopy12: [
+ // {
+ // equipNo: "403",
+ // imgType: "2",
+ // positionX: 17.525,
+ // positionY: 16,
+ // condition: false,
+ // },
{
- equipNo: "1029",
- imgType: "1",
- positionX: 6,
- positionY: 8,
+ equipNo: "419",
+ imgType: "2",
+ //positionX: 18.9,
+ positionX: 0,
+ positionY: 16,
condition: false,
},
+ // {
+ // equipNo: "419.1",
+ // imgType: "2",
+ // positionX: 23.1,
+ // positionY: 16,
+ // condition: false,
+ // },
+ ],
+ linescopyCP1: [
{
- equipNo: "1030",
+ equipNo: "1003",
imgType: "1",
- positionX: 6,
+ positionX: 0,
positionY: 16,
condition: false,
},
],
-
+ linescopyCP2: [
+ {
+ equipNo: "1008",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP3: [
+ {
+ equipNo: "1007",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP4: [
+ {
+ equipNo: "1012",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP5: [
+ {
+ equipNo: "1013",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP6: [
+ {
+ equipNo: "1018",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP7: [
+ {
+ equipNo: "1017",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP8: [
+ {
+ equipNo: "1022",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP9: [
+ {
+ equipNo: "1023",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+ linescopyCP10: [
+ {
+ equipNo: "1026",
+ imgType: "1",
+ positionX: 0,
+ positionY: 16,
+ condition: false,
+ },
+ ],
+
StackerCrane: {
Automatic: "",
Fault: "",
@@ -554,9 +987,455 @@
LineInfoCopy,
LineInfo,
LineComponent,
+ LineComponentCP,
JElDescription,
},
methods: {
+ groupedLines(linescopy) {
+ const groups = {};
+ linescopy.forEach((line) => {
+ const positionY = line.positionY;
+ if (!groups[positionY]) {
+ groups[positionY] = {
+ positionY,
+ lines: [],
+ };
+ }
+ groups[positionY].lines.push(line);
+ });
+ return Object.values(groups);
+ },
+ mouseClickRGVFirst() {
+ this.fullscreenLoading = true;
+ this.RGVFirst = true;
+ this.fullscreenLoading = false;
+ },
+ mouseClickSecond() {
+ this.fullscreenLoading = true;
+ this.RGVSecond = true;
+ this.fullscreenLoading = false;
+ },
+ mouseClickThird() {
+ this.fullscreenLoading = true;
+ this.RGVThird = true;
+ this.fullscreenLoading = false;
+ },
+ // SendCommand(x) {
+ // this.fullscreenLoading = true;
+ // this.formRGV.DeviceCode = x;
+ // this.http.post("api/DeviceInfo/RGVHandTask", this.formRGV)
+ // .then((x) => {
+ // if (!x.status) {
+ // this.$message.error(x.message);
+ // } else {
+ // this.$Message.success(x.message);
+ // $vue.refresh();
+ // }
+ // })
+ // .finally(() => {
+ // this.fullscreenLoading = false;
+ // });
+ // },
+ // RGVReset(x) {
+ // this.fullscreenLoading = true;
+ // this.http.post("api/DeviceInfo/RGVReset?DeviceCode=" + x, null, "")
+ // .then((x) => {
+ // if (!x.status) {
+ // this.$message.error(x.message);
+ // } else {
+ // this.$Message.success(x.message);
+
+ // }
+ // })
+ // .finally(() => {
+ // this.fullscreenLoading = false;
+ // });
+ // },
+ // RGVemergencyStop(x) {
+ // this.fullscreenLoading = true;
+ // this.http.post("api/DeviceInfo/RGVemergencyStop?DeviceCode=" + x, null, "")
+ // .then((x) => {
+ // if (!x.status) {
+ // this.$message.error(x.message);
+ // } else {
+ // this.$Message.success(x.message);
+
+ // }
+ // })
+ // .finally(() => {
+ // this.fullscreenLoading = false;
+ // });
+ // },
+ // RGVPause(x) {
+ // this.fullscreenLoading = true;
+ // this.http.post("api/DeviceInfo/RGVPause?DeviceCode=" + x, null, "")
+ // .then((x) => {
+ // if (!x.status) {
+ // this.$message.error(x.message);
+ // } else {
+ // this.$Message.success(x.message);
+ // }
+ // })
+ // .finally(() => {
+ // this.fullscreenLoading = false;
+ // });
+ // },
+ // RGVCancel(x) {
+ // this.fullscreenLoading = true;
+ // this.http.post("api/DeviceInfo/RGVCancel?DeviceCode=" + x, null, "")
+ // .then((x) => {
+ // if (!x.status) {
+ // this.$message.error(x.message);
+ // } else {
+ // this.$Message.success(x.message);
+ // }
+ // })
+ // .finally(() => {
+ // this.fullscreenLoading = false;
+ // });
+ // },
+ // RGVInitialize(x) {
+ // this.fullscreenLoading = true;
+ // this.http.post("api/DeviceInfo/RGVInitialize?DeviceCode=" + x, null, "")
+ // .then((x) => {
+ // if (!x.status) {
+ // this.$message.error(x.message);
+ // } else {
+ // this.$Message.success(x.message);
+ // }
+ // })
+ // .finally(() => {
+ // this.fullscreenLoading = false;
+ // });
+ // },
+ },
+ computed: {
+
+ },
+ mounted() {
+ // 鐩戝惉WebSocket娑堟伅
+ this.$watch(
+ () => this.messages.length,
+ (newLength, oldLength) => {
+ if (newLength > oldLength) {
+ const data = this.messages[newLength - 1];
+ this.processWebSocketMessage(data);
+ }
+ }
+ );
+ },
+ created() {
+ // WebSocket杩炴帴宸插湪setup涓垵濮嬪寲
+ },
+ methods: {
+ // 澶勭悊WebSocket娑堟伅
+ processWebSocketMessage(data) {
+ //鏀跺埌鐨勬秷鎭暟鎹�
+ console.log(data);
+ // 澶勭悊鍫嗗灈鏈烘暟鎹�
+ if (data && data.R_PP_Status) {
+ const stackerComponentsMap = {
+ "SC01_YL": 'stacker1',
+ "SC02_YL": 'stacker2',
+ "SC03_YLDual": 'stacker3',
+ "SC04_YLDual": 'stacker4',
+ "SC05_YLDual": 'stacker5',
+ "SC01_CP": 'stackerCP1',
+ "SC02_CP": 'stackerCP2',
+ "SC03_CP": 'stackerCP3',
+ "SC04_CP": 'stackerCP4',
+ "SC05_CP": 'stackerCP5',
+ };
+ const componentKey = stackerComponentsMap[data.R_PP_Status];
+ if (componentKey) {
+ const stackerData = {
+ YL_Status: data.YL_Status || "",
+ YL_AutoStatus: data.YL_AutoStatus || "",
+ YL_TaskNum: data.YL_TaskNum || "",
+ YL_WorkStatus: data.YL_WorkStatus || "",
+ YL_WorkType: data.YL_WorkType || "",
+ YL_Row: data.YL_Row || "0",
+ YL_Column: data.YL_Column || "0",
+ YL_Layer: data.YL_Layer || "0",
+ DeviceCode: data.R_PP_Status || "",
+ StackerAlarm: data.StackerAlarm || ""
+ };
+ this.$nextTick(() => {
+ if (this.$refs[componentKey]) {
+ this.$refs[componentKey].moveDot(stackerData);
+ } else {
+ console.error('缁勪欢寮曠敤涓嶅瓨鍦�:', componentKey);
+ }
+ });
+ } else {
+ console.warn('鏈壘鍒板尮閰嶇殑缁勪欢鏄犲皠:', data.R_PP_Status);
+ }
+ }
+ // 澶勭悊杈撻�佺嚎鏁版嵁锛堝吋瀹瑰師鏂欏簱鍜屾垚鍝佸簱锛�
+ else if (data && (data.ConveyorLineInfo || data.ConveyorLineCPInfo)) {
+ // 鑾峰彇杈撻�佺嚎鏁版嵁锛屽吋瀹逛笉鍚岀殑閿悕
+ const conveyorLineData = data.ConveyorLineInfo || data.ConveyorLineCPInfo;
+ // 鏇存柊杈撻�佺嚎鐘舵��
+
+ // 瀹氫箟缂栧彿鏄犲皠鍏崇郴锛堝師鏂欏簱鍜屾垚鍝佸簱锛�
+ const stationCodeMap = {
+ "SC05-1": "320",
+ "SC05-2": "321",
+ "SC04-1": "322",
+ "SC04-2": "323",
+ "SC03-1": "324",
+ "SC03-2": "325",
+ "SC02-2": "424",
+ "SC02-1": "423",
+ "SC01-1": "422",
+ "SC01-2": "425",
+ };
+
+ // 鍏堟敹闆嗘墍鏈塃rror淇℃伅
+ const errorMap = {};
+ for (const key in conveyorLineData) {
+ if (conveyorLineData[key].Error !== undefined) {
+ errorMap[key] = conveyorLineData[key].Error;
+ }
+ }
+
+ // 閬嶅巻鎵�鏈夎緭閫佺嚎鏁版嵁锛屾洿鏂板搴旂殑鏉′欢
+ for (const stationCode in conveyorLineData) {
+ // 璺宠繃鍙湁Error瀛楁鐨勯」
+ if (conveyorLineData[stationCode].Error !== undefined && Object.keys(conveyorLineData[stationCode]).length === 1) {
+ continue;
+ }
+
+ // 鑾峰彇鏄犲皠鍚庣殑缂栧彿
+ const mappedStationCode = stationCodeMap[stationCode] || stationCode;
+ // 閬嶅巻鎵�鏈塴inescopy鏁扮粍锛屾煡鎵惧搴旂殑绔欏彴
+ const allLines = [
+ ...this.linescopy1,
+ ...this.linescopy2,
+ ...this.linescopy3,
+ ...this.linescopy4,
+ ...this.linescopy5,
+ ...this.linescopy6,
+ ...this.linescopy7,
+ ...this.linescopy8,
+ ...this.linescopy9,
+ ...this.linescopy10,
+ ...this.linescopy11,
+ ...this.linescopy12,
+ ...this.linescopyCP1,
+ ...this.linescopyCP2,
+ ...this.linescopyCP3,
+ ...this.linescopyCP4,
+ ...this.linescopyCP5,
+ ...this.linescopyCP6,
+ ...this.linescopyCP7,
+ ...this.linescopyCP8,
+ ...this.linescopyCP9,
+ ...this.linescopyCP10
+ ];
+
+ allLines.forEach((line) => {
+ if (String(line.equipNo) === String(mappedStationCode)) {
+ // 鍒ゆ柇鏄惁涓烘垚鍝佸簱杈撻�佺嚎锛堢紪鍙蜂互10寮�澶达級
+ const isCP = String(line.equipNo).startsWith('10');
+ // 鏍规嵁HasGoods瀛楁鍒ゆ柇鐘舵�侊紝鎴愬搧搴撴牴鎹换鍔″彿鍒ゆ柇鏄惁鏈夌洏
+ const rawHasGoods = conveyorLineData[stationCode].HasGoods || false;
+ const taskNum = conveyorLineData[stationCode].TaskNum;
+ const hasGoods = isCP ? (taskNum && taskNum !== '0') : rawHasGoods;
+ // 纭繚condition鏄竷灏斿��
+ line.condition = !!hasGoods;
+ // 瀛樺偍杈撻�佺嚎璇︾粏淇℃伅鍒板叏灞�鍙橀噺
+ this.$root.conveyorLineDetails = this.$root.conveyorLineDetails || {};
+ // 鑾峰彇鐜版湁鐨勮缁嗕俊鎭�
+ const existingDetails = this.$root.conveyorLineDetails[line.equipNo] || {};
+ // 鏍规嵁搴撶被鍨嬩娇鐢ㄤ笉鍚岀殑瀛楁鍒ゆ柇鎶ヨ鐘舵��
+ let alarmMessage = "鏃�";
+ let isAlarm = false;
+
+ if (isCP) {
+ // 鎴愬搧搴擄細浣跨敤Status瀛楁
+ const statusValue = conveyorLineData[stationCode].Status;
+ if (statusValue === 1 || statusValue === 2 || statusValue === 3) {
+ alarmMessage = "姝e父";
+ isAlarm = false;
+ } else if (statusValue === 4) {
+ alarmMessage = statusValue === 0 ? "鑴辨満涓�" : "璁惧鏁呴殰";
+ isAlarm = true;
+ } else {
+ isAlarm = false;
+ }
+ } else {
+ // 鍘熸枡搴擄細浣跨敤Error瀛楁
+ let errorValue = undefined;
+ for (const scKey in stationCodeMap) {
+ if (stationCodeMap[scKey] === mappedStationCode) {
+ errorValue = errorMap[scKey];
+ break;
+ }
+ }
+ if (errorValue === 1) {
+ alarmMessage = "姝e父";
+ } else if (errorValue === 2) {
+ alarmMessage = "鏁呴殰";
+ isAlarm = true;
+ }
+ }
+ // 鍚堝苟鏁版嵁锛岀‘淇濇潵鑷笉鍚屾暟鎹簮鐨勫瓧娈甸兘鑳借淇濈暀
+ this.$root.conveyorLineDetails[line.equipNo] = {
+ taskNum: taskNum || existingDetails.taskNum || "鏃�",
+ inStock: hasGoods ? "鏄�" : existingDetails.inStock || "鍚�",
+ alarm: alarmMessage || existingDetails.alarm || "鏃�",
+ rfid: conveyorLineData[stationCode].RFID || existingDetails.rfid || "鏃�",
+ width: conveyorLineData[stationCode].Width || existingDetails.width || 0,
+ request: conveyorLineData[stationCode].Request || existingDetails.request || "鏃�",
+ reresult: conveyorLineData[stationCode].Reresult || existingDetails.reresult || "鏃�",
+ error: alarmMessage || existingDetails.error || "鏃�",
+ heartbeat: conveyorLineData[stationCode].Heartbeat || existingDetails.heartbeat || "鏃�",
+ status: conveyorLineData[stationCode].Status || existingDetails.status || "鏃�",
+ palletCode: conveyorLineData[stationCode].PalletCode || existingDetails.palletCode || "鏃�",
+ command: conveyorLineData[stationCode].Command || existingDetails.command || "鏃�",
+ isAlarm: isAlarm,
+ };
+ }
+ });
+ }
+ }
+ // 澶勭悊璁惧鏁版嵁锛屽寘鎷緭閫佺嚎鍜屾ā鎷熶俊鍙�
+ else if (data && (data.StackerDataJson || data.ConveyorLineDataJson)) {
+ // 澶勭悊杈撻�佺嚎鏁版嵁
+ if (data.ConveyorLineDataJson) {
+ try {
+ const conveyorLineData = JSON.parse(data.ConveyorLineDataJson);
+ // 鏇存柊杈撻�佺嚎鐘舵��
+ // 瀹氫箟缂栧彿鏄犲皠鍏崇郴锛岀洿鎺ユ槧灏勫埌鍏蜂綋鐨勮緭閫佺嚎缂栧彿
+ const stationCodeMap = {
+ "SC05-1": "320",
+ "SC05-2": "321",
+ "SC04-1": "322",
+ "SC04-2": "323",
+ "SC03-1": "324",
+ "SC03-2": "325",
+ "SC02-2": "424",
+ "SC02-1": "423",
+ "SC01-1": "422",
+ "SC01-2": "425",
+ "SC05-1-CP": "1003",
+ "SC05-2-CP": "1008",
+ "SC04-1-CP": "1007",
+ "SC04-2-CP": "1012",
+ "SC03-1-CP": "1013",
+ "SC03-2-CP": "1018",
+ "SC02-1-CP": "1017",
+ "SC02-2-CP": "1022",
+ "SC01-1-CP": "1023",
+ "SC01-2-CP": "1026",
+ };
+
+ // 閬嶅巻鎵�鏈塴inescopy鏁扮粍锛屾煡鎵惧搴旂殑绔欏彴
+ const linesArrays = [
+ this.linescopy1,
+ this.linescopy2,
+ this.linescopy3,
+ this.linescopy4,
+ this.linescopy5,
+ this.linescopy6,
+ this.linescopy7,
+ this.linescopy8,
+ this.linescopy9,
+ this.linescopy10,
+ this.linescopy11,
+ this.linescopy12,
+ this.linescopyCP1,
+ this.linescopyCP2,
+ this.linescopyCP3,
+ this.linescopyCP4,
+ this.linescopyCP5,
+ this.linescopyCP6,
+ this.linescopyCP7,
+ this.linescopyCP8,
+ this.linescopyCP9,
+ this.linescopyCP10
+ ];
+
+ // 閬嶅巻鎵�鏈夎緭閫佺嚎鏁版嵁锛屾洿鏂板搴旂殑鏉′欢
+ for (const roadway in conveyorLineData) {
+ // 鑾峰彇鏄犲皠鍚庣殑缂栧彿
+ const mappedStationCode = stationCodeMap[roadway] || roadway;
+
+ // 閬嶅巻姣忎釜lines鏁扮粍
+ linesArrays.forEach((linesArray) => {
+ linesArray.forEach((line) => {
+ if (String(line.equipNo) === String(mappedStationCode)) {
+ if (conveyorLineData[roadway][line.equipNo]) {
+ // 鍒ゆ柇鏄惁涓烘垚鍝佸簱杈撻�佺嚎锛堢紪鍙蜂互10寮�澶达級
+ const isCP = String(line.equipNo).startsWith('10');
+ // 鏍规嵁HasGoods瀛楁鍒ゆ柇鐘舵�侊紝鎴愬搧搴撴牴鎹换鍔″彿鍒ゆ柇鏄惁鏈夌洏
+ const rawHasGoods = conveyorLineData[roadway][line.equipNo].inStock || conveyorLineData[roadway][line.equipNo].HasGoods || false;
+ const taskNum = conveyorLineData[roadway][line.equipNo].taskNum || conveyorLineData[roadway][line.equipNo].TaskNum;
+ const hasGoods = isCP ? (taskNum && taskNum !== '0') : rawHasGoods;
+ line.condition = !!hasGoods;
+ // 瀛樺偍杈撻�佺嚎璇︾粏淇℃伅鍒板叏灞�鍙橀噺
+ this.$root.conveyorLineDetails = this.$root.conveyorLineDetails || {};
+ // 鑾峰彇鐜版湁鐨勮缁嗕俊鎭�
+ const existingDetails = this.$root.conveyorLineDetails[line.equipNo] || {};
+ // 鏍规嵁搴撶被鍨嬩娇鐢ㄤ笉鍚岀殑瀛楁鍒ゆ柇鎶ヨ鐘舵��
+ let alarmMessage = "鏃�";
+ let isAlarm = false;
+
+ if (isCP) {
+ // 鎴愬搧搴擄細浣跨敤Status瀛楁
+ const statusValue = conveyorLineData[roadway][line.equipNo].status || conveyorLineData[roadway][line.equipNo].Status;
+ if (statusValue === 1 || statusValue === 2 || statusValue === 3) {
+ alarmMessage = "姝e父";
+ isAlarm = false;
+ } else if (statusValue === 0 || statusValue === 4) {
+ alarmMessage = statusValue === 0 ? "鑴辨満涓�" : "璁惧鏁呴殰";
+ isAlarm = true;
+ } else {
+ isAlarm = false;
+ }
+ } else {
+ // 鍘熸枡搴擄細浣跨敤Error瀛楁
+ const errorValue = conveyorLineData[roadway][line.equipNo].error || conveyorLineData[roadway][line.equipNo].Error;
+ if (errorValue === 1) {
+ alarmMessage = "姝e父";
+ isAlarm = false;
+ } else if (errorValue === 2) {
+ alarmMessage = "鏁呴殰";
+ isAlarm = true;
+ } else {
+ isAlarm = false;
+ }
+ }
+ // 鍚堝苟鏁版嵁锛岀‘淇濇潵鑷笉鍚屾暟鎹簮鐨勫瓧娈甸兘鑳借淇濈暀
+ this.$root.conveyorLineDetails[line.equipNo] = {
+ taskNum: taskNum || existingDetails.taskNum || "鏃�",
+ inStock: hasGoods ? "鏄�" : existingDetails.inStock || "鍚�",
+ rfid: conveyorLineData[roadway][line.equipNo].rfid || conveyorLineData[roadway][line.equipNo].RFID || existingDetails.rfid || "鏃�",
+ width: conveyorLineData[roadway][line.equipNo].width || conveyorLineData[roadway][line.equipNo].Width || existingDetails.width || 0,
+ request: conveyorLineData[roadway][line.equipNo].request || conveyorLineData[roadway][line.equipNo].Request || existingDetails.request || "鏃�",
+ reresult: conveyorLineData[roadway][line.equipNo].reresult || conveyorLineData[roadway][line.equipNo].Reresult || existingDetails.reresult || "鏃�",
+ error: alarmMessage || existingDetails.error || "鏃�",
+ alarm: alarmMessage || existingDetails.alarm || "鏃�",
+ heartbeat: conveyorLineData[roadway][line.equipNo].heartbeat || conveyorLineData[roadway][line.equipNo].Heartbeat || existingDetails.heartbeat || "鏃�",
+ status: conveyorLineData[roadway][line.equipNo].status || conveyorLineData[roadway][line.equipNo].Status || existingDetails.status || "鏃�",
+ palletCode: conveyorLineData[roadway][line.equipNo].palletCode || conveyorLineData[roadway][line.equipNo].PalletCode || existingDetails.palletCode || "鏃�",
+ command: conveyorLineData[roadway][line.equipNo].command || conveyorLineData[roadway][line.equipNo].Command || existingDetails.command || "鏃�",
+ isAlarm: isAlarm,
+ };
+ }
+ }
+ });
+ });
+ }
+ } catch (e) {
+ console.error('杈撻�佺嚎鏁版嵁瑙f瀽澶辫触', e);
+ }
+ }
+ }
+ // 涓嶅啀鏄剧ず鏈鐞嗙殑娑堟伅绫诲瀷鏃ュ織锛岄伩鍏嶆帶鍒跺彴娣蜂贡
+ // 鍙鐞嗗凡鐭ョ被鍨嬬殑鏁版嵁锛屽拷鐣ュ叾浠栫被鍨�
+ },
groupedLines(linescopy) {
const groups = {};
linescopy.forEach((line) => {
@@ -675,81 +1554,6 @@
});
},
},
- computed: {
-
- },
- mounted() {
- },
- created() {
-
- this.ws = new WebSocket('ws://localhost:9260/');
-
- this.ws.onmessage = (event) => {
- try {
- const data = JSON.parse(event.data);
- console.log('鏀跺埌娑堟伅:', data);
- // 澶勭悊娑堟伅...
- } catch (e) {
- console.error('娑堟伅瑙f瀽澶辫触', e);
- }
- };
- const stackerComponentsMap = {
- "SC01": 'stacker1',
- "SC02": 'stacker2',
- "SC03": 'stacker3',
- "SC04": 'stacker4',
- "SC05": 'stacker5',
- "SC06": 'stacker6',
- };
- // const componentKey = stackerComponentsMap[data.R_PP_Status];
- // if (componentKey) {
- // this.StackerCrane.Automatic = data;
- // this.StackerCrane.Fault = data;
- // this.StackerCrane.Running = data;
- // this.StackerCrane.CurrentColumn = data;
- // this.StackerCrane.CurrentLayer = data;
- // this.StackerCrane.LevelPoint = data;
- // this.StackerCrane.DeviceName = data;
- // this.StackerCrane.DeviceCode = data;
- // this.StackerCrane.CurrentTaskNum = data;
- // this.StackerCrane.StackerAlarm = data;
-
- // this.$nextTick(() => {
- // this.$refs[componentKey].moveDot(this.StackerCrane);
- // });
- // }
- const stationMap = {
- "SC011F": this.linescopy1,
- "SC021F": this.linescopy2,
- "SC031F": this.linescopy3,
- "SC041F": this.linescopy4,
- "SC051F": this.linescopy5,
- "SC061F": this.linescopy6,
- "SC071F": this.linescopy7,
- "SC081F": this.linescopy8,
- "SC091F": this.linescopy9,
- "SC101F": this.linescopy10,
- "SC111F": this.linescopy11,
- "SC121F": this.linescopy12,
- "SC012F": this.linescopy13,
- "SC022F": this.linescopy13,
- "SC032F": this.linescopy13,
- "SC042F": this.linescopy13,
- "SC052F": this.linescopy13,
- "SC062F": this.linescopy13,
- "SC072F": this.linescopy13,
- "SC082F": this.linescopy14,
- };
-
- // var station = eventData.stationChildCode;
- // if (stationMap[eventData.roadway]) {
- // stationMap[eventData.roadway].forEach((line) => {
- // if (line.equipNo === station) {
- // line.condition = eventData.inStock;
- // }
- // })
- // }
- },
};
</script>
@@ -758,7 +1562,8 @@
margin-bottom: 10px;
} */
.title {
- height: 1800px;
+ height: auto;
+ margin-bottom: 50px;
}
.cardWidth {
@@ -787,7 +1592,13 @@
.stackerDiv {
border: 1px solid rgba(0, 195, 255, 0.822);
- width: 980px;
+ width: 2720px;
+ padding-left: 3px;
+}
+
+.stackerDivCP {
+ border: 1px solid rgba(0, 195, 255, 0.822);
+ width: 2000px;
padding-left: 3px;
}
@@ -890,4 +1701,5 @@
height: 1px;
/* margin-top:180px; */
background-color: #a0cfff;
-}</style>
\ No newline at end of file
+}
+</style>
\ No newline at end of file
--
Gitblit v1.9.3