From 340fd90b8c92f3c7d3a3d85bad643e6fbd7fdaf4 Mon Sep 17 00:00:00 2001
From: Junjie <xjj@123>
Date: 星期日, 15 六月 2025 12:50:48 +0800
Subject: [PATCH] #

---
 src/main/webapp/views/pipeline.html |  306 +++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 224 insertions(+), 82 deletions(-)

diff --git a/src/main/webapp/views/pipeline.html b/src/main/webapp/views/pipeline.html
index 8c19df6..c182d24 100644
--- a/src/main/webapp/views/pipeline.html
+++ b/src/main/webapp/views/pipeline.html
@@ -13,99 +13,166 @@
     <script type="text/javascript" src="../static/js/common.js"></script>
     <script type="text/javascript" src="../static/js/layer/layer.js"></script>
     <style>
-
+        .io-mode-box {
+            float: left;
+            width: 16%;
+            text-align: center;
+        }
+        .io-mode-box label {
+            font-weight: bolder;
+        }
+        .ioModeBtn {
+            vertical-align: middle;
+            width: 50%;
+            height: 30px;
+            left: 0;
+            top: 0;
+            text-shadow: inherit;
+            font-size: 15px;
+            margin-left: 5px;
+            margin-right: 5px;
+            display: inline-block;
+            background-color: #FF5722;
+            border: none;
+            color: #FFF;
+            box-shadow: 1px 1px 5px #B6B6B6;
+            border-radius: 3px;
+            cursor: pointer;
+        }
     </style>
 </head>
 <body>
-<main>
-    <!-- plc寮傚父鏃ュ織鐩戞帶鐗� -->
-    <div id="plc-error" class="main-board" style="padding-left: 10px">
-        <!-- 澶撮儴 -->
-        <div class="plc-log-header">
-<!--            <div style="height: 40%">-->
-<!--                <span>涓滀晶PLC鎵ц鎸囦护</span>-->
-<!--            </div>-->
-<!--            <div style="height: 40%">-->
-<!--                <span>瑗夸晶PLC鎵ц鎸囦护</span>-->
-<!--            </div>-->
-            <div>
-                <span style="color: #1E9FFF">PLC寮傚父淇℃伅琛�:</span>
+<div style="padding: 10px;height: 100%;float: left;width: 6%">
+    <div class="button-window"></div>
+</div>
+
+<div style="height: 100%;padding-left: 6%">
+    <div style="padding: 10px;height: 100%">
+        <main>
+
+            <!-- plc寮傚父鏃ュ織鐩戞帶鐗� -->
+            <div id="plc-error" class="main-board" style="padding-left: 10px">
+                <!-- 澶撮儴 -->
+<!--                <div class="plc-log-header">-->
+<!--                    &lt;!&ndash; 璁惧浠诲姟鎿嶄綔 &ndash;&gt;-->
+<!--                    <div class="io-mode-oper">-->
+<!--                        <fieldset>-->
+<!--                            <legend>鍏ュ嚭搴撴ā寮忥紙IO-Mode锛�</legend>-->
+<!--                            <div class="io-mode-box">-->
+<!--                                <label>F2</label>-->
+<!--                                <button id="io-mode-2" class="ioModeBtn" onclick="ioModeSwitch(this.id)"> - </button>-->
+<!--                            </div>-->
+<!--                            <div class="io-mode-box">-->
+<!--                                <label>F4</label>-->
+<!--                                <button id="io-mode-4" class="ioModeBtn" onclick="ioModeSwitch(this.id)"> - </button>-->
+<!--                            </div>-->
+<!--                        </fieldset>-->
+<!--                    </div>-->
+<!--                    &lt;!&ndash;            <div style="height: 40%">&ndash;&gt;-->
+<!--                    &lt;!&ndash;                <span>涓滀晶PLC鎵ц鎸囦护</span>&ndash;&gt;-->
+<!--                    &lt;!&ndash;            </div>&ndash;&gt;-->
+<!--                    &lt;!&ndash;            <div style="height: 40%">&ndash;&gt;-->
+<!--                    &lt;!&ndash;                <span>瑗夸晶PLC鎵ц鎸囦护</span>&ndash;&gt;-->
+<!--                    &lt;!&ndash;            </div>&ndash;&gt;-->
+<!--                    &lt;!&ndash;                    <div>&ndash;&gt;-->
+<!--                    &lt;!&ndash;                        <span style="color: #1E9FFF">PLC寮傚父淇℃伅琛�:</span>&ndash;&gt;-->
+<!--                    &lt;!&ndash;                    </div>&ndash;&gt;-->
+<!--                </div>-->
+                <!-- 涓讳綋 -->
+                <div class="plc-log-body">
+                    <div>
+                        <span style="color: #1E9FFF">PLC寮傚父淇℃伅琛�:</span>
+                    </div>
+                    <table id="plc-error-table">
+                        <thead>
+                        <tr>
+                            <th style="width: 200px">搴忓彿</th>
+                            <th style="width: 400px">PLC閿欒鎻忚堪</th>
+                            <th style="width: 400px">寮傚父</th>
+                        </tr>
+                        </thead>
+                        <tbody>
+
+                        </tbody>
+                    </table>
+                </div>
             </div>
-        </div>
-        <!-- 涓讳綋 -->
-        <div class="plc-log-body">
-            <table id="plc-error-table">
-                <thead>
+
+            <!-- 绔欑偣鐘舵�佹暟鎹洃鎺х増 -->
+            <div id="site-monitor" class="main-board">
+                <!-- 琛ㄦ牸 -->
+                <!--鍥哄畾琛ㄥご table 鍔爐able-layout: fixed;  th 鍔� position:sticky;top: 0;-->
+                <table id="site-table" style="table-layout: fixed;">
+                    <!-- 琛ㄥご -->
+                    <thead style="position:sticky;top: 0;">
                     <tr>
-                        <th style="width: 200px">搴忓彿</th>
-                        <th style="width: 400px">PLC閿欒鎻忚堪</th>
-                        <th style="width: 400px">寮傚父</th>
+                        <th>绔欏彿</th>
+                        <th>宸ヤ綔鍙�</th>
+                        <th>鑷姩</th>
+                        <th>鏈夌墿</th>
+                        <th>鍙叆</th>
+                        <th>鍙嚭</th>
+                        <th>鍏ュ簱鏍囪</th>
+                        <th>绌烘澘淇″彿</th>
+                        <th>鐩爣绔�</th>
+                        <th>楂樹綆搴撲綅</th>
                     </tr>
-                </thead>
-                <tbody>
+                    </thead>
+                    <!-- 琛ㄦ牸鍐呭 -->
+                    <tbody></tbody>
+                </table>
+            </div>
+        </main>
+        <footer>
+            <textarea id="output"></textarea>
+        </footer>
 
-                </tbody>
-            </table>
+        <div id="site-detl" style="display: none">
+            <form>
+                <div class="form-item">
+                    <label class="form-label">绔欏彿:</label>
+                    <div class="form-input">
+                        <input id="siteId" name="siteId" class="layui-input" lay-verify="required|number" autocomplete="off" disabled="disabled">
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">宸ヤ綔鍙�:</label>
+                    <div class="form-input">
+                        <input id="workNo" name="workNo" type="number" class="layui-input" lay-verify="number" autocomplete="off">
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鐩爣绔�:</label>
+                    <div class="form-input">
+                        <input id="staNo" name="staNo" type="number" class="layui-input" lay-verify="number" autocomplete="off">
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鎵樼洏灏哄:</label>
+                    <div class="form-input">
+                        <input id="palletSize" name="palletSize" type="number" class="layui-input" lay-verify="number" autocomplete="off">
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍏ュ簱鏍囪:</label>
+                    <div class="form-input">
+                        <input id="pakMk" name="pakMk" type="text" class="layui-input" autocomplete="off">
+                    </div>
+                </div>
+                <div class="form-item form-button-container">
+                    <button class="form-button" id="save">淇濆瓨</button>
+                    <button class="form-button" id="cancel" style="background-color: #D0D0D0">鍙栨秷</button>
+                </div>
+            </form>
         </div>
     </div>
 
-    <!-- 绔欑偣鐘舵�佹暟鎹洃鎺х増 -->
-    <div id="site-monitor" class="main-board">
-        <!-- 琛ㄦ牸 -->
-        <table id="site-table">
-            <!-- 琛ㄥご -->
-            <thead>
-                <tr>
-                    <th>绔欏彿</th>
-                    <th>宸ヤ綔鍙�</th>
-                    <th>鑷姩</th>
-                    <th>鏈夌墿</th>
-                    <th>鍙叆</th>
-                    <th>鍙嚭</th>
-                    <th>鍏ュ簱鏍囪</th>
-                    <th>绌烘澘淇″彿</th>
-                    <th>鐩爣绔�</th>
-                </tr>
-            </thead>
-            <!-- 琛ㄦ牸鍐呭 -->
-            <tbody></tbody>
-        </table>
-    </div>
-</main>
-<footer>
-    <textarea id="output"></textarea>
-</footer>
-
-<div id="site-detl" style="display: none">
-    <form>
-        <div class="form-item">
-            <label class="form-label">绔欏彿:</label>
-            <div class="form-input">
-                <input id="siteId" name="siteId" class="layui-input" lay-verify="required|number" autocomplete="off" disabled="disabled">
-            </div>
-        </div>
-        <div class="form-item">
-            <label class="form-label">宸ヤ綔鍙�:</label>
-            <div class="form-input">
-                <input id="workNo" name="workNo" type="number" class="layui-input" lay-verify="number" autocomplete="off">
-            </div>
-        </div>
-        <div class="form-item">
-            <label class="form-label">鐩爣绔�:</label>
-            <div class="form-input">
-                <input id="staNo" name="staNo" type="number" class="layui-input" lay-verify="number" autocomplete="off">
-            </div>
-        </div>
-        <div class="form-item form-button-container">
-            <button class="form-button" id="save">淇濆瓨</button>
-            <button class="form-button" id="cancel" style="background-color: #D0D0D0">鍙栨秷</button>
-        </div>
-    </form>
 </div>
 </body>
 <script>
     // 鍒濆鍖�
     // 绌虹櫧琛屾暟
+    var stop = false
     var plcErrorTableBlankRows = 0;
     var siteTableBlankRows = 0;
     // 瀹為檯琛屾暟
@@ -113,6 +180,7 @@
     var siteTableFullRows = 0;
     var outputDom = document.getElementById("output");
     $(document).ready(function() {
+        getIoModeInfo();
         initPlcErrorTable();
         getPlcError();
         initSiteTable();
@@ -121,11 +189,74 @@
     // 瀹炴椂璁块棶
     setInterval(function () {
         getPlcError();
-        getSite();
+        starGetSite();
+        getIoModeInfo();
     }, 1000);
     setInterval(function () {
         getSiteOutput();
     },500);
+    function starGetSite() {
+        if (stop) {
+            return
+        } else {
+            getSite();
+        }
+    }
+
+    var ioModeData;
+    function getIoModeInfo() {
+        $.ajax({
+            url: baseUrl+ "/site/io/mode/info/site",
+            headers: {'token': localStorage.getItem('token')},
+            method: 'GET',
+            success: function (res) {
+                if (res.code === 200){
+                    ioModeData = res.data;
+                    ioModeData.forEach(function (e) {
+                        $("#io-mode-"+e.floor).html(e.modeDesc);
+                    })
+                } else if (res.code === 403){
+                    window.location.href = baseUrl+"/login";
+                }  else {
+                    console.log(res.msg);
+                }
+            }
+        });
+    }
+
+    /**
+     * 寮哄埗鍒囨崲鍏ュ嚭搴撴ā寮�
+     */
+    function ioModeSwitch(el) {
+        var floor = el.split("-")[2];
+        if (ioModeData != null && ioModeData.length > 1) {
+            ioModeData.forEach(function(e) {
+                if (e.floor === Number(floor)) {
+                    if (e.modeVal === 3 || e.modeVal === 4) {
+                        layer.confirm('纭畾鍒囨崲涓哄叆搴撴ā寮忓悧锛�',function () {
+                            $.ajax({
+                                url: baseUrl+ "/site/io/mode/action/site",
+                                headers: {'token': localStorage.getItem('token')},
+                                data: {floor: e.floor},
+                                method: 'POST',
+                                success: function (res) {
+                                    if (res.code === 200){
+                                        layer.msg("鏆傛椂涓嶈兘鍒囨崲锛�", {icon: 1})
+                                    } else if (res.code === 403){
+                                        window.location.href = baseUrl+"/login";
+                                    }  else {
+                                        console.log(res.msg);
+                                    }
+                                }
+                            });
+                            layer.closeAll();
+                        })
+                    }
+                }
+            });
+        }
+
+    }
 
     // plc寮傚父淇℃伅琛ㄨ幏鍙�
     function getPlcError() {
@@ -178,6 +309,7 @@
                         setVal(tr.children("td").eq(6), table[i-1].pakMk);
                         setVal(tr.children("td").eq(7), table[i-1].emptyMk);
                         setVal(tr.children("td").eq(8), table[i-1].staNo);
+                        setVal(tr.children("td").eq(9), table[i-1].locType1);
                     }
                 } else if (res.code === 403){
                     window.location.href = baseUrl+"/login";
@@ -263,6 +395,7 @@
                 "       <td></td>\n" +
                 "       <td></td>\n" +
                 "       <td></td>\n" +
+                "       <td></td>\n" +
                 "     </tr>\n";
         }
         $('#site-table tbody').after(html);
@@ -271,6 +404,7 @@
     // 璇︽儏鎿嶄綔 -------------------------------------------------------------------------
     var layerDetl;
     $(document).on('dblclick ','#site-table tr', function () {
+        stop = true
         var siteId = $(this).children("td").eq(0).html();
         if (siteId !== null && siteId !== "") {
             layerDetl = layer.open({
@@ -280,7 +414,7 @@
                 offset: 'rt',
                 anim: 5,
                 shade: [0],
-                area: ['340px', '215px'],
+                area: ['340px', '255px'],
                 closeBtn: 0,
                 content: $("#site-detl"),
                 success: function(layero, index){
@@ -288,22 +422,28 @@
                         $('#siteId').val(siteId);
                         $('#workNo').val(res.data.workNo);
                         $('#staNo').val(res.data.staNo);
+                        $('#pakMk').val(res.data.pakMk);
                     })
                 },
                 end: function () {
                     $('#siteId').val("");
                     $('#workNo').val("");
                     $('#staNo').val("");
+                    $('#pakMk').val("");
+                    stop = false
                 }
             })
         }
+
     });
 
     $(document).on('click ','#save', function () {
-        http.post(baseUrl+ "/site//detl/update", {
+        http.post(baseUrl+ "/site/detl/update", {
             siteId: $('#siteId').val(),
             workNo: $('#workNo').val(),
-            staNo:  $('#staNo').val()
+            staNo:  $('#staNo').val(),
+            palletSize:  $('#palletSize').val(),
+            pakMk: $('#pakMk').val()
         }, function (res) {
             layer.msg("淇敼鎴愬姛",{icon: 1,});
         })
@@ -312,6 +452,8 @@
         $('#siteId').val("");
         $('#workNo').val("");
         $('#staNo').val("");
+        $('#palletSize').val("");
+        $('#pakMk').val("");
         layer.close(layerDetl);
     })
 

--
Gitblit v1.9.1