From c2b0be1a368a88e4adb6dda12d0aa5d3bb0df838 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期二, 27 六月 2023 16:50:50 +0800
Subject: [PATCH] 搜索最近穿梭车,提升机完成方法

---
 src/main/webapp/views/console.html |  762 ++++++++++++++++++++++++++++++----------------------------
 1 files changed, 395 insertions(+), 367 deletions(-)

diff --git a/src/main/webapp/views/console.html b/src/main/webapp/views/console.html
index cf0e3b8..8f36d8b 100644
--- a/src/main/webapp/views/console.html
+++ b/src/main/webapp/views/console.html
@@ -5,6 +5,7 @@
     <title>WCS鎺у埗涓績</title>
     <link rel="stylesheet" href="../static/css/console.css">
     <link rel="stylesheet" href="../static/css/animate.min.css">
+    <link rel="stylesheet" href="../static/css/toggle-switch.css">
     <script src="../static/js/jquery/jquery-3.3.1.min.js"></script>
     <script src="../static/js/layer/layer.js"></script>
     <script type="text/javascript" src="../static/js/common.js"></script>
@@ -16,227 +17,21 @@
         <h6>AUTOMATIC WAREHOUSE WCS MONITORING DIAGRAM</h6>
     </header>
     <main class="main">
-        <!--绗�1鍒� -->
-        <div class="site-row site-row-1" id="fool1">
-            <div id="site-100" class="site" style="height: 38px;line-height: 38px;width:156px;">100</div>
-
-            <div id="site-101" class="site" style="height: 38px;line-height: 38px;width:156px;">101</div>
-
-            <div id="site-102" class="site" style="height: 38px;line-height: 38px;width:156px;">102</div>
-        </div>
-        <!--绗�2鍒�-->
-        <div class="site-row site-row-2" id="fool2" style="display: none">
-            <div id="site-200" class="site" style="height: 38px;line-height: 38px;width:156px;">200</div>
-
-            <div id="site-201" class="site" style="height: 38px;line-height: 38px;width:156px;">201</div>
-
-            <div id="site-202" class="site" style="height: 38px;line-height: 38px;width:156px;">202</div>
-        </div>
-
-        <!--绗�3鍒�-->
-        <div class="site-row site-row-3" id="fool3" style="display: none">
-            <div id="site-300" class="site" style="height: 38px;line-height: 38px;width:156px;">300</div>
-
-            <div id="site-301" class="site" style="height: 38px;line-height: 38px;width:156px;">301</div>
-
-            <div id="site-302" class="site" style="height: 38px;line-height: 38px;width:156px;">302</div>
-        </div>
-
         <!--妤煎眰鎸夐挳-->
-
-            <button class="floorBtn  btn-16" onclick="changFloor(1)" style="margin-top: 150px">1F</button>
-            <button class="floorBtn  btn-16" onclick="changFloor(2)" style="margin-top: 200px">2F</button>
-            <button class="floorBtn  btn-16" onclick="changFloor(3)" style="margin-top: 250px">3F</button>
+            <div id="floorBtnBox">
+                <button class="floorBtn  btn-16" onclick="changFloor(this,1)" style="margin-top: 150px">1F</button>
+                <button class="floorBtn  btn-16" onclick="changFloor(this,2)" style="margin-top: 200px">2F</button>
+                <button class="floorBtn  btn-16" onclick="changFloor(this,3)" style="margin-top: 250px">3F</button>
+                <button class="floorBtn  btn-16" onclick="changFloor(this,4)" style="margin-top: 300px">4F</button>
+            </div>
+            <button class="floorBtn  btn-16" onclick="testMove()" style="margin-top: 350px;font-size: 14px;">娴嬭瘯绉诲姩杞�</button>
+            <button class="floorBtn  btn-16" onclick="resetMap()" style="margin-top: 400px;font-size: 14px;">閲嶇疆鍦板浘</button>
 
         <!-- 璐ф灦 + 鍫嗗灈鏈� + 鍏ュ簱绔欑偣 -->
         <div class="main-part">
             <!-- 绗竴缁� -->
-            <div class="lane" style="margin-bottom: 280px">
-                <!-- 璐ф灦 -->
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">1#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">2#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">3#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item" style="border: none;background-color: #6ca7a8"></button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">4#</span>
-                </div>
+            <div class="lane" id="mapDataId" style="margin-bottom: 280px">
 
-                <!-- 鍫嗗灈鏈� -->
-                <div class="crn">
-                    <hr class="pathway">
-                    <div id="crn-1" class="machine"></div>
-                </div>
-
-                <!-- 璐ф灦 -->
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item">5</button>
-                    <button class="item">6</button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">5#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item">5</button>
-                    <button class="item">6</button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">6#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item">5</button>
-                    <button class="item">6</button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">7#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item">5</button>
-                    <button class="item">6</button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">8#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item">5</button>
-                    <button class="item">6</button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">9#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item">5</button>
-                    <button class="item">6</button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">10#</span>
-                </div>
-                <div class="stock-group">
-                    <button class="item">1</button>
-                    <button class="item">2</button>
-                    <button class="item">3</button>
-                    <button class="item">4</button>
-                    <button class="item">5</button>
-                    <button class="item">6</button>
-                    <button class="item">7</button>
-                    <button class="item">8</button>
-                    <button class="item">9</button>
-                    <button class="item">10</button>
-                    <button class="item">11</button>
-                    <button class="item">12</button>
-                    <button class="item">13</button>
-                    <span class="row-no">11#</span>
-                </div>
             </div>
         </div>
     </main>
@@ -245,35 +40,51 @@
         <div class="system-state">
             <div class="body-head">鎬诲紑鍏�</div>
             <div class="switch">
-                <div id="system-icon" class="system-icon-open" onclick="systemSwitch()"></div>
+                <label id="system-toggle" class="toggle-switch" style="margin-left: 20px;">
+                    <input id="system-toggle-checked" checked="checked" type="checkbox">
+                    <div class="button">
+                        <div class="light"></div>
+                        <div class="dots"></div>
+                        <div class="characters"></div>
+                        <div class="shine"></div>
+                        <div class="shadow"></div>
+                    </div>
+                </label>
+
                 <div class="switch_r">
                     <p>绯荤粺鐘舵��</p>
                     <p id="system-run-desc">绯荤粺杩愯涓�</p>
                 </div>
             </div>
         </div>
-        <!-- 鍫嗗灈鏈虹姸鎬� -->
-        <div class="machine-status">
-            <div class="body-head">鍫嗗灈鏈虹姸鎬�</div>
-            <div class="state">
-                <span>鍫嗗灈鏈� 1</span>
-                <span class="state-ss machine-put-flag	">鍏ュ簱</span>
+        <!-- 鍥涘悜绌挎杞︾姸鎬� -->
+        <div class="line-status">
+            <div class="body-head">绌挎杞︾姸鎬�</div>
+            <div id="shuttle-status-box">
             </div>
-<!--            <div class="state">-->
-<!--                <span>鍫嗗灈鏈� 2</span>-->
-<!--                <span class="state-ss machine-auto-flag	">鑷姩</span>-->
-
-<!--            </div>-->
             <div class="button"><span>鎵�鏈夌姸鎬�</span></div>
             <div class="button item-group">
-                <span class="machine-put-flag">鍏ュ簱</span>
-                <span class="machine-take-flag">鍑哄簱</span>
-                <span class="machine-stock-move-flag">搴撳埌搴�</span>
-                <span class="machine-site-move-flag">绔欏埌绔�</span>
-                <span class="machine-p-move-flag">PToP</span>
-                <span class="machine-error-flag">寮傚父</span>
-                <span class="machine-auto-flag">鑷姩</span>
-                <span class="machine-unauto-flag">闈炶嚜鍔�/鎵嬪姩</span>
+                <span class="shuttle-idle">绌洪棽</span>
+                <span class="shuttle-working">浣滀笟涓�</span>
+                <span class="shuttle-waiting">绛夊緟纭</span>
+                <span class="shuttle-charging">鍏呯數涓�</span>
+                <span class="shuttle-charging-waiting">鍏呯數浠诲姟绛夊緟纭</span>
+                <span class="shuttle-fixing">鏁呴殰淇涓�</span>
+                <span class="shuttle-offline">绂荤嚎</span>
+            </div>
+        </div>
+        <!-- 鎻愬崌鏈虹姸鎬� -->
+        <div class="line-status">
+            <div class="body-head">鎻愬崌鏈虹姸鎬�</div>
+            <div id="lift-status-box">
+
+            </div>
+            <div class="button"><span>鎵�鏈夌姸鎬�</span></div>
+            <div class="button item-group">
+                <span class="lift-idle">绌洪棽</span>
+                <span class="lift-working">浣滀笟涓�</span>
+                <span class="lift-waiting">绛夊緟纭</span>
+                <span class="lift-offline">绂荤嚎</span>
             </div>
         </div>
         <!-- 杈撻�佺嚎鐘舵�� -->
@@ -308,14 +119,6 @@
                     <li><span>鏉$爜鍚嶇О</span><span class="right">鎵爜鏃堕棿</span></li>
                 </div>
                 <div id="barcode2" class="table-body">
-
-                </div>
-            </div>
-            <div class="tablebox">
-                <div class="table-head">
-                    <li><span>鏉$爜鍚嶇О</span><span class="right">鎵爜鏃堕棿</span></li>
-                </div>
-                <div id="barcode3" class="table-body">
 
                 </div>
             </div>
@@ -549,6 +352,8 @@
     var tData1 = []
     var tData2 = []
     var tData3 = []
+    var mapData = [] //鍦板浘鏁版嵁
+    var currentLev = 1;//褰撳墠鍦板浘妤煎眰
     function getCodeData(){
         $.ajax({
             url:baseUrl +'/console/barcode/output/site',
@@ -600,6 +405,335 @@
             var str3 = '<li><span>' + tData3[k].barcode + '</span><span class="right">' + tData3[k].time + '</span></li>'
             $('#barcode3').append(str3)
         }
+    }
+
+
+    $(function (){
+        initMap(1)
+    })
+
+    setInterval(() => {
+        getShuttleStateInfo()
+        getLiftStateInfo()
+    },1000)
+
+    // 鎻愬崌鏈轰俊鎭〃鑾峰彇
+    function getLiftStateInfo() {
+        $.ajax({
+            url: baseUrl+ "/lift/table/lift/state",
+            headers: {'token': localStorage.getItem('token')},
+            method: 'POST',
+            success: function (res) {
+                $("#lift-status-box").empty()
+                res.data.forEach((item,index) => {
+                    let liftStatusClass = "lift-idle"
+                    switch (item.status) {
+                        case 1://绌洪棽
+                            liftStatusClass = "lift-idle";
+                            break
+                        case 2://浣滀笟涓�
+                            liftStatusClass = "lift-working";
+                            break
+                        case 3://绛夊緟纭
+                            liftStatusClass = "lift-waiting";
+                            break
+                        case 4://绂荤嚎
+                            liftStatusClass = "lift-offline";
+                            break
+                        default:
+                            liftStatusClass = "lift-idle"
+                    }
+                    let liftStatus = '<div class="state states">' +
+                        '<span>鎻愬崌鏈� ' + item.liftNo + '</span>' +
+                        '<span class="state-ss ' + liftStatusClass + '">' + item.protocolStatus$ + '</span></div>';
+                    $("#lift-status-box").append(liftStatus)
+
+                })
+            }
+        });
+    }
+
+    // 鍥涘悜绌挎杞︿俊鎭〃鑾峰彇
+    function getShuttleStateInfo() {
+        $.ajax({
+            url: baseUrl+ "/shuttle/table/shuttle/state",
+            headers: {'token': localStorage.getItem('token')},
+            method: 'POST',
+            success: function (res) {
+                $("#shuttle-status-box").empty()
+                res.data.forEach((item,index) => {
+                    let shuttleStatusClass = "shuttle-idle"
+                    switch (item.status) {
+                        case 1://绌洪棽
+                            shuttleStatusClass = "shuttle-idle";
+                            break
+                        case 2://浣滀笟涓�
+                            shuttleStatusClass = "shuttle-working";
+                            break
+                        case 3://绛夊緟纭
+                            shuttleStatusClass = "shuttle-waiting";
+                            break
+                        case 4://鍏呯數涓�
+                            shuttleStatusClass = "shuttle-charging";
+                            break
+                        case 5://鍏呯數浠诲姟绛夊緟纭
+                            shuttleStatusClass = "shuttle-charging-waiting";
+                            break
+                        case 6://鏁呴殰淇涓�
+                            shuttleStatusClass = "shuttle-fixing";
+                            break
+                        case 7://绂荤嚎
+                            shuttleStatusClass = "shuttle-offline";
+                            break
+                        default:
+                            shuttleStatusClass = "shuttle-offline"
+                    }
+                    let shuttleStatus = '<div class="state">' +
+                        '<span>鍥涘悜绌挎杞� ' + item.shuttleNo + '</span>' +
+                        '<span class="state-ss ' + shuttleStatusClass + '">' + item.status$ + '</span></div>';
+                    $("#shuttle-status-box").append(shuttleStatus)
+
+                    if(item.locNoLev != currentLev){
+                        //鍥涘悜绌挎杞︽ゼ灞傚拰褰撳墠鍦板浘妤煎眰涓嶄竴鑷达紝鍒犻櫎璇ヨ溅杈�
+                        $("#sxcar-" + item.shuttleNo).remove()
+                    }else {
+                        //绉诲姩鍥涘悜绌挎杞�
+                        moveCar(item.shuttleNo,item.locNoX,item.locNoY)
+                    }
+                })
+            }
+        });
+    }
+
+    //璁$畻鍥涘悜绌挎杞﹀浘鏍囦綅缃�
+    function getCarPosition(x,y) {
+        let top = (x * 35 - 35) + "px" //闇�瑕佸噺鍘诲皬杞﹁嚜宸辨墍鍗犻珮搴�
+        let left = (y * 70 - 70) + "px" //闇�瑕佸噺鍘诲皬杞﹁嚜宸辨墍鍗犲搴�
+        return [top,left];
+    }
+
+    //绉诲姩鍥涘悜绌挎杞﹀浘鏍�
+    function moveCar(id,x,y) {
+        //鑾峰彇鍏蜂綋浣嶇疆top鍜宭eft鍊�
+        let position = getCarPosition(x,y)
+        let top = position[0]
+        let left = position[1]
+        $("#sxcar-" + id).animate({top: top,left: left}, 1000);
+    }
+
+    //鍒濆鍖栧湴鍥�
+    function initMap(lev) {
+        getMap(lev)
+
+        $.ajax({
+            url: baseUrl+ "/shuttle/table/shuttle/state",
+            headers: {'token': localStorage.getItem('token')},
+            method: 'POST',
+            success: function (res) {
+                res.data.forEach((item,index) => {
+                    if(lev == item.locNoLev){
+                        let carBox = '<div class="sxcar" id="sxcar-' + item.shuttleNo + '"></div>'
+                        $("#mapDataId").append(carBox)
+                    }
+                })
+            }
+        });
+    }
+
+    //鑾峰彇鍦板浘鏁版嵁
+    function getMap(lev) {
+        //姣嶈建閬撶涓�娆$储寮曪紝鐢ㄤ簬瀹氫綅灏忚溅
+        let firstMotherIndex = [0,0];
+        $("#mapDataId").empty()
+        $.ajax({
+            type:"get",
+            // url: baseUrl + "/static/js/map_" + lev + ".json",
+            url: baseUrl + "/console/map/" + lev + "/auth",
+            headers: {'token': localStorage.getItem('token')},
+            success: (res) => {
+                let data = res.data
+                mapData = data
+                let content = ""
+                data.forEach((rowData,index) => {
+                    //鍘绘帀涓婁笅杈圭紭绂佸尯
+                    if(!(index == 0 || data.length - 1 == index)){
+                        let row = '<div class="stock-group">';
+                        rowData.forEach((colData,idx) => {
+                            //鍘绘帀宸﹀彸杈圭紭绂佸尯
+                            if(!(idx == 0 || rowData.length - 1 == idx)){
+                                let col;
+                                switch (colData.value){
+                                    case -999:
+                                        col = '<button class="item" style="background:#f83333;color: #fff;">' + idx + '</button>';
+                                        break;
+                                    case -1:
+                                        col = '<button class="item" style="visibility: hidden">' + idx + '</button>';
+                                        break;
+                                    case 3:
+                                        //姣嶈建閬�
+                                        col = '<button class="item" style="background: #5af;">&#x21c5;&#x21c4;</button>';
+                                        if (firstMotherIndex[0] === 0 && firstMotherIndex[1] === 0) {
+                                            //绗竴娆¢亣鍒版瘝杞ㄩ亾锛屽垯淇濆瓨璇ヨ建閬撳湴鍧�(鐢ㄤ簬灏忚溅鍒濆鍖栧畾浣�)
+                                            firstMotherIndex = [index,idx]
+                                        }
+                                        break;
+                                    case 4:
+                                        //绔欑偣
+                                        var data = colData.data;
+                                        col = '<div id="site-' + data + '" class="site">' + data + '(9991)</div>';
+                                        break;
+                                    case 5:
+                                        //鍏呯數妗�
+                                        col = '<button class="item" style="font-size: 24px">&#9889;</button>';
+                                        break;
+                                    default:
+                                        col = '<button class="item">' + idx + '</button>';
+                                }
+
+                                if(rowData.length - 2 == idx){
+                                    //鎵撲笂琛屾暟鏍囪
+                                    col += '<span class="row-no">' + index + '#</span>';
+                                }
+                                row += col
+                            }
+                        })
+                        row += '</div>';
+                        content += row
+                    }
+                })
+
+                $("#mapDataId").append(content)
+            }
+        })
+    }
+
+    //灏嗗湴鍥炬暟鎹浆鎹㈡垚int浜岀淮鏁扮粍(鍚庣画鐢ㄤ簬璇锋眰璁$畻璺緞鏃舵惡甯﹀湴鍥炬暟鎹弬鏁颁娇鐢�)
+    function getMap2TwoArr() {
+        let data = []
+        mapData.forEach((item,index) => {
+            let data2 = []
+            item.forEach((val,idx) => {
+                data2.push(val.value)
+            })
+            data.push(data2)
+        })
+
+        return data;
+    }
+
+    function testMove() {
+        getMap2TwoArr()//娴嬭瘯鍦板浘鏁版嵁杞崲鏄惁姝e父
+        let json = "[{\n" +
+            "\t\t\"x\": 5,\n" +
+            "\t\t\"y\": 5\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 6,\n" +
+            "\t\t\"y\": 5\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 7,\n" +
+            "\t\t\"y\": 5\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 8,\n" +
+            "\t\t\"y\": 5\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 9,\n" +
+            "\t\t\"y\": 5\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 10,\n" +
+            "\t\t\"y\": 5\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 11,\n" +
+            "\t\t\"y\": 5\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 11,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 12,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 13,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 14,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 15,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 16,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 17,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 18,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 19,\n" +
+            "\t\t\"y\": 6\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 19,\n" +
+            "\t\t\"y\": 7\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 19,\n" +
+            "\t\t\"y\": 8\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 20,\n" +
+            "\t\t\"y\": 8\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 21,\n" +
+            "\t\t\"y\": 8\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 22,\n" +
+            "\t\t\"y\": 8\n" +
+            "\t},\n" +
+            "\t{\n" +
+            "\t\t\"x\": 23,\n" +
+            "\t\t\"y\": 8\n" +
+            "\t}\n" +
+            "]";
+        json = JSON.parse(json)
+        json.forEach((item,index) => {
+            moveCar(1, item.x, item.y);
+        })
+
+    }
+
+    /**
+     * 閲嶇疆鍦板浘
+     */
+    function resetMap() {
+        $.ajax({
+            url:baseUrl+"/console/map/resetMap/auth",
+            headers:{
+                'token': localStorage.getItem('token')
+            },
+            data:{},
+            method:'get',
+            success:function (res) {
+                layer.msg('閲嶇疆瀹屾垚');
+            }
+        })
     }
 
     // 灏忚溅鍋忕Щ鍔ㄧ敾
@@ -659,7 +793,7 @@
 </script>
 <script type="text/javascript">
     // 寮圭獥绔欑偣淇℃伅
-    $('.site').on('click',function(){
+    $('#mapDataId').on('click','.site',function(){
         var id = this.id.split("-")[1];
         $("#siteWindow").attr("style","display:block;");//鏄剧ずdiv
         $("#crnWindow").attr("style","display:none;");
@@ -725,7 +859,6 @@
     })
 
 
-
     var crn1Position = 0;
     var crn2Position = 0;
     var crn3Position = 0;
@@ -748,6 +881,12 @@
     setInterval(function () {
         getSitesInfo();
     }, 3000);
+
+    $("#system-toggle").on("click",(e) => {
+        systemSwitch()
+        e.stopPropagation();//琛ㄧず闃绘鍚戠埗鍏冪礌鍐掓场
+        e.preventDefault();//闃绘 鏂规硶闃绘鍏冪礌鍙戠敓榛樿鐨勮涓猴紙渚嬪锛屽綋鐐瑰嚮鎻愪氦鎸夐挳鏃堕樆姝㈠琛ㄥ崟鐨勬彁浜ゆ垨鑰卆鏍囩锛夈��
+    })
 
     // 绯荤粺杩愯寮�鍏�
     function systemSwitch() {
@@ -780,11 +919,11 @@
                 layer.close(index);
                 if (res.code === 200){
                     if (res.data.status) {
-                        $('#system-icon').attr("class", "system-icon-open");
+                        $('#system-toggle-checked').attr("checked", true);
                         $('#system-run-desc').html("绯荤粺杩愯涓�...");
                         parent.systemRunning = true;
                     } else {
-                        $('#system-icon').attr("class", "system-icon-close");
+                        $('#system-toggle-checked').attr("checked", false);
                         $('#system-run-desc').html("绯荤粺宸插仠姝�!");
                         parent.systemRunning = false;
                     }
@@ -808,11 +947,11 @@
             success: function (res) {
                 if (res.code === 200){
                     if (res.data.status) {
-                        $('#system-icon').attr("class", "system-icon-open");
+                        $('#system-toggle-checked').attr("checked", true);
                         $('#system-run-desc').html("绯荤粺杩愯涓�...");
                         parent.systemRunning = true;
                     } else {
-                        $('#system-icon').attr("class", "system-icon-close");
+                        $('#system-toggle-checked').attr("checked", false);
                         $('#system-run-desc').html("绯荤粺宸插仠姝�!");
                         parent.systemRunning = false;
                     }
@@ -923,102 +1062,6 @@
         });
     }
 
-    // 鍫嗗灈鏈哄亸绉诲姩鐢�
-    function crnAnimate(id, leftVal) {
-        switch (id) {
-            case 1:
-                $("#crn-1").animate({left: leftVal+'px'}, 1000);
-                crn1Position = leftVal;
-                break;
-            case 2:
-                $("#crn-2").animate({left: leftVal+'px'}, 1000);
-                crn2Position = leftVal;
-                break;
-            case 3:
-                $("#crn-3").animate({left: leftVal+'px'}, 1000);
-                crn3Position = leftVal;
-                break;
-            case 4:
-                $("#crn-4").animate({left: leftVal+'px'}, 1000);
-                crn4Position = leftVal;
-                break;
-            case 5:
-                $("#crn-5").animate({left: leftVal+'px'}, 1000);
-                crn5Position = leftVal;
-                break;
-            default:
-                break
-        }
-    }
-
-    // 椤甸潰鐐瑰嚮浜嬩欢鐩戝惉 ---------------------------------------------------------
-
-    // 杈撻�佽澶囩偣鍑讳簨浠�
-    // $('.site').on('click', function () {
-    // 	var id = this.id.split("-")[1];
-    // 	if (id === undefined) {
-    // 		return;
-    // 	}
-    // 	layer.open({
-    // 		title: id + " 绔欑偣淇℃伅璇︽儏",
-    // 		closeBtn: 0,
-    // 		skin: 'layui-layer-lan',
-    // 		offset: '180px',
-    // 		type: 1,
-    // 		shadeClose: true,
-    // 		content: $('#siteWindow'),
-    // 		area: ['35rem', '18rem'],
-    // 		btn: ['纭畾', '鍏抽棴'],
-    // 		success: function(layero, index){
-    // 			http.post(baseUrl+"/console/site/detail", {siteId: id}, function (res) {
-    // 				for (var val in res.data) {
-    // 					var find = $("#siteWindow").find(":input[name='" + val + "']");
-    // 					if (find[0].type==='text') {
-    // 						find.val(res.data[val]);
-    // 					} else if (find[0].type === 'checkbox') {
-    // 						find.attr("checked", res.data[val] === 'Y');
-    // 					}
-    // 				}
-    // 			})
-    // 		},
-    // 		end: function () {
-    // 			$(':input', $("#siteWindow")).val('').removeAttr('checked').removeAttr('selected');
-    // 		}
-    // 	});
-    // });
-
-    // 鍫嗗灈鏈虹偣鍑讳簨浠�
-    // $('.machine').on('click', function () {
-    // 	var id = this.id.split("-")[1];
-    // 	layer.open({
-    // 		title: id+"鍙峰爢鍨涙満",
-    // 		skin: 'layui-layer-lan',
-    // 		closeBtn: 0,
-    // 		type: 1,
-    // 		offset: '150px',
-    // 		shadeClose: true,
-    // 		content: $("#crnWindow"),
-    // 		area: ['40rem', '20rem'],
-    // 		btn: ['纭畾', '鍏抽棴'],
-    // 		success: function(layero, index){
-    // 			http.post(baseUrl+"/console/crn/detail", {crnNo: id}, function (res) {
-    // 				for (var val in res.data) {
-    // 					var find = $("#crnWindow").find(":input[name='" + val + "']");
-    // 					if (find[0].type==='text') {
-    // 						find.val(res.data[val]);
-    // 					} else if (find[0].type === 'checkbox') {
-    // 						find.attr("checked", res.data[val] === 'Y');
-    // 					}
-    // 				}
-    // 			})
-    // 		},
-    // 		end: function () {
-    // 			$(':input', $("#crnWindow")).val('').removeAttr('checked').removeAttr('selected');
-    // 		}
-    // 	});
-    // });
-
-
     // 灏忚溅鍋忕Щ鍔ㄧ敾
     function carAnimate(id, target) {
         var targetTop = 122;
@@ -1048,29 +1091,14 @@
         $("#site-" + id).animate({top: targetTop+'px'}, 1000);
     }
 
-
      //妤煎眰鍒囨崲鎸夐挳
-    function changFloor(x) {
-        switch (x) {
-            case 1:
-                $('#fool1').css("display","block")
-                $('#fool2').css("display","none")
-                $('#fool3').css("display","none")
-                return
-            case 2:
-                $('#fool1').css("display","none")
-                $('#fool2').css("display","block")
-                $('#fool3').css("display","none")
-                return
-            case 3:
-                $('#fool1').css("display","none")
-                $('#fool2').css("display","none")
-                $('#fool3').css("display","block")
-                return
-            default:
-                return;
-
-        }
+    function changFloor(e,x) {
+        $("#floorBtnBox button").each((index,item) => {
+            $(item).removeClass("btn-16-active")
+        })
+        $(e).addClass("btn-16-active")
+        currentLev = x
+        initMap(currentLev)
     }
 
 </script>

--
Gitblit v1.9.1