From 56e96066dd6595085703b25fe2dc317590fb06f2 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期四, 10 七月 2025 16:55:37 +0800
Subject: [PATCH] 1

---
 src/main/webapp/views/pipeline.html |  340 ++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 267 insertions(+), 73 deletions(-)

diff --git a/src/main/webapp/views/pipeline.html b/src/main/webapp/views/pipeline.html
index 96ba05f..c316cbd 100644
--- a/src/main/webapp/views/pipeline.html
+++ b/src/main/webapp/views/pipeline.html
@@ -11,74 +11,162 @@
     <link rel="stylesheet" type="text/css" href="../static/css/pipeline.css">
     <script type="text/javascript" src="../static/js/jquery/jquery-3.3.1.min.js"></script>
     <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 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 style="height: 40%">
-                <span>瑗夸晶PLC鎵ц鎸囦护</span>
-            </div>
-            <div>
-                <span style="color: #1E9FFF">PLC寮傚父淇℃伅琛�:</span>
-            </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="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>
-                    <th>鐩爣绔�</th>
-                </tr>
-            </thead>
-            <!-- 琛ㄦ牸鍐呭 -->
-            <tbody></tbody>
-        </table>
-    </div>
-</main>
-<footer>
-    <textarea id="output"></textarea>
-</footer>
+</div>
 </body>
 <script>
     // 鍒濆鍖�
     // 绌虹櫧琛屾暟
+    var stop = false
     var plcErrorTableBlankRows = 0;
     var siteTableBlankRows = 0;
     // 瀹為檯琛屾暟
@@ -86,6 +174,7 @@
     var siteTableFullRows = 0;
     var outputDom = document.getElementById("output");
     $(document).ready(function() {
+        getIoModeInfo();
         initPlcErrorTable();
         getPlcError();
         initSiteTable();
@@ -94,12 +183,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() {
@@ -121,7 +272,7 @@
                 } else if (res.code === 403){
                     window.location.href = baseUrl+"/login";
                 }  else {
-                    alert(res.msg);
+                    console.log(res.msg);
                 }
             }
         });
@@ -147,28 +298,17 @@
                         setVal(tr.children("td").eq(1), table[i-1].workNo);
                         setVal(tr.children("td").eq(2), table[i-1].autoing);
                         setVal(tr.children("td").eq(3), table[i-1].loading);
-                        setVal(tr.children("td").eq(4), table[i-1].canining);
-                        setVal(tr.children("td").eq(5), table[i-1].canouting);
-                        setVal(tr.children("td").eq(6), table[i-1].inreqIn);
-                        setVal(tr.children("td").eq(7), table[i-1].inreqOut);
-                        setVal(tr.children("td").eq(8), table[i-1].highLow);
-                        setVal(tr.children("td").eq(9), table[i-1].staNo);
-
-                        // tr.children("td").eq(0).html(table[i-1].devNo);
-                        // tr.children("td").eq(1).html(table[i-1].workNo);
-                        // tr.children("td").eq(2).html(table[i-1].autoing);
-                        // tr.children("td").eq(3).html(table[i-1].loading);
-                        // tr.children("td").eq(4).html(table[i-1].canining);
-                        // tr.children("td").eq(5).html(table[i-1].canouting);
-                        // tr.children("td").eq(6).html(table[i-1].inreqIn);
-                        // tr.children("td").eq(7).html(table[i-1].inreqOut);
-                        // tr.children("td").eq(8).html(table[i-1].highLow);
-                        // tr.children("td").eq(9).html(table[i-1].staNo);
+                        setVal(tr.children("td").eq(4), table[i-1].inEnable);
+                        setVal(tr.children("td").eq(5), table[i-1].outEnable);
+                        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";
                 }  else {
-                    alert(res.msg);
+                    console.log(res.msg);
                 }
             }
         });
@@ -255,5 +395,59 @@
         $('#site-table tbody').after(html);
     }
 
+    // 璇︽儏鎿嶄綔 -------------------------------------------------------------------------
+    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({
+                type: 1,
+                title: false,
+                shadeClose: true,
+                offset: 'rt',
+                anim: 5,
+                shade: [0],
+                area: ['340px', '255px'],
+                closeBtn: 0,
+                content: $("#site-detl"),
+                success: function(layero, index){
+                    http.get(baseUrl+ "/site/detl/"+siteId, null, function (res) {
+                        $('#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", {
+            siteId: $('#siteId').val(),
+            workNo: $('#workNo').val(),
+            staNo:  $('#staNo').val(),
+            pakMk: $('#pakMk').val()
+        }, function (res) {
+            layer.msg("淇敼鎴愬姛",{icon: 1,});
+        })
+    })
+    $(document).on('click ','#cancel', function () {
+        $('#siteId').val("");
+        $('#workNo').val("");
+        $('#staNo').val("");
+        $('#pakMk').val("");
+        layer.close(layerDetl);
+    })
+
 </script>
 </html>
\ No newline at end of file

--
Gitblit v1.9.1