From 909164aa1859fdf25330eb130bc90b8bd22e540b Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期二, 24 三月 2026 12:00:51 +0800
Subject: [PATCH] #

---
 src/main/webapp/components/DevpCard.js |   48 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 48 insertions(+), 0 deletions(-)

diff --git a/src/main/webapp/components/DevpCard.js b/src/main/webapp/components/DevpCard.js
index c2a89b3..118fcdb 100644
--- a/src/main/webapp/components/DevpCard.js
+++ b/src/main/webapp/components/DevpCard.js
@@ -1,3 +1,5 @@
+var stationTracePageVersion = "20260319_station_trace_layout_v2";
+
 Vue.component("devp-card", {
   template: `
     <div class="mc-root">
@@ -32,6 +34,8 @@
           <div class="mc-action-row">
             <button type="button" class="mc-btn" @click="controlCommand">涓嬪彂</button>
             <button type="button" class="mc-btn mc-btn-soft" @click="resetCommand">澶嶄綅</button>
+            <button type="button" class="mc-btn mc-btn-ghost" @click="openStationTracePage">杩愯杞ㄨ抗</button>
+            <button v-if="showFakeTraceEntry" type="button" class="mc-btn mc-btn-ghost" @click="openFakeTracePage">浠跨湡杞ㄨ抗</button>
           </div>
         </div>
       </div>
@@ -113,6 +117,7 @@
         targetStationId: ""
       },
       barcodePreviewCache: {},
+      showFakeTraceEntry: false,
       pageSize: this.readOnly ? 24 : 12,
       currentPage: 1,
       timer: null
@@ -155,6 +160,7 @@
   },
   created: function () {
     MonitorCardKit.ensureStyles();
+    this.loadFakeProcessStatus();
     if (this.autoRefresh) {
       this.timer = setInterval(this.getDevpStateInfo, 1000);
     }
@@ -223,8 +229,34 @@
         this.afterDataRefresh();
       }
     },
+    loadFakeProcessStatus: function () {
+      if (this.readOnly || !window.$ || typeof baseUrl === "undefined") {
+        this.showFakeTraceEntry = false;
+        return;
+      }
+      $.ajax({
+        url: baseUrl + "/openapi/getFakeSystemRunStatus",
+        method: "get",
+        success: function (res) {
+          var data = res && res.data ? res.data : null;
+          this.showFakeTraceEntry = !!(data && data.isFake);
+        }.bind(this),
+        error: function () {
+          this.showFakeTraceEntry = false;
+        }.bind(this)
+      });
+    },
     openControl: function () {
       this.showControl = !this.showControl;
+    },
+    openFakeTracePage: function () {
+      if (!this.showFakeTraceEntry) {
+        return;
+      }
+      window.open(baseUrl + "/views/watch/fakeTrace.html", "_blank");
+    },
+    openStationTracePage: function () {
+      window.open(baseUrl + "/views/watch/stationTrace.html?v=" + stationTracePageVersion, "_blank");
     },
     buildDetailEntries: function (item) {
       return [
@@ -243,11 +275,27 @@
         { label: "鏉$爜", value: this.orDash(item.barcode), code: true, type: "barcode" },
         { label: "閲嶉噺", value: this.orDash(item.weight) },
         { label: "浠诲姟鍙啓鍖�", value: this.orDash(item.taskWriteIdx) },
+        { label: "缂撳瓨鍖烘暟鎹�", value: this.formatTaskBufferItems(item.taskBufferItems), code: true },
         { label: "鏁呴殰浠g爜", value: this.orDash(item.error) },
         { label: "鏁呴殰淇℃伅", value: this.orDash(item.errorMsg) },
+        { label: "绯荤粺鍛婅", value: this.orDash(item.systemWarning) },
         { label: "鎵╁睍鏁版嵁", value: this.orDash(item.extend) }
       ];
     },
+    formatTaskBufferItems: function (items) {
+      if (!Array.isArray(items) || items.length === 0) {
+        return "--";
+      }
+      return items.map(function (item) {
+        var slotIdx = item && item.slotIdx != null ? item.slotIdx : "?";
+        var taskNo = item && item.taskNo != null ? item.taskNo : 0;
+        var targetStaNo = item && item.targetStaNo != null ? item.targetStaNo : 0;
+        if (!taskNo && !targetStaNo) {
+          return slotIdx + ": 绌�";
+        }
+        return slotIdx + ": " + taskNo + " -> " + targetStaNo;
+      }).join(" | ");
+    },
     postControl: function (url, payload) {
       $.ajax({
         url: baseUrl + url,

--
Gitblit v1.9.1