From 03e68b2be24ea024eae645c47da1d4cb1773302a Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期五, 13 十月 2023 19:47:13 +0800
Subject: [PATCH] #

---
 src/main/webapp/views/ste.html |  933 ++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 807 insertions(+), 126 deletions(-)

diff --git a/src/main/webapp/views/ste.html b/src/main/webapp/views/ste.html
index eba9ade..153d040 100644
--- a/src/main/webapp/views/ste.html
+++ b/src/main/webapp/views/ste.html
@@ -21,66 +21,10 @@
             <!-- 鏃ュ織鐩戞帶鏉� -->
             <div class="log-board">
                 <div class="command-log">
-                    <h3>绌挎杞︿綅缃�</h3>
-                    <div class="ste-command-item">
+                    <div data-steNo="1" class="ste-command-item">
                         <label>1#</label>
-                        <div class="dropdown-menu">
-                            <button id="steBtn-1" class="demoBtn" onclick="changePosition(this.id)">淇敼浣嶇疆</button>
-                                <ul class="dropdown-menu-nav dark" >
-                                    <div class="dropdown-anchor"></div>
-                                    <div class="form-item"><span>褰撳墠绌挎鏈猴細</span><input type="text"></div>
-                                    <div class="form-item"><span>鎺掞細</span><input type="text"></div>
-                                    <div class="form-item"><span>鍒楋細</span><input type="text"></div>
-                                    <div class="form-item"><span>灞傦細</span><input type="text"></div>
-                                </ul>
-                        </div>
-                        <div class="dropdown-menu">
-                            <button class="demoBtn" onclick="">鎵�灞炲爢鍨涙満</button>
-                                <ul class="dropdown-menu-nav dark">
-                                    <div class="dropdown-anchor"></div>
-                                    <div class="form-item"><span>鍫嗗灈鏈哄彿锛�</span><input type="text"></div>
-                                </ul>
-                        </div>
-                    </div>
-                    <div class="ste-command-item" style="margin-top: 25px">
-                        <label>2#</label>
-                        <div class="dropdown-menu">
-                            <button id="steBtn-2" class="demoBtn" onclick="changePosition(this.id)">淇敼浣嶇疆</button>
-                            <ul class="dropdown-menu-nav dark" >
-                                <div class="dropdown-anchor"></div>
-                                <div class="form-item"><span>褰撳墠绌挎鏈猴細</span><input type="text"></div>
-                                <div class="form-item"><span>鎺掞細</span><input type="text"></div>
-                                <div class="form-item"><span>鍒楋細</span><input type="text"></div>
-                                <div class="form-item"><span>灞傦細</span><input type="text"></div>
-                            </ul>
-                        </div>
-                        <div class="dropdown-menu">
-                            <button class="demoBtn" onclick="">鎵�灞炲爢鍨涙満</button>
-                                <ul class="dropdown-menu-nav dark">
-                                    <div class="dropdown-anchor"></div>
-                                    <div class="form-item"><span>鍫嗗灈鏈哄彿锛�</span><input type="text"></div>
-                                </ul>
-                        </div>
-                    </div>
-                    <div class="ste-command-item" style="margin-top: 25px">
-                        <label>3#</label>
-                        <div class="dropdown-menu">
-                            <button id="steBtn-3" class="demoBtn" onclick="changePosition(this.id)">淇敼浣嶇疆</button>
-                            <ul class="dropdown-menu-nav dark" >
-                                <div class="dropdown-anchor"></div>
-                                <div class="form-item"><span>褰撳墠绌挎鏈猴細</span><input type="text"></div>
-                                <div class="form-item"><span>鎺掞細</span><input type="text"></div>
-                                <div class="form-item"><span>鍒楋細</span><input type="text"></div>
-                                <div class="form-item"><span>灞傦細</span><input type="text"></div>
-                            </ul>
-                        </div>
-                        <div class="dropdown-menu">
-                        <button class="demoBtn" onclick="">鎵�灞炲爢鍨涙満</button>
-                            <ul class="dropdown-menu-nav dark">
-                                <div class="dropdown-anchor"></div>
-                                <div class="form-item"><span>鍫嗗灈鏈哄彿锛�</span><input type="text"></div>
-                            </ul>
-                        </div>
+                        <button class="demoBtn pos-btn">鏁版嵁缁存姢</button>
+                        <button id="mode-1" class="demoBtn mode-btn" >璁惧淇℃伅</button>
                     </div>
                 </div>
                 <!-- 鍫嗗灈鏈虹姸鎬佷綅淇℃伅 -->
@@ -97,9 +41,9 @@
                                 <th>鎺�</th>
                                 <th>鍒�</th>
                                 <th>灞�</th>
-                                <th>璐у弶瀹氫綅</th>
-                                <th>杞借揣鍙板畾浣�</th>
-                                <th>璧拌鍦ㄥ畾浣�</th>
+                                <th>绛夊緟WCS纭</th>
+                                <th>瀹氫綅</th>
+                                <th>鍏呯數鐘舵��</th>
                                 <th>鎶ヨ淇℃伅1</th>
                                 <th>鎶ヨ淇℃伅2</th>
                             </tr>
@@ -109,26 +53,21 @@
                     </table>
                 </div>
             </div>
-            <!-- 鍫嗗灈鏈虹姸鎬� -->
+            <!-- 绌挎杞︾姸鎬� -->
             <div class="ste-msg">
                 <table id="ste-msg-table">
                     <thead>
                         <tr>
                             <th>绌挎杞�</th>
-                            <th>浠诲姟鍙�</th>
-                            <th>浠诲姟绫诲瀷</th>
-                            <th>褰撳墠浣嶇疆</th>
+                            <th>宸ヤ綔鍙�</th>
+                            <th>鐘舵��</th>
+                            <th>婧愮珯</th>
+                            <th>鐩爣绔�</th>
+                            <th>婧愬簱浣�</th>
+                            <th>鐩爣搴撲綅</th>
+                            <th>閫熷害</th>
                             <th>杩戠偣璺濈</th>
-                            <th>褰撳墠閫熷害</th>
-                            <th>楂樹綆浣�</th>
-                            <th>杩囪处鎸囦护浠诲姟鍙�</th>
-                            <th>杩囪处鎸囦护鐘舵��</th>
-                            <th>鐩樼偣鏁伴噺</th>
-                            <th>绌挎鏉垮氨缁�</th>
-                            <th>鍏呯數妗╁彿</th>
-                            <th>鍫嗗灈鏈鸿繍琛�</th>
-                            <th>鍫嗗灈鏈轰几鍙�</th>
-                            <th>鍫嗗灈鏈烘惉绉�</th>
+                            <th>浣滀笟鏍囪</th>
                         </tr>
                     </thead>
                     <tbody>
@@ -138,11 +77,11 @@
             <!-- 鎵嬪姩鎿嶄綔 -->
             <div class="ste-operation">
                 <!-- 閬僵灞� -->
-<!--                <div class="ste-operation-shade">-->
-<!--                    <span class="ste-operation-shade-span">-->
-<!--                        WCS 绯荤粺杩愯涓紝璇峰仠姝㈠悗鎿嶄綔-->
-<!--                    </span>-->
-<!--                </div>-->
+                <div class="ste-operation-shade">
+                    <span class="ste-operation-shade-span">
+                        WCS 绯荤粺杩愯涓紝璇峰仠姝㈠悗鎿嶄綔
+                    </span>
+                </div>
                 <!-- 璁惧浠诲姟閫夋嫨 -->
                 <div class="task-select">
                     <!-- 閫夋嫨 -->
@@ -150,8 +89,6 @@
                         <span class="select-title">绌挎杞﹀彿</span>
                         <div class="select-container">
                             <label><input type="radio" name="steSelect" value="1" checked>&nbsp;1鍙风┛姊溅</label>
-                            <label><input type="radio" name="steSelect" value="2">&nbsp;2鍙风┛姊溅</label>
-                            <label><input type="radio" name="steSelect" value="3">&nbsp;3鍙风┛姊溅</label>
                         </div>
                     </div>
                 </div>
@@ -160,69 +97,813 @@
                     <fieldset>
                         <legend>鎵嬪姩鎿嶄綔</legend>
                         <div class="button-group">
-                            <button class="item" onclick="leftTake()">宸﹀嚭搴�</button>
-                            <button class="item" onclick="rightTake()">鍙冲嚭搴�</button>
-                            <button class="item" onclick="leftPut()">宸﹀叆搴�</button>
-                            <button class="item" onclick="rightPut()">鍙冲叆搴�</button>
-                            <button class="item" onclick="leftStockMove()">宸︾Щ搴�</button>
-                            <button class="item" onclick="rightStockMove()">鍙崇Щ搴�</button>
-                            <button class="item" onclick="oOrigin()">鍘熺偣</button>
-                            <button class="item" onclick="farPoint()">杩滅偣</button>
-                            <button class="item" onclick="aPoint()">A 鐐�</button>
-                            <button class="item" onclick="bPoint()">B 鐐�</button>
-                            <button class="item" onclick="moveLift()">宸︽惉绉�</button>
-                            <button class="item" onclick="moveRight()">鍙虫惉绉�</button>
-                            <button class="item" onclick="charging()">鍏呯數</button>
-                            <button class="item" onclick="pause()">宸︾洏鐐�</button>
-                            <button class="item" onclick="boot()">鍙崇洏鐐�</button>
-                            <button class="item" onclick="boot()">浠诲姟瀹屾垚</button>
-                            <button class="item" onclick="clearCommand()">娓呴櫎鍛戒护</button>
-                            <button class="item" onclick="handleReset()">澶嶄綅</button>
+                            <button class="item" onclick="steOperator(99)">鑱旀満</button>
+                            <button class="item" onclick="steOperator(100)">鑴辨満</button>
+                            <button class="item" onclick="steOperator(1)">鍚戝彸鍑哄簱</button>
+                            <button class="item" onclick="steOperator(2)">鍚戝乏鍑哄簱</button>
+                            <button class="item" onclick="steOperator(3)">浠庡彸鍏ュ簱</button>
+                            <button class="item" onclick="steOperator(4)">浠庡乏鍏ュ簱</button>
+                            <button class="item" onclick="steOperator(5)">宸︾Щ搴�</button>
+                            <button class="item" onclick="steOperator(6)">鍙崇Щ搴�</button>
+                            <button class="item" onclick="steOperator(7)">鍘诲彸绔�</button>
+                            <button class="item" onclick="steOperator(8)">鍘诲乏绔�</button>
+                            <button class="item" onclick="steOperator(9)">鍙冲緟鏈�</button>
+                            <button class="item" onclick="steOperator(10)">宸﹀緟鏈�</button>
+<!--                            <button class="item" onclick="steOperator(11)">宸︽惉绉�</button>-->
+<!--                            <button class="item" onclick="steOperator(12)">鍙虫惉绉�</button>-->
+<!--                            <button class="item" onclick="steOperator(13)">宸﹀厖鐢�</button>-->
+<!--                            <button class="item" onclick="steOperator(14)">鍙冲厖鐢�</button>-->
+<!--                            <button class="item" onclick="steOperator(17)">鏂紑鍏呯數</button>-->
+<!--                            <button class="item" onclick="steOperator(14)">宸︾洏鐐�</button>-->
+<!--                            <button class="item" onclick="steOperator(15)">鍙崇洏鐐�</button>-->
+                            <button class="item" onclick="steOperator(16)">浠诲姟瀹屾垚</button>
+
                         </div>
                     </fieldset>
                 </div>
 
             </div>
-            <!-- 鍫嗗灈鏈烘棩蹇楄緭鍑� -->
+            <!-- 绌挎杞︽棩蹇楄緭鍑� -->
             <div class="ste-output-board">
                 <textarea id="ste-output"></textarea>
+            </div>
+        </div>
+    </div>
+
+    <div id="ste-detl" style="display: none">
+        <div>
+            <div class="form-item">
+                <label class="form-label">绌挎杞﹀彿:</label>
+                <div class="form-input">
+                    <input id="steNo" name="steNo" 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="row" name="row" 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="bay" name="bay" type="number" class="layui-input" autocomplete="off">
+                </div>
+            </div>
+            <div class="form-item">
+                <label class="form-label">灞�:</label>
+                <div class="form-input">
+                    <input id="lev" name="lev" type="number" class="layui-input" autocomplete="off">
+                </div>
+            </div>
+            <div class="form-item">
+                <label class="form-label">鍫嗗灈鏈�:</label>
+                <div class="form-input">
+                    <input id="crnNo" name="crnNo" type="number" class="layui-input" 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>
+        </div>
+    </div>
+    <div id="ste-detl2" style="display: none">
+        <div style="width: 1400px">
+            <div class="form-item" style="text-align: left">
+                <spen style="margin:  20px 10px 10px 10px; padding: 10px 10px 10px 10px;border: black;border-width: 3px;border-style:dotted;">
+                    寮傚父锛�<spen style="color: #FD482C;">鉁�</spen>
+                </spen>
+                <spen style="margin:  20px 10px 10px 10px; padding: 10px 10px 10px 10px;border: black;border-width: 3px;border-style: double;">
+                    姝e父锛�<spen style="color: #00FF00;">鈥�</spen>
+                </spen>
+            </div>
+            <div style="float:left;margin:  10px 10px 10px 10px; padding: 10px 10px 10px 10px;border: black;border-width: 3px;border-style:dotted;">
+                <div class="form-item" style="text-align: center">
+                    <label>绌挎杞﹀紓甯�</label>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">绌挎杞﹀彿:</label>
+                    <div class="form-input">
+                        <input id="steNo1" name="steNo" class="layui-input" lay-verify="required|number" autocomplete="off" disabled="disabled" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍗囬檷瓒呮椂鎶ヨ:</label>
+                    <div class="form-input">
+                        <input id="liftErr" name="liftErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍏ュ簱鍙栫┖鎶ヨ:</label>
+                    <div class="form-input">
+                        <input id="inFetchErr" name="inFetchErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍑哄簱鍙栫┖鎶ヨ:</label>
+                    <div class="form-input">
+                        <input id="outFetchErr" name="outFetchErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">闃叉挒淇濇姢:</label>
+                    <div class="form-input">
+                        <input id="antiErr" name="antiErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍗囬檷鎺ヨ繎寮�鍏虫晠闅�:</label>
+                    <div class="form-input">
+                        <input id="liftSwitchErr" name="liftSwitchErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">杞ㄩ亾妫�娴嬫姤璀�:</label>
+                    <div class="form-input">
+                        <input id="trackErr" name="trackErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">璁惧杩愯瓒呮椂鎶ヨ:</label>
+                    <div class="form-input">
+                        <input id="timeoutErr" name="timeoutErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">閫氫俊閿欒鎶ヨ:</label>
+                    <div class="form-input">
+                        <input id="connectErr" name="connectErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">璁惧鎬ュ仠:</label>
+                    <div class="form-input">
+                        <input id="emergencyErr" name="emergencyErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浠诲姟绫诲瀷缂哄け:</label>
+                    <div class="form-input">
+                        <input id="taskTypeErr" name="taskTypeErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浠诲姟鍙风己澶�:</label>
+                    <div class="form-input">
+                        <input id="taskNoErr" name="taskNoErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">杩愯涓湁鏂颁换鍔�:</label>
+                    <div class="form-input">
+                        <input id="newTaskErr" name="newTaskErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鏁呴殰涓湁浠诲姟:</label>
+                    <div class="form-input">
+                        <input id="errTaskErr" name="errTaskErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">杩愯涓仠姝�:</label>
+                    <div class="form-input">
+                        <input id="stopErr" name="stopErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鑴辨満妯″紡涓嬫湁浠诲姟:</label>
+                    <div class="form-input">
+                        <input id="offlineTaskErr" name="offlineTaskErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鏉′欢鏈弧瓒冲惎鍔ㄤ换鍔�:</label>
+                    <div class="form-input">
+                        <input id="startTaskErr" name="startTaskErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浣庣數鍘嬫椂鏈変换鍔�:</label>
+                    <div class="form-input">
+                        <input id="voltageTaskErr" name="voltageTaskErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">璁惧鏁呴殰鏍囧織浣�:</label>
+                    <div class="form-input">
+                        <input id="devpErr" name="devpErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+            </div>
+            <div style="float:left;margin:  10px 10px 10px 10px; padding: 10px 10px 10px 10px;border: black;border-width: 3px;border-style:dotted">
+                <div class="form-item" style="text-align: center">
+                    <label>绌挎杞︽彁绀轰俊鎭�</label>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鑱旀満鐘舵��:</label>
+                    <div class="form-input">
+                        <input id="online" name="online" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">涓嶅湪杞ㄩ亾涓�:</label>
+                    <div class="form-input">
+                        <input id="notOnTrack" name="notOnTrack" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浣庣數閲忔彁閱�:</label>
+                    <div class="form-input">
+                        <input id="lowVoltage" name="lowVoltage" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浜忕數涓�:</label>
+                    <div class="form-input">
+                        <input id="electricityLoss" name="electricityLoss" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">寮哄埗琛岃蛋鍚姩:</label>
+                    <div class="form-input">
+                        <input id="forcedTravel" name="forcedTravel" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">婕旂ず妯″紡寮�鍚�:</label>
+                    <div class="form-input">
+                        <input id="demoMode" name="demoMode" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍏呯數鍒峰凡鎺ラ��:</label>
+                    <div class="form-input">
+                        <input id="brushConnect" name="brushConnect" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浠诲姟涓姝㈡墜鍔�:</label>
+                    <div class="form-input">
+                        <input id="taskManualForbid" name="taskManualForbid" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鑱旀満涓姝㈡墜鍔�:</label>
+                    <div class="form-input">
+                        <input id="onlineManualForbid" name="onlineManualForbid" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">璁惧鎬ュ仠涓�:</label>
+                    <div class="form-input">
+                        <input id="devpEmergency" name="devpEmergency" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浠诲姟涓柇涓�:</label>
+                    <div class="form-input">
+                        <input id="taskInterrupt" name="taskInterrupt" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浠诲姟宸叉竻闄�:</label>
+                    <div class="form-input">
+                        <input id="taskClear" name="taskClear" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">浠诲姟纭宸茶秴鏃�:</label>
+                    <div class="form-input">
+                        <input id="taskConfirmTimeout" name="taskConfirmTimeout" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍏呯數涓湁浠诲姟:</label>
+                    <div class="form-input">
+                        <input id="taskWithCharge" name="taskWithCharge" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+            </div>
+            <div style="float:left;margin:  10px 10px 10px 10px; padding: 10px 10px 10px 10px;border: black;border-width: 3px;border-style:dotted">
+                <div class="form-item" style="text-align: center">
+                    <label>浠诲姟淇℃伅</label>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍏ュ簱浠诲姟涓�:</label>
+                    <div class="form-input">
+                        <input id="pakInTask" name="pakInTask" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍑哄簱浠诲姟涓�:</label>
+                    <div class="form-input">
+                        <input id="pakOutTask" name="pakOutTask" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">绉诲簱浠诲姟涓�:</label>
+                    <div class="form-input">
+                        <input id="pakMoveTask" name="pakMoveTask" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍥炲師鐐逛换鍔′腑:</label>
+                    <div class="form-input">
+                        <input id="goHpTask" name="goHpTask" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍘诲弽鍘熺偣浠诲姟涓�:</label>
+                    <div class="form-input">
+                        <input id="goOHpTask" name="goOHpTask" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍘诲師鐐归伩璁╀綅:</label>
+                    <div class="form-input">
+                        <input id="goHpAvoid" name="goHpAvoid" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍘诲弽鍘熺偣閬胯浣�:</label>
+                    <div class="form-input">
+                        <input id="goOHpAvoid" name="goOHpAvoid" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍏ュ簱鍙栫┖缁撴潫:</label>
+                    <div class="form-input">
+                        <input id="pakInEmpty" name="pakInEmpty" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍏ュ簱姝e父缁撴潫:</label>
+                    <div class="form-input">
+                        <input id="pakInFinish" name="pakInFinish" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍑哄簱鍙栫┖缁撴潫:</label>
+                    <div class="form-input">
+                        <input id="pakOutEmpty" name="pakOutEmpty" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍑哄簱姝e父缁撴潫:</label>
+                    <div class="form-input">
+                        <input id="pakOutFinish" name="pakOutFinish" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍘诲師鐐归伩璁╁畬鎴�:</label>
+                    <div class="form-input">
+                        <input id="goHpAvoidFinish" name="goHpAvoidFinish" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍘诲弽鍘熺偣閬胯瀹屾垚:</label>
+                    <div class="form-input">
+                        <input id="goOHpAvoidFinish" name="goOHpAvoidFinish" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍘诲師鐐归伩璁╁畬鎴�:</label>
+                    <div class="form-input">
+                        <input id="goHpAvoidErr" name="goHpAvoidErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鍘诲弽鍘熺偣閬胯瀹屾垚:</label>
+                    <div class="form-input">
+                        <input id="goOHpAvoidErr" name="goOHpAvoidErr" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+            </div>
+            <div style="float:left;margin:  10px 10px 10px 10px; padding: 10px 10px 10px 10px;border: black;border-width: 3px;border-style:dotted">
+                <div class="form-item" style="text-align: center">
+                    <label>鐘舵�佷俊鎭�</label>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鑱旀満妯″紡:</label>
+                    <div class="form-input">
+                        <input id="autoMode" name="autoMode" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
+                <div class="form-item">
+                    <label class="form-label">鐢靛帇杩囦綆:</label>
+                    <div class="form-input">
+                        <input id="voltageLow" name="voltageLow" class="layui-input" autocomplete="off" readonly>
+                    </div>
+                </div>
             </div>
         </div>
     </div>
 </body>
 </html>
 <script>
-    layui.config({
-        base: baseUrl + "/static/layui/lay/modules/"
-    }).extend({
-        dropdown: 'dropdown/dropdown',
-    }).use(['dropdown'],function () {
-        var dropdown = layui.dropdown;
-    })
-</script>
-<script>
-    // 淇敼绌挎杞︿綅缃�
-    function changePosition(id) {
-        console.log(id)
-        // $.ajax({
-        //     url: baseUrl +
-        // })
+    // 绌虹櫧琛屾暟
+    var steStateTableBlankRows = 0;
+    var steMsgTableBlankRows = 0;
+    // 瀹為檯琛屾暟
+    var steStateTableFullRows = 0;
+    var steMsgTableFullRows = 0;
+    // 鍒濆鍖�
+    var steOutputDom = document.getElementById("ste-output");
+    $(document).ready(function() {
+        initSteStateTable();
+        getSteStateInfo();
+        initSteMsgTable();
+        getSteMsgInfo();
+        operatorBlockShow();
+    });
+
+    setInterval(function () {
+        getSteStateInfo()
+        getSteMsgInfo();
+    },1000)
+    setInterval(function () {
+        getSteOutput();
+        operatorBlockShow();
+    },500);
+
+    // 鍒ゆ柇鎵嬪姩鎿嶄綔妯″潡鏄惁鍙敤
+    function operatorBlockShow() {
+        if (parent.systemRunning) {
+            $('.ste-operation').css("opacity", "0.5");
+            $('.ste-operation-shade').show();
+            $('.ste-operation-shade-span').show();
+        }  else {
+            $('.ste-operation').css("opacity", "1");
+            $('.ste-operation-shade').hide();
+            $('.ste-operation-shade-span').hide();
+        }
     }
+
+    var layerIdx;
+    $(document).on('click ','.pos-btn', function () {
+        let steNo = Number($(this).parent().attr("data-steNo"));
+        layerIdx = layer.open({
+            type: 1,
+            title: false,
+            shadeClose: true,
+            offset: [$(this).offset().top + 30 + 'px', $(this).offset().left + 'px'],
+            anim: 5,
+            shade: [0],
+            area: ['310px', '370px'],
+            closeBtn: 0,
+            content: $("#ste-detl"),
+            success: function(layero, index){
+                http.get(baseUrl+ "/ste/detl/"+steNo, null, function (res) {
+                    $('#steNo').val(steNo);
+                    $('#workNo').val(res.data.workNo);
+                    $('#row').val(res.data.row);
+                    $('#bay').val(res.data.bay);
+                    $('#lev').val(res.data.lev);
+                    $('#crnNo').val(res.data.crnNo);
+                    $('#pakMk').val(res.data.pakMk);
+                })
+            },
+            end: function () {
+                $('#steNo').val("");
+                $('#workNo').val("");
+                $('#row').val("");
+                $('#bay').val("");
+                $('#lev').val("");
+                $('#crnNo').val("");
+                $('#pakMk').val("");
+            }
+        })
+    })
+
+    var layerIdx0;
+    $(document).on('click ','.mode-btn', function () {
+        let steNo = Number($(this).parent().attr("data-steNo"));
+        layerIdx0 = layer.open({
+            type: 1,
+            title: false,
+            shadeClose: true,
+            offset: [$(this).offset().top + 30 + 'px', $(this).offset().left + 'px'],
+            anim: 5,
+            shade: [0],
+            area: ['70%', '85%'],
+            closeBtn: 0,
+            content: $("#ste-detl2"),
+            success: function(layero, index){
+                http.get(baseUrl+ "/ste/sensor/detl/"+steNo, null, function (res) {
+                    $('#steNo1').val(res.data.steNo);
+                    getColor(res.data.liftErr,'#liftErr');
+                    getColor(res.data.inFetchErr,'#inFetchErr');
+                    getColor(res.data.outFetchErr,'#outFetchErr');
+                    getColor(res.data.antiErr,'#antiErr');
+                    getColor(res.data.liftSwitchErr,'#liftSwitchErr');
+                    getColor(res.data.trackErr,'#trackErr');
+                    getColor(res.data.timeoutErr,'#timeoutErr');
+                    getColor(res.data.connectErr,'#connectErr');
+                    getColor(res.data.emergencyErr,'#emergencyErr');
+                    getColor(res.data.taskTypeErr,'#taskTypeErr');
+                    getColor(res.data.taskNoErr,'#taskNoErr');
+                    getColor(res.data.newTaskErr,'#newTaskErr');
+                    getColor(res.data.errTaskErr,'#errTaskErr');
+                    getColor(res.data.stopErr,'#stopErr');
+                    getColor(res.data.offlineTaskErr,'#offlineTaskErr');
+                    getColor(res.data.startTaskErr,'#startTaskErr');
+                    getColor(res.data.voltageTaskErr,'#voltageTaskErr');
+                    getColor(res.data.devpErr,'#devpErr');
+                    getColor(res.data.online,'#online');
+                    getColor(res.data.notOnTrack,'#notOnTrack');
+                    getColor(res.data.lowVoltage,'#lowVoltage');
+                    getColor(res.data.electricityLoss,'#electricityLoss');
+                    getColor(res.data.forcedTravel,'#forcedTravel');
+                    getColor(res.data.demoMode,'#demoMode');
+                    getColor(res.data.brushConnect,'#brushConnect');
+                    getColor(res.data.taskManualForbid,'#taskManualForbid');
+                    getColor(res.data.onlineManualForbid,'#onlineManualForbid');
+                    getColor(res.data.devpEmergency,'#devpEmergency');
+                    getColor(res.data.taskInterrupt,'#taskInterrupt');
+                    getColor(res.data.taskClear,'#taskClear');
+                    getColor(res.data.taskConfirmTimeout,'#taskConfirmTimeout');
+                    getColor(res.data.taskWithCharge,'#taskWithCharge');
+                    getColor(res.data.pakInTask,'#pakInTask');
+                    getColor(res.data.pakOutTask,'#pakOutTask');
+                    getColor(res.data.pakMoveTask,'#pakMoveTask');
+                    getColor(res.data.goHpTask,'#goHpTask');
+                    getColor(res.data.goOHpTask,'#goOHpTask');
+                    getColor(res.data.goHpAvoid,'#goHpAvoid');
+                    getColor(res.data.goOHpAvoid,'#goOHpAvoid');
+                    getColor(res.data.pakInEmpty,'#pakInEmpty');
+                    getColor(res.data.pakInFinish,'#pakInFinish');
+                    getColor(res.data.pakOutEmpty,'#pakOutEmpty');
+                    getColor(res.data.pakOutFinish,'#pakOutFinish');
+                    getColor(res.data.goHpAvoidFinish,'#goHpAvoidFinish');
+                    getColor(res.data.goOHpAvoidFinish,'#goOHpAvoidFinish');
+                    getColor(res.data.goHpAvoidErr,'#goHpAvoidErr');
+                    getColor(res.data.goOHpAvoidErr,'#goOHpAvoidErr');
+                    getColor(res.data.autoMode,'#autoMode');
+                    getColor(res.data.voltageLow,'#voltageLow');
+                })
+            },
+            end: function () {
+                $('#steNo').val("");
+            }
+        })
+    })
+
+    function getColor(res,e){
+        $(e).val(res?"鉁�":"鈥�");
+        if (res){
+            $(e).attr("style", "color: #FD482C;");
+        }else {
+            $(e).attr("style", "color: #00FF00;");
+        }
+    }
+
+    // $(document).on('click ','.mode-btn', function () {
+    //     let steNo = Number($(this).parent().attr("data-steNo"));
+    //     layer.confirm("鏀瑰彉" + steNo + ' 鍙风┛姊溅鍦ㄧ嚎鐘舵�佸悧锛�', function(){
+    //         var index = layer.load(1, {
+    //             shade: [0.1,'#fff']
+    //         });
+    //         $.ajax({
+    //             url: baseUrl+ "/ste/mode/switch",
+    //             headers: {'token': localStorage.getItem('token')},
+    //             data: {
+    //                 steNo: Number(steNo),
+    //                 password: 'root'
+    //             },
+    //             method: 'POST',
+    //             success: function (res) {
+    //                 layer.close(index);
+    //                 if (res.code === 200){
+    //                     layer.msg(res.msg, {icon: 1});
+    //                 } else if (res.code === 403){
+    //                     window.location.href = baseUrl+"/login";
+    //                 }  else {
+    //                     layer.msg(res.msg, {icon: 2});
+    //                 }
+    //             }
+    //         });
+    //     });
+    // })
+
+
+
+    $(document).on('click ','#save', function () {
+        http.post(baseUrl+ "/ste/detl/update", {
+            steNo: $('#steNo').val(),
+            workNo: $('#workNo').val(),
+            row:  $('#row').val(),
+            bay: $('#bay').val(),
+            lev:  $('#lev').val(),
+            crnNo: $('#crnNo').val(),
+            pakMk: $('#pakMk').val(),
+        }, function (res) {
+            layer.msg("淇敼鎴愬姛", {icon: 1,});
+            layer.close(layerIdx);
+        })
+    })
+
+    $(document).on('click ','#cancel', function () {
+        layer.close(layerIdx);
+    })
+
     // 绌挎杞︿俊鎭〃鑾峰彇 ---- 琛ㄤ竴
-
     function getSteStateInfo() {
-        var tableEl = $('ste-state-table');
+        let tableEl = $('#ste-state-table');
         $.ajax({
-            url: baseUrl + "/crn/table/crn/state",
+            url: baseUrl+ "/ste/table/ste/state",
             headers: {'token': localStorage.getItem('token')},
-            method: 'GET',
+            method: 'POST',
             success: function (res) {
-                console.log(res)
+                if (res.code === 200){
+                    let table = res.data;
+                    if (table.length > steStateTableBlankRows && table.length !== steStateTableFullRows) {
+                        initSteStateTable(table.length-steStateTableBlankRows);
+                        steStateTableFullRows = table.length;
+                    }
+                    for (let i=1;i<=table.length;i++){
+                        // $("#mode-"+table[i-1].steNo).html(table[i-1].statusVal===0?'鑱旀満':'鑴辨満');
+                        let tr = tableEl.find("tr").eq(i);
+                        setVal(tr.children("td").eq(0), table[i-1].steNo);
+                        setVal(tr.children("td").eq(1), table[i-1].statusType);
+                        setVal(tr.children("td").eq(2), table[i-1].status);
+                        setVal(tr.children("td").eq(3), table[i-1].loading);
+                        setVal(tr.children("td").eq(4), table[i-1].track);
+                        setVal(tr.children("td").eq(5), table[i-1].charge);
+                        setVal(tr.children("td").eq(6), table[i-1].row);
+                        setVal(tr.children("td").eq(7), table[i-1].bay);
+                        setVal(tr.children("td").eq(8), table[i-1].lev);
+                        setVal(tr.children("td").eq(9), table[i-1].waiting);
+                        setVal(tr.children("td").eq(10), table[i-1].loca);
+                        setVal(tr.children("td").eq(11), table[i-1].chargeStatus);
+                        setVal(tr.children("td").eq(12), table[i-1].alarm1);
+                        setVal(tr.children("td").eq(13), table[i-1].alarm2);
+                    }
+                } else if (res.code === 403){
+                    window.location.href = baseUrl+"/login";
+                }  else {
+                    console.log(res.msg);
+                }
+            }
+        });
+    }
 
+    // 绌挎杞︽暟鎹〃鑾峰彇 ---- 琛ㄤ簩
+    function getSteMsgInfo() {
+        let tableEl = $('#ste-msg-table');
+        $.ajax({
+            url: baseUrl+ "/ste/table/ste/msg",
+            headers: {'token': localStorage.getItem('token')},
+            method: 'POST',
+            success: function (res) {
+                if (res.code === 200){
+                    var table = res.data;
+                    if (table.length > steMsgTableBlankRows && table.length !== steMsgTableFullRows) {
+                        initSteMsgTable(table.length-steMsgTableBlankRows);
+                        steMsgTableFullRows = table.length;
+                    }
+                    for (var i=1;i<=table.length;i++){
+                        var tr = tableEl.find("tr").eq(i);
+                        setVal(tr.children("td").eq(0), table[i-1].steNo);
+                        setVal(tr.children("td").eq(1), table[i-1].workNo);
+                        setVal(tr.children("td").eq(2), table[i-1].status);
+                        setVal(tr.children("td").eq(3), table[i-1].sourceStaNo);
+                        setVal(tr.children("td").eq(4), table[i-1].staNo);
+                        setVal(tr.children("td").eq(5), table[i-1].sourceLocNo);
+                        setVal(tr.children("td").eq(6), table[i-1].locNo);
+                        setVal(tr.children("td").eq(7), table[i-1].speed);
+                        setVal(tr.children("td").eq(8), table[i-1].closer);
+                        setVal(tr.children("td").eq(9), table[i-1].pakMk);
+                    }
+                } else if (res.code === 403){
+                    window.location.href = baseUrl+"/login";
+                }  else {
+                    console.log(res.msg);
+                }
+            }
+        });
+    }
+
+    // 绌挎杞︽棩蹇楄緭鍑� -----------------------------------------------------------------------
+    function getSteOutput() {
+        $.ajax({
+            url: baseUrl + "/ste/output/ste",
+            headers: {'token': localStorage.getItem('token')},
+            method: 'POST',
+            success: function (res) {
+                if (res.code === 200) {
+                    steOutput(res.data);
+                } else if (res.code === 403) {
+                    window.location.href = baseUrl + "/login";
+                } else {
+                    console.log(res.msg);
+                }
             }
         })
     }
-    setInterval(function () {
-        getSteStateInfo()
-    },1000)
-</script>
\ No newline at end of file
+
+    // 浠诲姟鎸囦护涓嬪彂
+    function steOperator(steTaskMode) {
+        http.post(baseUrl+"/ste/operator/ste", {
+            steNo: $('input[name="steSelect"]:checked').val(),
+            steTaskMode: steTaskMode
+        }, function (res) {
+            layer.msg(res.msg, {icon: 1});
+        });
+    }
+
+
+    // ------------------------------------------------------------------------------------------------
+
+    // 绌挎杞︿俊鎭〃鑾峰彇  ----- 琛ㄤ竴
+    function initSteStateTable(row) {
+        let line;
+        if (row === undefined){
+            let one = $('#ste-state-table thead').height();
+            let total = $('.ste-state').height();
+            let count = total / one;
+            count = parseInt(count) - 1;
+            steStateTableBlankRows = count;
+            line = count;
+        } else {
+            line = row;
+        }
+        let html = "";
+        for (let i = 0; i < line; i ++){
+            html += " <tr>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "     </tr>\n";
+        }
+        $('#ste-state-table tbody').after(html);
+    }
+
+    // 绌挎杞︽暟鎹〃鑾峰彇  ----- 琛ㄤ簩
+    function initSteMsgTable(row) {
+        let line;
+        if (row === undefined){
+            let one = $('#ste-msg-table thead').height();
+            let total = $('.ste-msg').height();
+            let count = total / one;
+            count = parseInt(count) - 1;
+            steMsgTableBlankRows = count;
+            line = count;
+        } else {
+            line = row;
+        }
+        let html = "";
+        for (let i = 0; i < line; i ++){
+            html += " <tr>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "       <td></td>\n" +
+                "     </tr>\n";
+        }
+        $('#ste-msg-table tbody').after(html);
+    }
+
+    // 鏃ュ織杈撳嚭妗�
+    function steOutput(content){
+        steOutputDom.value += content;
+        steOutputDom.scrollTop = steOutputDom.scrollHeight;
+    }
+
+</script>

--
Gitblit v1.9.1