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/console.html | 1981 +++++++++++++++++++-------------------------------------- 1 files changed, 670 insertions(+), 1,311 deletions(-) diff --git a/src/main/webapp/views/console.html b/src/main/webapp/views/console.html index 788e404..f03c349 100644 --- a/src/main/webapp/views/console.html +++ b/src/main/webapp/views/console.html @@ -1,1329 +1,688 @@ <!DOCTYPE html> <html lang="en"> -<head> - <meta charset="utf-8"> - <title>WCS鎺у埗涓績</title> - <link rel="stylesheet" href="../static/css/console.css"> - <link rel="stylesheet" href="../static/css/animate.min.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> -</head> -<body> -<div class="root"> - <header class="header"> - <h1>鑷姩浠撳簱WCS鐩戞帶鍥�</h1> - <h6>AUTOMATIC WAREHOUSE WCS MONITORING DIAGRAM</h6> - </header> - <main class="main"> - <!--绗�1鍒� --> - <div class="site-row site-row-1"> - <div id="site-102" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 340px">102</div> + <head> + <meta charset="UTF-8"> + <title>WCS鎺у埗涓績</title> + <link rel="stylesheet" href="../static/css/animate.min.css"> + <link rel="stylesheet" href="../static/vue/element/element.css"> + <link rel="stylesheet" href="../static/css/console_vue.css"> + <link rel="stylesheet" href="../static/css/toggle-switch.css"> + <script type="text/javascript" src="../static/js/jquery/jquery-3.3.1.min.js"></script> + <script type="text/javascript" src="../static/layui/layui.js"></script> + <script type="text/javascript" src="../static/js/handlebars/handlebars-v4.5.3.js"></script> + <script type="text/javascript" src="../static/js/common.js"></script> + <script type="text/javascript" src="../static/vue/js/vue.min.js"></script> + <script type="text/javascript" src="../static/vue/element/element.js"></script> + </head> + <body> + <div id="app"> + <div style="display: flex;justify-content: center;align-items: center;width: 100%;margin-top: 150px;"> + <div id="mapDataId" style="zoom: 0.7;position: relative;"> + <div class="pointContainer" v-for="(row,index) in map" :key="index"> + <div v-for="(col,idx) in row" :key="idx"> + <div v-if="col.value == 0"> + <!-- 瀛愯建閬� 璺緞涓虹┛姊溅棰勮璺緞鍒欐樉绀虹┛姊溅棰滆壊鍜岀┛姊溅鍙� --> + <div :style="{background: checkAdvancePath(index,idx).length == 0 ? '':shuttleColorList[checkAdvancePath(index,idx)[0]]}" class="item" v-if="col.data.length > 0">{{col.data}}</div> + <div :style="{background: checkAdvancePath(index,idx).length == 0 ? '':shuttleColorList[checkAdvancePath(index,idx)[0]]}" class="item" v-else>{{checkAdvancePath(index,idx).length == 0 ? idx:checkAdvancePath(index,idx)}}</div> + </div> + <div v-else-if="col.value == 3"> + <!-- 姣嶈建閬� 璺緞涓虹┛姊溅棰勮璺緞鍒欐樉绀虹┛姊溅棰滆壊鍜岀┛姊溅鍙� --> + <div :style="{background: checkAdvancePath(index,idx).length == 0 ? '#5af':shuttleColorList[checkAdvancePath(index,idx)[0]]}" class="item">{{checkAdvancePath(index,idx).length == 0 ? '⇅⇄':checkAdvancePath(index,idx)}}</div> + </div> + <div v-else-if="col.value == 4"> + <!-- 绔欑偣 --> + <div class="site" :id="'site-' + col.data" @click="openSite(col.data)">{{col.data}}</div> + </div> + <div v-else-if="col.value == 5"> + <!-- 鍏呯數妗� --> + <div class="item" style="font-size: 24px">⚡</div> + </div> + <div v-else-if="col.value == -999"> + <!-- 璺緞鍗犵敤鍖哄煙 --> + <div class="item" style="background:#f83333;color: #fff;">{{idx}}</div> + </div> + <div v-else-if="col.value < 0"> + <!-- 绂佹鏄剧ず鍖哄煙 --> + <div class="item" style="visibility: hidden">{{idx}}</div> + </div> + <div v-else> + <div class="item" v-if="col.data.length > 0">{{col.data}}</div> + <div class="item" v-else>{{idx}}-{{col.value}}</div> + </div> + </div> - <div id="site-101" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 20px">101</div> + <div> + <!-- 鏄剧ず琛屽彿 --> + <div class="item" style="background: none;color: #000;">#{{index+1}}</div> + </div> + </div> - <div id="site-100" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 184px">100</div> - </div> - <!--绗�2鍒�--> - <div class="site-row site-row-2"> - </div> - <!-- 绗�3鍒� --> - <div class="site-row site-row-3"> - <div id="site-118" class="site" style="height: 18px;line-height: 18px;width:80px;">118</div> + <!--杈撳嚭灏忚溅--> + <div v-for="(car,idx) in currentLevShuttleList" + :style="{ + left: getCarPosition(car.wcsPoint.x,car.wcsPoint.y)[1] + ,top: getCarPosition(car.wcsPoint.x,car.wcsPoint.y)[0] + ,color: shuttleColorList[car.shuttleNo] + }" + class="sxcar" :id="'sxcar-' + car.shuttleNo"> + {{car.shuttleNo}} + </div> - <div id="site-115" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 47px">115</div> + </div> - <div id="site-112" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 168px">112</div> + <!--杈撳嚭妤煎眰--> + <div style="height: 100%;"> + <div class="floorBtnBox" v-for="(lev,idx) in floorList"> + <el-button :style="{background:currentLev === lev ? '#7DCDFF':''}" @click="changFloor(lev)">{{lev}}F</el-button> + </div> + <div> + <el-button @click="testMove()">娴嬭瘯绉诲姩杞�</el-button> + <el-button @click="resetMap()">閲嶇疆鍦板浘</el-button> + </div> + </div> + </div> - <div id="site-107" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 105px">107</div> + <div class="footer"> + <!-- 鎬诲紑鍏� --> + <div class="line-status"> + <div class="body-head">鎬诲紑鍏�</div> + <div class="switch" @click="systemSwitch"> + <label id="system-toggle" class="toggle-switch" style="margin-left: 20px;"> + <input id="system-toggle-checked" disabled 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 id="site-103" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 184px">103</div> - </div> - <!-- 绗�4鍒� --> - <div class="site-row site-row-4"> - <div id="site-119" class="site" style="height: 18px;line-height: 18px;width:80px;">119</div> + <div class="switch_r"> + <p>绯荤粺鐘舵��</p> + <p id="system-run-desc">绯荤粺杩愯涓�</p> + </div> + </div> + </div> + <!-- 鍥涘悜绌挎杞︾姸鎬� --> + <div class="line-status"> + <div class="body-head">绌挎杞︾姸鎬�</div> + <div class="shuttle-status-box"> + <div v-for="(item,idx) in shuttleList" class="state"> + <span :style="{color: shuttleColorList[item.shuttleNo]}">鍥涘悜绌挎杞� {{item.shuttleNo}}</span> + <span v-if="item.protocolStatus == 1" + class="state-ss shuttle-idle">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 2" + class="state-ss shuttle-working">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 3" + class="state-ss shuttle-waiting">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 4" + class="state-ss shuttle-charging">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 5" + class="state-ss shuttle-charging-waiting">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 6" + class="state-ss shuttle-fixing">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 7" + class="state-ss shuttle-offline">{{item.protocolStatus$}}</span> + <span v-else class="state-ss shuttle-offline">{{item.protocolStatus$}}</span> + </div> + </div> + <div class="allStatus"><span>鎵�鏈夌姸鎬�</span></div> + <div class="allStatus item-group"> + <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 class="lift-status-box"> + <div v-for="(item,idx) in liftList" class="state states"> + <span>鎻愬崌鏈� {{item.liftNo}}</span> + <span v-if="item.protocolStatus == 1" + class="state-ss lift-idle">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 2" + class="state-ss lift-working">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 3" + class="state-ss lift-waiting">{{item.protocolStatus$}}</span> + <span v-else-if="item.protocolStatus == 4" + class="state-ss lift-offline">{{item.protocolStatus$}}</span> + <span v-else class="state-ss lift-offline">{{item.protocolStatus$}}</span> + </div> + </div> + <div class="allStatus"><span>鎵�鏈夌姸鎬�</span></div> + <div class="allStatus item-group"> + <span class="lift-idle">绌洪棽</span> + <span class="lift-working">浣滀笟涓�</span> + <span class="lift-waiting">绛夊緟纭</span> + <span class="lift-offline">绂荤嚎</span> + </div> + </div> + <!-- 杈撻�佺嚎鐘舵�� --> + <div class="line-status"> + <div class="body-head">杈撻�佺嚎鐘舵��</div> + <div class="state states"> + <span>杩愯緭绾挎�绘暟</span> + <span class="line-ss">9</span> + </div> + <div class="allStatus"><span>鎵�鏈夌姸鎬�</span></div> + <div class="allStatus item-group"> + <span class="site-auto-run-id">鑷姩+鏈夌墿+ID</span> + <span class="site-auto-run">鑷姩+鏈夌墿</span> + <span class="site-auto-id">鑷姩+ID</span> + <span class="site-auto">鑷姩</span> + <span class="site-unauto">闈炶嚜鍔�/鎵嬪姩</span> + </div> + </div> + <!-- 鏉$爜琛ㄦ牸 --> + <div class="bar-code"> + <div class="body-head" id="code">鏉$爜鎵弿鍣�</div> + <div class="tablebox"> + <div class="table-head"> + <li><span>鏉$爜鍚嶇О</span><span class="right">鎵爜鏃堕棿</span></li> + </div> + <div id="barcode1" class="table-body"> + <li v-for="(item,index) in codeList1" :key="index"><span>{{item.barcode}}</span><span class="right">{{item.time}}</span></li> + </div> + </div> + <div class="tablebox"> + <div class="table-head"> + <li><span>鏉$爜鍚嶇О</span><span class="right">鎵爜鏃堕棿</span></li> + </div> + <div id="barcode2" class="table-body"> + <li v-for="(item,index) in codeList2" :key="index"><span>{{item.barcode}}</span><span class="right">{{item.time}}</span></li> + </div> + </div> + </div> + </div> - <div id="site-117" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 27px">117</div> - <div id="site-116" class="site" style="height: 18px;line-height: 18px;width:80px;">116</div> + <!-- 杈撻�佽澶囧脊绐� --> + <div id="siteWindow" :style="{display:siteWindow?'block':'none'}" class="animate__animated animate__fadeIn"> + <!-- 琛ㄥご --> + <div id="siteWindow-head"> + <div class="detailed"></div> + <button @click="siteWindow = false"></button> + </div> + <!-- 琛ㄥ唴瀹� --> + <div class="siteWindow-body"> + <form> + <!-- 璁惧鍙� --> + <div class="form-item"> + <div class="form-item-label"> + <span>璁惧鍙凤細</span> + </div> + <div class="form-item-input"> + <input type="text" name="siteId" value=""> + </div> + </div> + <!-- 宸ヤ綔鍙� --> + <div class="form-item"> + <div class="form-item-label"> + <span>宸ヤ綔鍙凤細</span> + </div> + <div class="form-item-input"> + <input type="text" name="workNo" value=""> + </div> + </div> + <!-- 宸ヤ綔鐘舵�� --> + <div class="form-item"> + <div class="form-item-label"> + <span>宸ヤ綔鐘舵�侊細</span> + </div> + <div class="form-item-input"> + <input type="text" name="wrkSts" value=""> + </div> + </div> + <div class="form-item"> + <!-- 鑷姩 --> + <div class="form-item-checkbox"> + <div class="form-item-label-checkbox"> + <span>鑷姩</span> + </div> + <div class="form-item-input-checkbox"> + <input type="checkbox" name="autoing"> + </div> + </div> + <!-- 鏈夌墿 --> + <div class="form-item-checkbox"> + <div class="form-item-label-checkbox"> + <span>鏈夌墿</span> + </div> + <div class="form-item-input-checkbox"> + <input type="checkbox" name="loading"> + </div> + </div> + <!-- 鑳藉叆 --> + <div class="form-item-checkbox"> + <div class="form-item-label-checkbox"> + <span>鑳藉叆</span> + </div> + <div class="form-item-input-checkbox"> + <input type="checkbox" name="canining"> + </div> + </div> + <!-- 鑳藉嚭 --> + <div class="form-item-checkbox"> + <div class="form-item-label-checkbox"> + <span>鑳藉嚭</span> + </div> + <div class="form-item-input-checkbox"> + <input type="checkbox" name="canouting"> + </div> + </div> + </div> + <!-- 鍑哄叆绫诲瀷 --> + <div class="form-item"> + <div class="form-item-label"> + <span>鍑哄叆绫诲瀷锛�</span> + </div> + <div class="form-item-input"> + <input type="text" name="ioType" value=""> + </div> + </div> + <!-- 婧愮珯 --> + <div class="form-item"> + <div class="form-item-label"> + <span>婧愮珯锛�</span> + </div> + <div class="form-item-input"> + <input type="text" name="sourceStaNo" value=""> + </div> + </div> + <!-- 鐩爣绔� --> + <div class="form-item"> + <div class="form-item-label"> + <span>鐩爣绔欙細</span> + </div> + <div class="form-item-input"> + <input type="text" name="staNo" value=""> + </div> + </div> + <!-- 婧愬簱浣� --> + <div class="form-item"> + <div class="form-item-label"> + <span>婧愬簱浣嶏細</span> + </div> + <div class="form-item-input"> + <input type="text" name="sourceLocNo" value=""> + </div> + </div> + <!-- 鐩爣搴撲綅 --> + <div class="form-item"> + <div class="form-item-label"> + <span>鐩爣搴撲綅锛�</span> + </div> + <div class="form-item-input"> + <input type="text" name="locNo" value=""> + </div> + </div> + </form> + </div> + </div> - <div id="site-113" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 168px">113</div> - <div id="site-114" class="site" style="height: 18px;line-height: 18px;width:80px;">114</div> + </div> + <script> + var app = new Vue({ + el: '#app', + data: { + map: [],//鍦板浘鏁版嵁 + currentLev: 1,//鍦板浘褰撳墠妤煎眰 + siteWindow: false, //绔欑偣寮圭獥鏄剧ず榛樿涓嶆樉绀� + floorList: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10], //褰撳墠椤圭洰妤煎眰 + shuttleList: [], //鍥涘悜绌挎杞﹂泦鍚� + currentLevShuttleList: [],//褰撳墠妤煎眰鍥涘悜绌挎杞﹂泦鍚� + shuttleColorList: [],//鍥涘悜绌挎杞﹂鑹查泦鍚� + liftList: [], //鎻愬崌鏈洪泦鍚� + systemStatus: true,//绯荤粺杩愯鐘舵�� + consoleInterval: null,//瀹氭椂鍣ㄥ瓨鍌ㄥ彉閲� + codeList1: [],//鏉$爜List + codeList2: [],//鏉$爜List + }, + created() { + this.init() + }, + watch: { - <div id="site-111" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 25px">111</div> - <div id="site-110" class="site" style="height: 18px;line-height: 18px;width:80px;">110</div> - <div id="site-109" class="site" style="height: 18px;line-height: 18px;width:80px;">109</div> - <div id="site-108" class="site" style="height: 18px;line-height: 18px;width:80px;">108</div> + }, + methods: { + init() { + this.getMap(this.currentLev) + this.getSystemRunningStatus() //鑾峰彇绯荤粺杩愯鐘舵�� - <div id="site-104" class="site" style="height: 18px;line-height: 18px;width:80px;margin-top: 184px">104</div> - <div id="site-105" class="site" style="height: 18px;line-height: 18px;width:80px;">105</div> - </div> + this.consoleInterval = setInterval(() => { + this.getShuttleStateInfo() //鑾峰彇鍥涘悜绌挎杞︿俊鎭� + this.getLiftStateInfo() //鑾峰彇鎻愬崌鏈轰俊鎭� + this.getSiteInfo() //鑾峰彇杈撻�佺珯鐐规暟鎹� + this.getMap(this.currentLev) //鑾峰彇瀹炴椂鍦板浘鏁版嵁 + this.getCodeData()//鑾峰彇鏉$爜 + }, 1000) + }, + //鑾峰彇鍦板浘鏁版嵁 + getMap(lev) { + $.ajax({ + type: "get", + url: baseUrl + "/console/map/" + lev + "/auth", + headers: { + 'token': localStorage.getItem('token') + }, + success: (res) => { + let data = res.data + let tmp = [] + for (let i = 1; i < data.length - 1; i++) { + tmp.push(data[i]) + } + // console.log(tmp) + this.map = tmp + } + }) + }, + openSite(id) { + this.siteWindow = true; //鎵撳紑绔欑偣淇℃伅寮圭獥 + $(".detailed").empty(); + $('.detailed').append(id + '绔欑偣璇︾粏淇℃伅'); + $.ajax({ + url: baseUrl + "/console/site/detail", + headers: { + 'token': localStorage.getItem('token') + }, + data: { + siteId: id + }, + method: 'post', + success: 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'); + } + } + } - <!-- 璐ф灦 + 鍫嗗灈鏈� + 鍏ュ簱绔欑偣 --> - <div class="main-part"> - <div class="lane"> - <!-- 璐ф灦 --> - <!-- 1鍙峰爢鍨涙満 --> - <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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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">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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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">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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">3#</span> - </div> - <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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">4#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">11#</span> - </div> - <!-- 鍫嗗灈鏈� --> - <div class="crn"> - <hr class="pathway"> - <div id="crn-2" 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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">12#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">13#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">14#</span> - </div> - <span class="row-no"></span> - <!-- 璐ф灦 --> - <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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">15#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">16#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">17#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">18#</span> - </div> - <!-- 鍫嗗灈鏈� --> - <div class="crn"> - <hr class="pathway"> - <div id="crn-3" 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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">19#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">20#</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> - <button class="item">14</button> - <button class="item">15</button> - <button class="item">16</button> - <button class="item">17</button> - <button class="item">18</button> - <button class="item">19</button> - <button class="item">20</button> - <button class="item">21</button> - <button class="item">22</button> - <button class="item">23</button> - <button class="item">24</button> - <button class="item">25</button> - <span class="row-no">21#</span> - </div> - </div> - </div> - </main> - <footer class="footer"> - <!-- 鎬诲紑鍏� --> - <div class="system-state"> - <div class="body-head">鎬诲紑鍏�</div> - <div class="switch"> - <div id="system-icon" class="system-icon-open" onclick="systemSwitch()"></div> - <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> - <div class="state"> - <span>鍫嗗灈鏈� 2</span> - <span class="state-ss machine-auto-flag ">鑷姩</span> + }) + }, + getSiteInfo() { + //鑾峰彇杈撻�佺珯鐐规暟鎹� + $.ajax({ + url: baseUrl+ "/console/latest/data/site", + headers: {'token': localStorage.getItem('token')}, + method: 'POST', + success: function (res) { + if (res.code === 200){ + var sites = res.data; + for (var i = 0; i < sites.length; i++){ + var siteEl = $("#site-"+sites[i].siteId); + siteEl.attr("class", "site " + sites[i].siteStatus); + if (sites[i].workNo != null && sites[i].workNo>0) { + siteEl.html(sites[i].siteId + "[" + sites[i].workNo + "]"); + } else { + siteEl.html(sites[i].siteId); + } + } + } else if (res.code === 403){ + parent.location.href = baseUrl+"/login"; + } else { + console.log(res.msg); + } + } + }); + }, + changFloor(lev) { + this.currentLev = lev + this.currentLevShuttleList = [] + this.getMap(lev) + }, + getShuttleStateInfo() { + // 鍥涘悜绌挎杞︿俊鎭〃鑾峰彇 + let that = this + $.ajax({ + url: baseUrl + "/shuttle/table/shuttle/state", + headers: { + 'token': localStorage.getItem('token') + }, + method: 'POST', + success: function(res) { + if (res.code == 200) { + let currentLevShuttle = []//褰撳墠妤煎眰灏忚溅闆嗗悎 + res.data.forEach((item,idx) => { + if (item != null && item.point != undefined && item.point != null) { + if (item.point.z == that.currentLev) { + currentLevShuttle.push(item); + } + } + }) + that.currentLevShuttleList = currentLevShuttle + that.shuttleList = res.data - </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> - </div> - </div> - <!-- 杈撻�佺嚎鐘舵�� --> - <div class="line-status"> - <div class="body-head">杈撻�佺嚎鐘舵��</div> - <div class="state states"> - <span>杩愯緭绾挎�绘暟</span> - <span class="line-ss">48</span> - </div> - <div class="button"><span>鎵�鏈夌姸鎬�</span></div> - <div class="button item-group"> - <span class="site-auto-run-id">鑷姩+鏈夌墿+ID</span> - <span class="site-auto-run">鑷姩+鏈夌墿</span> - <span class="site-auto-id">鑷姩+ID</span> - <span class="site-auto">鑷姩</span> - <span class="site-unauto">闈炶嚜鍔�/鎵嬪姩</span> - </div> - </div> - <!-- 鏉$爜琛ㄦ牸 --> - <div class="bar-code"> - <div class="body-head" id="code">鏉$爜鎵弿鍣�</div> - <div class="tablebox"> - <div class="table-head"> - <li><span>鏉$爜鍚嶇О</span><span class="right">鎵爜鏃堕棿</span></li> - </div> - <div id="barcode1" class="table-body"> + if (that.shuttleColorList.length == 0) { + let colorList = []//闅忔満灏忚溅棰滆壊 + res.data.forEach((item,idx) => { + colorList[item.shuttleNo] = that.colorRGB() + }) + that.shuttleColorList = colorList + } + } + } + }); + }, + getLiftStateInfo() { + // 鎻愬崌鏈轰俊鎭〃鑾峰彇 + let that = this + $.ajax({ + url: baseUrl + "/lift/table/lift/state", + headers: { + 'token': localStorage.getItem('token') + }, + method: 'POST', + success: function(res) { + if (res.code == 200) { + that.liftList = res.data + } + } + }); + }, + systemSwitch() { + // 绯荤粺寮�鍏� + let that = this + if (this.systemStatus) { + this.$prompt('璇疯緭鍏ュ彛浠わ紝骞跺仠姝CS绯荤粺', '鎻愮ず', { + confirmButtonText: '纭畾', + cancelButtonText: '鍙栨秷', + }).then(({ + value + }) => { + that.doSwitch(0, value) + }).catch(() => { - </div> - </div> - <div class="tablebox"> - <div class="table-head"> - <li><span>鏉$爜鍚嶇О</span><span class="right">鎵爜鏃堕棿</span></li> - </div> - <div id="barcode2" class="table-body"> + }); + } else { + this.doSwitch(1) + } + }, + doSwitch(operatorType, password) { + let that = this + $.ajax({ + url: baseUrl + "/console/system/switch", + headers: { + 'token': localStorage.getItem('token') + }, + data: { + operatorType: operatorType, + password: password + }, + method: 'POST', + success: function(res) { + if (res.code === 200) { + if (res.data.status) { + $('#system-toggle-checked').attr("checked", true); + $('#system-run-desc').html("绯荤粺杩愯涓�..."); + that.systemStatus = true; + parent.systemRunning = true; + } else { + $('#system-toggle-checked').attr("checked", false); + $('#system-run-desc').html("绯荤粺宸插仠姝�!"); + that.systemStatus = false; + parent.systemRunning = false; + } + } else if (res.code === 403) { + parent.location.href = baseUrl + "/login"; + } else { + that.$message({ + message: res.msg, + type: 'error' + }); + } + } + }); + }, + getSystemRunningStatus() { + // 鑾峰彇wcs绯荤粺杩愯鐘舵�� + let that = this + $.ajax({ + url: baseUrl + "/console/system/running/status", + headers: { + 'token': localStorage.getItem('token') + }, + method: 'POST', + success: function(res) { + if (res.code === 200) { + if (res.data.status) { + $('#system-toggle-checked').attr("checked", true); + $('#system-run-desc').html("绯荤粺杩愯涓�..."); + that.systemStatus = true; + parent.systemRunning = true; + } else { + $('#system-toggle-checked').attr("checked", false); + $('#system-run-desc').html("绯荤粺宸插仠姝�!"); + that.systemStatus = false; + parent.systemRunning = false; + } + } else if (res.code === 403) { + parent.location.href = baseUrl + "/login"; + } else { + that.$message({ + message: res.msg, + type: 'error' + }); + } + } + }); + }, + getCarPosition(x,y) { + //璁$畻鍥涘悜绌挎杞﹀浘鏍囦綅缃� + let top = (x * 35 - 35) + "px" //闇�瑕佸噺鍘诲皬杞﹁嚜宸辨墍鍗犻珮搴� + let left = (y * 35) + "px" //闇�瑕佸噺鍘诲皬杞﹁嚜宸辨墍鍗犲搴� + return [top,left]; + }, + testMove() { + let that = this + clearInterval(this.consoleInterval)//娓呯悊瀹氭椂鍣� - </div> - </div> - <div class="tablebox"> - <div class="table-head"> - <li><span>鏉$爜鍚嶇О</span><span class="right">鎵爜鏃堕棿</span></li> - </div> - <div id="barcode3" class="table-body"> + let shuttleList = this.currentLevShuttleList + $.ajax({ + url: baseUrl + "/static/testMoveData.json", + headers: { + 'token': localStorage.getItem('token') + }, + method: 'GET', + success: function(res) { + shuttleList[0].moveAdvancePath = res + that.currentLevShuttleList = shuttleList - </div> - </div> - </div> - </footer> - - <!-- 鍫嗗灈鏈哄脊绐� --> - <div id="crnWindow" style="display: none;" class="animate__animated animate__fadeIn"> - <div id="crnWindow-head"> - <div class='detailed'></div> - <button></button> - </div> - <form> - <!-- 鍫嗗灈鏈哄彿 --> - <div class="form-item"> - <div class="form-item-label" style> - <span>鍫嗗灈鏈哄彿锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="crnNo" value=""> - </div> - </div> - <!-- 宸ヤ綔鍙� --> - <div class="form-item"> - <div class="form-item-label"> - <span>宸ヤ綔鍙凤細</span> - </div> - <div class="form-item-input"> - <input type="text" name="workNo" value=""> - </div> - </div> - <!-- 绔欐簮 --> - <div class="form-item"> - <div class="form-item-label"> - <span>绔欐簮锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="sourceStaNo" value=""> - </div> - </div> - <!-- 鐩爣绔� --> - <div class="form-item"> - <div class="form-item-label"> - <span>鐩爣绔欙細</span> - </div> - <div class="form-item-input"> - <input type="text" name="staNo" value=""> - </div> - </div> - <!-- 宸ヤ綔鐘舵�� --> - <div class="form-item"> - <div class="form-item-label"> - <span>宸ヤ綔鐘舵�侊細</span> - </div> - <div class="form-item-input"> - <input type="text" name="wrkSts" value=""> - </div> - </div> - <!-- 鍑哄叆绫诲瀷 --> - <div class="form-item"> - <div class="form-item-label"> - <span>鍑哄叆绫诲瀷锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="ioType" value=""> - </div> - </div> - <!-- 婧愬簱浣� --> - <div class="form-item"> - <div class="form-item-label"> - <span>婧愬簱浣嶏細</span> - </div> - <div class="form-item-input"> - <input type="text" name="sourceLocNo" value=""> - </div> - </div> - <!-- 鐩爣搴撲綅 --> - <div class="form-item"> - <div class="form-item-label"> - <span>鐩爣搴撲綅锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="locNo" value=""> - </div> - </div> - <!-- 鍫嗗灈鏈虹姸鎬� --> - <div class="form-item"> - <div class="form-item-label"> - <span>鍫嗗灈鏈虹姸鎬侊細</span> - </div> - <div class="form-item-input"> - <input type="text" name="crnStatus" value=""> - </div> - </div> - <!-- 寮傚父 --> - <div class="form-item"> - <div class="form-item-label"> - <span>寮傚父锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="error" value=""> - </div> - </div> - </form> - </div> - - <!-- 杈撻�佽澶囧脊绐� --> - <div id="siteWindow" style="display: none;" class="animate__animated animate__fadeIn"> - <!-- 琛ㄥご --> - <div id="siteWindow-head"> - <div class='detailed'></div> - <button></button> - </div> - <form> - <!-- 璁惧鍙� --> - <div class="form-item" > - <div class="form-item-label"> - <span>璁惧鍙凤細</span> - </div> - <div class="form-item-input"> - <input type="text" name="siteId" value=""> - </div> - </div> - <!-- 宸ヤ綔鍙� --> - <div class="form-item"> - <div class="form-item-label"> - <span>宸ヤ綔鍙凤細</span> - </div> - <div class="form-item-input"> - <input type="text" name="workNo" value=""> - </div> - </div> - <!-- 宸ヤ綔鐘舵�� --> - <div class="form-item"> - <div class="form-item-label"> - <span>宸ヤ綔鐘舵�侊細</span> - </div> - <div class="form-item-input"> - <input type="text" name="wrkSts" value=""> - </div> - </div> - <!-- 鑷姩 --> - <div class="form-item-checkbox"> - <div class="form-item-label-checkbox"> - <span>鑷姩</span> - </div> - <div class="form-item-input-checkbox"> - <input type="checkbox" name="autoing"> - </div> - </div> - <!-- 鏈夌墿 --> - <div class="form-item-checkbox"> - <div class="form-item-label-checkbox"> - <span>鏈夌墿</span> - </div> - <div class="form-item-input-checkbox"> - <input type="checkbox" name="loading"> - </div> - </div> - <!-- 鑳藉叆 --> - <div class="form-item-checkbox"> - <div class="form-item-label-checkbox"> - <span>鑳藉叆</span> - </div> - <div class="form-item-input-checkbox"> - <input type="checkbox" name="canining"> - </div> - </div> - <!-- 鑳藉嚭 --> - <div class="form-item-checkbox"> - <div class="form-item-label-checkbox"> - <span>鑳藉嚭</span> - </div> - <div class="form-item-input-checkbox"> - <input type="checkbox" name="canouting"> - </div> - </div> - <!-- 鍑哄叆绫诲瀷 --> - <div class="form-item"> - <div class="form-item-label"> - <span>鍑哄叆绫诲瀷锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="ioType" value=""> - </div> - </div> - <!-- 婧愮珯 --> - <div class="form-item"> - <div class="form-item-label"> - <span>婧愮珯锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="sourceStaNo" value=""> - </div> - </div> - <!-- 鐩爣绔� --> - <div class="form-item"> - <div class="form-item-label"> - <span>鐩爣绔欙細</span> - </div> - <div class="form-item-input"> - <input type="text" name="staNo" value=""> - </div> - </div> - <!-- 婧愬簱浣� --> - <div class="form-item"> - <div class="form-item-label"> - <span>婧愬簱浣嶏細</span> - </div> - <div class="form-item-input"> - <input type="text" name="sourceLocNo" value=""> - </div> - </div> - <!-- 鐩爣搴撲綅 --> - <div class="form-item"> - <div class="form-item-label"> - <span>鐩爣搴撲綅锛�</span> - </div> - <div class="form-item-input"> - <input type="text" name="locNo" value=""> - </div> - </div> - - </form> - </div> -</div> -</body> + let index = 0 + let tmp = null + tmp = setInterval(() => { + if (index < res.length) { + that.currentLevShuttleList[0].wcsPoint.y = res[index].y + that.currentLevShuttleList[0].wcsPoint.x = res[index].x + index++ + }else { + clearInterval(tmp) + that.init() + } + },1000) + } + }); + }, + colorRGB(){ + //闅忔満棰滆壊 + const r = Math.floor(Math.random()*256); + const g = Math.floor(Math.random()*256); + const b = Math.floor(Math.random()*256); + return `rgb(${r},${g},${b})`; + }, + checkAdvancePath(x,y) { + //妫�娴嬭矾寰勬槸鍚︿负绌挎杞﹂璁¤矾寰勶紝濡倄鍜寉璺緞鏄┛姊溅棰勮璺緞锛屽垯杩斿洖灏忚溅鍙� + this.currentLevShuttleList.forEach((item,idx) => { + if (item.moveAdvancePath != null) { + item.moveAdvancePath.forEach((path,index) => { + if (path.x === x && path.y === y) { + return item.shuttleNo; + } + }) + } + }) + let data = [] + let shuttleList = this.currentLevShuttleList; + for (var i = 0; i < shuttleList.length; i++) { + let shuttle = shuttleList[i] + let moveAdvancePath = shuttle.moveAdvancePath + if (moveAdvancePath != null) { + for (var j = 0; j < moveAdvancePath.length; j++) { + let path = moveAdvancePath[j] + if (path.x-1 === x && path.y === y) {//璺緞绗﹀悎 + data.push(shuttle.shuttleNo) + continue; + } + } + } + } + return data;//杩斿洖灏忚溅鍙烽泦鍚� + }, + resetMap() { + //閲嶇疆鍦板浘 + let that = this + $.ajax({ + url:baseUrl+"/console/map/resetMap/auth", + headers:{ + 'token': localStorage.getItem('token') + }, + data:{}, + method:'get', + success:function (res) { + that.$message({ + message: '閲嶇疆瀹屾垚', + type: 'success' + }); + } + }) + }, + getCodeData(){ + let that = this + $.ajax({ + url:baseUrl +'/console/barcode/output/site', + method:'GET', + success:function (res) { + if(res.code === 200){ + let data = JSON.parse(res.data) + if(data.length<=5){ + that.codeList1 = data + } else { + tData1 = data.slice(0,5) + tData2 = data.splice(5,10) + } + } + } + }) + } + } + }) + </script> + </body> </html> -<script> - var tData = [] - var tData1 = [] - var tData2 = [] - var tData3 = [] - function getCodeData(){ - $.ajax({ - url:baseUrl +'/console/barcode/output/site', - method:'GET', - success:function (res) { - if(res.code === 200){ - tData = eval(res.data); - if(tData.length<=5){ - tData1 = tData - } else if (tData.length<=10){ - tData1 = tData.slice(0,5) - tData.splice(0,5) - tData2 = tData - } else if(tData.length<=15){ - tData1 = tData.slice(0,5) - tData2 = tData.slice(6,10) - tData.splice(0,10) - tData3 = tData - } else { - tData = tData.slice(-15) - tData1 = tData.slice(-15) - tData2 = tData.slice(-10) - tData3 = tData.slice(-5) - - } - } - } - }) - } - setInterval(function () { - getCodeData(); - renderBarCode(); - }, 1000) - - - - - function renderBarCode() { - for (var i = 0;i<tData1.length;i++){ - var str1 = '<li><span>' + tData1[i].barcode + '</span><span class="right">' + tData1[i].time + '</span></li>' - $('#barcode1').append(str1) - } - for(var j = 0;j<tData2.length;j++){ - var str2 = '<li><span>' + tData2[j].barcode + '</span><span class="right">' + tData2[j].time + '</span></li>' - $('#barcode2').append(str2) - } - for(var k = 0;k<tData3.length;k++){ - var str3 = '<li><span>' + tData3[k].barcode + '</span><span class="right">' + tData3[k].time + '</span></li>' - $('#barcode3').append(str3) - } - } -</script> -<script type="text/javascript"> - // 寮圭獥绔欑偣淇℃伅 - $('.site').on('click',function(){ - var id = this.id.split("-")[1]; - $("#siteWindow").attr("style","display:block;");//鏄剧ずdiv - $("#crnWindow").attr("style","display:none;"); - $(".detailed").empty(); - $('.detailed').append(id+'绔欑偣璇︾粏淇℃伅'); - $.ajax({ - url:baseUrl+"/console/site/detail", - headers:{ - 'token': localStorage.getItem('token') - }, - data:{ - siteId: id - }, - method:'post', - success: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'); - } - } - } - - }) - - }); - // 鍫嗗灈鏈轰俊鎭� - $('.machine').on('click',function(){ - var id = this.id.split("-")[1]; - $("#crnWindow").attr('style','display:block;'); - $("#siteWindow").attr("style","display:none;"); - $('.detailed').empty(); - $('.detailed').append(id+'鍙峰爢鍨涙満'); - $.ajax({ - url:baseUrl+"/console/crn/detail", - headers:{ - 'token': localStorage.getItem('token') - }, - data:{ - crnNo: id - }, - method:'post', - success: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'); - } - } - } - - }) - - }) - // 寮圭獥鍏抽棴 - $('button').on('click',function(){ - $('#siteWindow').attr('style','display:none') - $('#crnWindow').attr('style','display:none') - }) - - - - var crn1Position = 0; - var crn2Position = 0; - var crn3Position = 0; - var crn4Position = 0; - var crn5Position = 0; - - // 鍒濆鍖� - getSitesInfo(); - getCrnInfo(); - getSystemRunningStatus(); - getBarcodeInfo(); - getScaleInfo(); - // 瀹炴椂璁块棶 - setInterval(function () { - getCrnInfo(); - getSystemRunningStatus(); - getBarcodeInfo(); - getScaleInfo(); - }, 1000); - setInterval(function () { - getSitesInfo(); - }, 3000); - - // 绯荤粺杩愯寮�鍏� - function systemSwitch() { - if (parent.systemRunning){ - layer.prompt({title: '璇疯緭鍏ュ彛浠わ紝骞跺仠姝� WCS 绯荤粺', formType: 1, shadeClose: true}, function(pass, idx){ - layer.close(idx); - doSwitch(0, pass); // 鍋滄wcs绯荤粺 - }); - } else { - doSwitch(1); // 鍚姩wcs绯荤粺 - } - } - - // 璇锋眰鏈嶅姟鍣ㄦ帶鍒秝cs绯荤粺杩愯鐘舵�� - function doSwitch(operatorType, password) { - // 鍔犺浇tips - var index = layer.load(1, { - shade: [0.1,'#fff'] - }); - $.ajax({ - url: baseUrl+ "/console/system/switch", - headers: {'token': localStorage.getItem('token')}, - // async: false, - data: { - operatorType: operatorType, - password: password - }, - method: 'POST', - success: function (res) { - layer.close(index); - if (res.code === 200){ - if (res.data.status) { - $('#system-icon').attr("class", "system-icon-open"); - $('#system-run-desc').html("绯荤粺杩愯涓�..."); - parent.systemRunning = true; - } else { - $('#system-icon').attr("class", "system-icon-close"); - $('#system-run-desc').html("绯荤粺宸插仠姝�!"); - parent.systemRunning = false; - } - } else if (res.code === 403){ - parent.location.href = baseUrl+"/login"; - } else { - console.log(res.msg); - - } - } - }); - - } - - // 鑾峰彇wcs绯荤粺杩愯鐘舵�� - function getSystemRunningStatus() { - $.ajax({ - url: baseUrl+ "/console/system/running/status", - headers: {'token': localStorage.getItem('token')}, - method: 'POST', - success: function (res) { - if (res.code === 200){ - if (res.data.status) { - $('#system-icon').attr("class", "system-icon-open"); - $('#system-run-desc').html("绯荤粺杩愯涓�..."); - parent.systemRunning = true; - } else { - $('#system-icon').attr("class", "system-icon-close"); - $('#system-run-desc').html("绯荤粺宸插仠姝�!"); - parent.systemRunning = false; - } - } else if (res.code === 403){ - parent.location.href = baseUrl+"/login"; - } else { - console.log(res.msg); - } - } - }); - } - - // 杈撻�佽澶囧疄鏃舵暟鎹幏鍙� - function getSitesInfo(){ - $.ajax({ - url: baseUrl+ "/console/latest/data/site", - headers: {'token': localStorage.getItem('token')}, - method: 'POST', - success: function (res) { - if (res.code === 200){ - var sites = res.data; - for (var i = 0; i < sites.length; i++){ - var siteEl = $("#site-"+sites[i].siteId); - siteEl.attr("class", "site " + sites[i].siteStatus); - if (sites[i].workNo != null && sites[i].workNo>0) { - siteEl.html(sites[i].siteId + "[" + sites[i].workNo + "]"); - } else { - siteEl.html(sites[i].siteId); - } - if (i+1===8) { - carAnimate(i+1, Number(sites[i].nearbySta)); - } - } - } else if (res.code === 403){ - parent.location.href = baseUrl+"/login"; - } else { - console.log(res.msg); - } - } - }); - } - - // 鍫嗗灈鏈哄疄鏃舵暟鎹幏鍙� - function getCrnInfo(){ - $.ajax({ - url: baseUrl+ "/console/latest/data/crn", - headers: {'token': localStorage.getItem('token')}, - method: 'POST', - success: function (res) { - if (res.code === 200){ - var crns = res.data; - for (var i = 0; i < crns.length; i++){ - var crnEl = $("#crn-"+crns[i].crnId); - crnEl.attr("class", "machine " + crns[i].crnStatus); - var unit = ($('.item').eq(0).width()+4)/2; - crnEl.animate({left: (crns[i].bay * unit + 25) +'px'}, 1000); - } - } else if (res.code === 403){ - parent.location.href = baseUrl+"/login"; - } else { - console.log(res.msg); - } - } - }); - } - - // 鎵爜鍣ㄥ疄鏃舵暟鎹幏鍙� - function getBarcodeInfo(){ - $.ajax({ - url: baseUrl+ "/console/latest/data/barcode", - headers: {'token': localStorage.getItem('token')}, - method: 'POST', - success: function (res) { - if (res.code === 200){ - var barcodes = res.data; - for (var i = 0; i < barcodes.length; i++){ - $("#code-decoder-data-"+barcodes[i].barcodeId).html(barcodes[i].codeValue); - } - } else if (res.code === 403){ - parent.location.href = baseUrl+"/login"; - } else { - console.log(res.msg); - } - } - }); - } - - // 纾呯Г瀹炴椂鏁版嵁鑾峰彇 - function getScaleInfo(){ - $.ajax({ - url: baseUrl+ "/console/latest/data/scale", - headers: {'token': localStorage.getItem('token')}, - method: 'POST', - success: function (res) { - - if (res.code === 200){ - var sclaes = res.data; - for (var i = 0; i < sclaes.length; i++){ - console.log(sclaes[i].scaleId + ":" + sclaes[i].value) - $("#scale-data-"+sclaes[i].scaleId).text(sclaes[i].value); - } - } else if (res.code === 403){ - parent.location.href = baseUrl+"/login"; - } else { - console.log(res.msg); - } - } - }); - } - - // 鍫嗗灈鏈哄亸绉诲姩鐢� - 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 - } - } - -</script> -- Gitblit v1.9.1